{"version":3,"sources":["site/gallery/config.js","lib/polyfill-ie/index.js","components/notFound/notFound.js","env.js","lib/app-version/index.js","components/form/buttons/button.js","lib/ui-error/errorMessage.js","lib/ui-error/errorPopup.js","lib/icons-svg/icons/NarrowRight.js","cssInJs/variables.js","config.js","lib/icons-svg/icons/Loading--circle.js","lib/ui-loading-v2/sectionLoading.js","lib/utils-core/url.js","lib/utils-core/form.js","lib/utils-core/array.js","lib/utils-core/date.js","lib/utils-core/css.js","lib/utils-core/ui.js","lib/utils-core/money.js","lib/utils-core/text.js","lib/utils-core/random.js","lib/utils-core/object.js","lib/utils-core/media.js","lib/utils-core/index.js","lib/css-emotion/breakpoints.js","lib/css-emotion/mixin.js","site/siteUtils.js","utils/index.js","lib/net-api/index.js","lib/dev-mediaQueryStatus/index.js","lib/seo/meta-tag.js","lib/seo/tracking--deprecated.js","lib/animation/animationUtils.js","lib/net-loader/loadJs.js","lib/ui-parallax/index.js","lib/router/useRouter.js","lib/store/reducers.js","lib/store/storeProvider.js","lib/router/useHistoryStore.js","lib/router/handleLink.js","lib/router/siteLink.js","lib/instagram-feed/feedStyle.js","lib/instagram-feed/feed.js","lib/utils-core/debounce.js","lib/youtube/iframeApi.js","lib/youtube/youtubeEmbedPopup.js","site/_cmsItems/cmsUtils.js","site/_cmsItems/code-instagram/render.js","site/_offline/index.js","lib/form/formModelHelper.js","lib/form/formBuilder.js","lib/form/validatorHelper.js","lib/form/validators/required.js","lib/form/validators/email.js","lib/form/validators/date.js","lib/form/validators/length.js","lib/form/validators.js","lib/form/formRenderHelper.js","lib/form/components/ValidationAlert.js","lib/form/controls/TextInput.js","lib/form/controls/RadioListInput.js","lib/form/controls/CheckboxListInput.js","lib/form/controls/DateSeparateInput.js","lib/form/controls/FileInput.js","lib/form/controls/index.js","lib/form/controls/TextareaInput.js","lib/form/controls/CheckboxInput.js","lib/form/controls/SelectInput.js","lib/form/controls/HiddenInput.js","lib/form/controlRenderer.js","lib/form/formValidate.js","lib/form/useForm.js","lib/tracking/gtm.js","site/button/buttonStyle.js","site/button/formButton.js","site/_cmsItems/code-subscribe/subscribe.js","site/_cmsItems/code-subscribe/subscribeFormModel.js","site/_cmsItems/code-subscribe/render.js","site/_cmsItems/html/view/renderHtml.js","site/_cmsItems/html/view/html.js","site/_cmsItems/html/render.js","site/bannerSize/bannerSize.js","site/_cmsItems/imagePanel/view/imagePanelStyle.js","site/useParallax/useParallax.js","site/_cmsItems/imagePanel/view/imagePanel.js","site/_cmsItems/imagePanel/render.js","site/_cmsItems/multiColumnPanel2/view/multiColumnPanel2Style.js","site/_cmsItems/multiColumnPanel2/view/renderHtml.js","cms/items/videoPanelNew/VideoPanelStyle.js","cms/items/videoPanelNew/view.js","site/_cmsItems/multiColumnPanel2/view/multiColumnPanel2.js","site/_cmsItems/multiColumnPanel2/view/iframeApi.js","site/_cmsItems/multiColumnPanel2/render.js","site/tileList/tileList.js","site/tileList/tileListStyle.js","site/_cmsItems/pageTiles/view/pageTile/pageTile.js","site/_cmsItems/pageTiles/view/pageTile/pageTileStyle.js","site/_cmsItems/pageTiles/view/pageTiles.js","site/_cmsItems/pageTiles/render.js","site/_cmsItems/panel/view/panel.js","site/_cmsItems/panel/render.js","site/gallery/galleryTiles.js","site/gallery/galleryStyle.js","site/portal/portal.js","site/gallery/gallery.js","site/_cmsItems/photoGallery/view/photoGallery.js","site/_cmsItems/photoGallery/render.js","site/shareButtons/shareButtons.js","site/shareButtons/shareButtonStyle.js","site/_cmsItems/sharingIcons/view/sharingIcons.js","site/_cmsItems/sharingIcons/render.js","site/_cmsItems/sketchfabItem/view/sketchfabItemStyle.js","site/_cmsItems/sketchfabItem/view/sketchfabItem.js","cms/items/youtubeNew/view.js","site/_cmsItems/videoPanel/view/videoPanel.js","cms/utils/cmsUtils.js","cms/items/html/view.js","site/_cmsItems/videoPanelWithText/view/VideoPanelWithText.js","site/_cmsItems/videoPanelWithText/render.js","site/_cmsItems/items-generated.js","site/_cmsItems/sketchfabItem/render.js","site/_cmsItems/videoPanel/render.js","cms/items/bannerPanel/view.js","cms/items/bannerItem/view.js","cms/items/panel/view.js","cms/items/imagePanel/view.js","cms/items/pageTiles/view.js","components/tiles/bsyc/style.js","components/tiles/bsyc/view.js","cms/items/singleBanner/view.js","cms/items/contactForm/contactForm.js","cms/items/contactForm/contactFormModel.js","cms/items/contactForm/view.js","lib/youtube/youtubeBanner--mobilePopup.js","cms/items/VideoPanel/view.js","site/searchResult/searchResult.js","components/TextWithJavaScript/view.js","cms/items/code/view.js","cms/items/blogPosts/view.js","cms/items/blogPostTitle/view.js","cms/items/videoHolder/view.js","cms/items/videoItem/view.js","cms/items/multiColumnPanel/view.js","cms/items/expandableHtml/view.js","components/photoGallery/style.js","components/photoGallery/view.js","components/testimonial/testimonialPanel/style.js","components/testimonial/testimonialItem/style.js","components/testimonial/testimonialItem/view.js","components/testimonial/testimonialPanel/view.js","components/expandablePanel/style.js","components/expandablePanel/view.js","cms/items/VideoPanelWithText/view.js","cms/items/multiColumnPanelNew/view.js","cms/items/item.js","cms/pages/viewPage/viewPage.js","lib/instagram-useInstagram/index.js","cms/services/cms-radio-sender.js","cms/services/cms-radio-receiver.js","cms/services/cms-html-editor.js","cms/services/cms-page-controller.js","cms/pages/editPage/editPage.js","layout/globalNav/globalNav.js","layout/topHeader/navBar.js","layout/backButton/backButtonStyle.js","layout/backButton/backButton.js","layout/hamburger/hamburgerStyle.js","layout/hamburger/hamburger.js","layout/topHeader/topHeaderStyle.js","layout/topHeader/topHeader.js","components/bottomDrawer/index.js","layout/bottomDock/bottomDock.js","layout/popup/commonVideoPopup.js","AppRouteChanged.js","App.js","serviceWorker.js","index.js","site/tileList/config.js"],"names":["exports","settings","breakpointNames","numOfTilesPerBreakpoints","marginLR","marginTB","Element","prototype","matches","msMatchesSelector","webkitMatchesSelector","closest","s","el","this","parentElement","parentNode","nodeType","NotFound","props","debugInfo","className","href","onClick","e","preventDefault","window","location","reload","refreshPage","history","back","goBack","style","marginTop","color","fontSize","pageUrl","loadFrom","config","isProd","process","locale","REACT_APP_COUNTRY_LOCALE","hostname","toLowerCase","indexOf","search","getCountry","siteName","titleSuffix","siteCode","apiBase","resourceBase","baseOrigin","origin","GATSBY_BASEURL","getBaseUrl","cmsEndpoint","ver","updateDate","stripeKey","console","log","getDevCartId","localStorage","getItem","setDevCartId","cartId","setItem","AppVersion","React","useState","checkStatus","setCheckStatus","env","useEffect","updateSW","then","timer","setTimeout","clearTimeout","button","type","AppVersionPage","margin","width","Button","status","children","btnStyle","buttonStyle","disabled","role","aria-hidden","ErrorMessage","errors","summaryMessage","length","message","Array","isArray","map","error","index","key","ErrorPopup","title","messages","push","css","position","padding","maxWidth","maxHeight","background","top","left","transform","zIndex","inx","dangerouslySetInnerHTML","__html","SvgNarrowRight","colors","blueColor","darkGrayColor","lightGrayColor","greenColor","variables","familyBase","familyHeader","primaryColor","fontColor","bgColor","breakpoints","cssEmotion","iconColors","siteConfig","primary","secondary","SvgLoading","height","viewBox","preserveAspectRatio","cx","cy","r","fill","stroke","strokeWidth","attributeName","repeatCount","dur","values","keyTimes","keySplines","calcMode","begin","Loading","undefined","loaded","setLoaded","loading","minHeight","display","justifyContent","alignItems","opacity","transition","isExternalLink","link","getLinkFromElement","linkEl","getAttribute","getLinkInfo","currentPath","pathname","linkFiltered","replace","linkLower","isExternal","isHash","isTel","isMailTo","url","path","i","exts","isStaticFile","ext","getExtension","filename","split","pop","getFilename","getFolderPath","parentDepth","slice","join","toQueryString","params","Object","keys","encodeURIComponent","getYoutubeId","getSlug","text","getWebUrl","schema","getErrors","result","forEach","err","errorMessage","getErrorMessage","convertToObject","array","reduce","obj","item","convertToKeyValues","value","moveItem","list","fromIndex","toIndex","splice","removed","removeItem","insertItem","find","fn","findIndex","contains","distinct","comparer","filtered","x","sum","total","equal","list1","list2","found","j","caseInsensitiveCompare","a","b","localeCompare","compareIgnoreEmpty","asc","isNaN","addDays","date","days","Date","setDate","getDate","formatDate","dateObj","formatStr","toDate","format","formatYYYYMMDDToday","dd","mm","getMonth","yyyy","getFullYear","formatYYYYMMDD","formatDDMMYYYY","parseDate","parseISO","toDateTime","dateStr","parse","isValidDate","d","bgUrl","imageUrl","encodeURI","decodeURI","bgUrlStyle","screenWidth","innerWidth","document","documentElement","clientWidth","body","screenHeight","innerHeight","clientHeight","outerWidth","offsetWidth","outerHeight","offsetHeight","hasClass","classList","match","RegExp","addClass","add","removeClass","remove","reg","toggleClass","scrollTo","selector","duration","delay","findElement","offset","elementOffset","gsap","to","ease","querySelectorOrNull","querySelector","rect","getBoundingClientRect","scrollLeft","pageXOffset","scrollTop","pageYOffset","isElementInViewport","bottom","right","getCurrentBreakpoint","bpHolder","getComputedStyle","getPropertyValue","formatMoney","number","fraction","formatter","Intl","NumberFormat","currency","minimumFractionDigits","toMonthlyCost","amount","frequency","isBlank","str","test","isEmpty","isNumeric","num","capitalize","expression","charAt","toUpperCase","toFieldName","trim","toHtml","truncateWords","maxLen","separator","ellipsis","pos","lastIndexOf","substr","numberWithCommas","parts","toString","registerPlugin","ScrollToPlugin","formatNumber","Math","round","toTelephoneNumber","like","shortId","shortid","guid","uuid","toCamel","o","newO","origKey","newKey","hasOwnProperty","constructor","getImageSetPath","setId","info","getPathDetails","baseFolder","setIds","lastFolder","classNames","form","ui","money","random","object","media","mq","facepaint","bp","mqMin","mqMax","mediaQuery","matchMedia","isMin","isMax","overlay","content","isMobile","md","resourcePath","utils","fullUrl","isNZ","coreUtils","site","useApi","response","setResponse","setErrors","setStatus","request","setRequest","options","apiNetJwt","fetch","res","ok","json","statusText","JSON","fetchData","hasErrors","containsErrorMessage","msg","finding","some","addErrors","errs","done","send","sendRaw","httpOptionFn","args","setResult","reset","usePost","formDataFn","data","method","post","headers","stringify","sending","sendFormData","useGet","get","MediaQueryStatus","MetaTag","seoData","assign","description","name","keywords","language","country","faceBookDomainVerifi","heroImageUrl","rel","canonical","alternates","hreflang","MAX","MIN","getScrollProgress","scroll","scrollY","progress","boundsTop","viewport","bounds","setClass","pr","range","prVal","min","max","y","removeTransform","getScreenSize","defaultHolder","storeName","loadJs","promises","scripts","script","loadScript","Promise","all","holder_","forceToReload","holder","resolve","reject","networkLoaded","existing","createElement","src","onload","onerror","getElementsByTagName","appendChild","defaultSettings","cutoffPadding","speed","ParallaxData","screenSize","panels","imageRatio","panelHeight","elements","timeoutId","useParallax","handleScroll","element","au","calculated","fromTop","toTop","backgroundPositionY","init","useLayoutEffect","addEventListener","removeEventListener","cnt","panel","querySelectorAll","autoPanelHeight","parseFloat","shadowHeight","shadowWidth","baseHeight","backgroundSize","useRouter","useParams","useLocation","useHistory","useRouteMatch","useMemo","navigate","Redirect","hash","query","queryString","initialState","page","menu","popup","reducer","state","action","payload","Error","StoreContext","createContext","StoreProvider","useReducer","dispatch","Provider","useStore","useContext","useHistoryStore","loc","setHistory","last","handleElementLink","externalHandler","linkInfo","handled","SiteLink","target","other","goToLink","stopPropagation","tiles","marginLeft","marginRight","flexWrap","tile","flexBasis","cursor","tileImage","mixin","backgroundColor","tileIcon","InstagramFeed","Feeds","posts","numOfPost","xs","sm","lg","xl","xxl","displayingPosts","Feed","alt","debounce","ms","_","apply","arguments","loadApi","onApiReady","YT","tag","id","onYouTubeIframeAPIReady","firstScriptTag","insertBefore","thumbnailMax","videoId","getYoutubeCode","YoutubeEmbedPopup","posterUrl","yt","posterImageUrl","popupIndex","setPopupIndex","backgroundImage","sources","defaultVal","payloads","hasItemInPageData","pageData","matchFn","sections","hasItemInItems","items","getCodeJson","code","hasItemInPageDataByItemTypeCode","itemTypeCode","renderRule","cmsOption","cmsUtils","itemElt","navigator","onLine","findControl","controlNameOrIndex","root","controls","findControlTraverse","controlName","control","getValue","getValueTraverse","helperFns","getFilesTraverse","getKeyValueTraverse","keyValue","controlType","customValueFn","files","abstractControl","controlObject","validators","controlOptions","touched","incomplete","findValidator","controlArray","ctrl","disableValidators","formModelHelper","parent","hasRequiredValidator","getNameForValidator","label","createValidator","opt","validate","defaultOpt","continueToValidate","getValidatorOptions","val","isValidEmail","mail","isDate","isPast","now","getTime","isValidLength","validator","Required","validateOpt","triggeredByChange","Email","PastDate","PastDateNullAllowed","Length","validateControl","getLabel","formOption","requiredMark","getLabelAsString","ValidationAlert","TextInput","handleChange","helpText","attrs","forceUsePlaceholder","fieldId","usePlaceholder","fieldLabel","placeHolder","valueStr","prependText","htmlFor","onChange","onKeyDown","onBlur","autoComplete","placeholder","checked","optionValue","includes","DateSeparateInput","thisYear","year","setYear","month","setMonth","day","setDay","handleChangeInner","persist","months","selectStyle","fromYear","recentYear","handleChangeDay","handleChangeMonth","m","handleChangeYear","FileInput","Components","RadioListInput","helpLabelText","option","inline","TextareaInput","textAreaRef","useRef","textAreaHeight","setTextAreaHeight","parentHeight","setParentHeight","disableAutoHeight","current","h","scrollHeight","rows","ref","CheckboxInput","linkText","CheckboxListInput","SelectInput","mainCategory","filter","selected","defaultValue","HiddenInput","renderControlDirect","Component","getControl","renderControl","formRoot","nameOrIndex","validateTraverse","errorsFromControl","errorsFromSub","useForm","initialFormModel","formModel","setFormModel","template","onControlChanged","controlFromEvent","getControlValue","onBeforeUpdateValue","validateGroup","successHandler","errorHandler","formValidate","model","controlRenderer","validateForm","getFiles","hasGTM","dataLayer","pageView","pageTitle","pageOpt","event","sendEvent","eventName","sendGAEvent","category","buttonColor","baseStyle","overflow","appearance","darken","textDecoration","buttonBg","borderRadius","buttonTxt","smallStyle","fontWeight","letterSpacing","FormButton","overridingStyle","ss","Subscribe","fb","email","sendingStatus","setSendingStatus","gtm","contactEmail","render","colorBlue","textAlign","node","attribs","attributesToProps","replaceImg","class","domToReact","replaceButton","_embedDataList","codeType","renderHtml","_cmsOption","replaceEmbedCode","html","isCmsEdit","cmsViewMode","embedDataList","Html","cssClass","anchorName","htmlBlock","data-cms-html","data-cms-item-id","itemId","processed","initPopupWidget","_href","setAttribute","handleClick","mqBanner","bannerThin","bannerStandard","getImageBannerStyle","heightSet","setName","bannerSize","bannerHeight","backgroundPositionX","photoCredit","transformOrigin","panelRef","_settings","paddingHeightRatio","stretchToFit","actionRange","cutTop","cutBottom","getSettings","onScroll","bgHeight","bgWidth","cutTopPx","cutBottomPx","onResize","ImagePanel","photoCreditUrl","hideTop","hideBottom","pageOptions","imagePath","cssClass2","parallaxSetting","container","paddingLeft","paddingRight","alignSelf","order","aspectRatio","html__wrapper","flexDirection","html__container","html__item","videoContainer","videolink","playIcon","backImgContainer","VideoPanelNew","openVideo","posterFrameUrl","MultiColumnPanel","bgTheme","backgroundTile","leftPanel","leftPanelBanner","leftTextVertical","leftTextHorizontal","leftTextBgColor","leftTextWidth","leftYoutube","leftPosterFrameUrl","rightPanel","rightPanelBanner","rightTextVertical","rightTextHorizontal","rightTextBgColor","rightTextWidth","rightYoutube","rightPosterFrameUrl","linkUrl","content2","idFirstUse","GetItem","itemName","bannerItems","checkOtherPanel","textVertical","textHorizontal","textBgColor","textWidth","youtubeCode","video","videoLinkOrId","playerId","toggler","setToggler","popupImages","enablejsapi","autoplay","loop","showinfo","modestbranding","allowfullscreen","wmode","allow","frameBorder","_imgs","data-cms-item-id2","sourceIndex","dots","infinite","autoplaySpeed","fade","slidesToShow","slidesToScroll","ImgItem","TileList","useSlider","slickSettings","tilesSlider","getTileListStyle","marginBottom","PageTile","tileLink","disableLink","desc","tileDesc","paddingTop","paddingBottom","flexGrow","flexShrink","rgba","tileSlider","tileBg","backgroundPosition","backgroundRepeat","tileContent","lineHeight","textTransform","WebkitLineClamp","WebkitBoxOrient","getTileStyle","PageTiles","pagesSerialized","getPages","Panel","subItems","waveColor","wave","subItemsElts","subItem","Item","data-svg-origin","GalleryTiles","images","openPopupImage","img","ImageTile","image","getImageTileStyle","thumbnailUrl","Portal","mount","getElementById","removeChild","createPortal","set","Gallery","galleryImages","caption","Fragment","PhotoGallery","ShareButtons","shareUrl","topLabel","shareButtons","shareButtonTitle","shareButton","FacebookShareButton","FacebookIcon","size","WhatsappShareButton","WhatsappIcon","EmailShareButton","subject","EmailIcon","SharingIcons","sketchfab__item","SketchfabItem","border","YoutubeNew","youtubeBannerRef","playerStatus","setPlayerStatus","playerSize","setPlayerSize","ytPlayer","setYtPlayer","muted","setMuted","mobileImageUrl","canPlayVideo","loadVideo","sizeCalculator","containerSize","w","getSize","checkInterTime","checkYoutubeIframeApJabaScript","setInterval","clearInterval","player","Player","events","onStateChange","PlayerState","ENDED","playVideo","onReady","mute","onError","resized","canPlay","pauseVideo","unMute","VideoPanel","videoCode","block","embed","ReactDOM","replaceEmbedCodes","buttons","restructureButton","span","innerHTML","VideoPanelWithText","code_instagram","code_subscribe","imagePanel","multiColumnPanel2","pageTiles","photoGallery","BannerPanel","slides","BannerItem","captionTitle","captionButton","titlePanel","linkOverlay","data-pxh","pageTileElts","Tile","responsive","breakpoint","pageTile__tile","flex","tile__content","tile__flip__wrapper","tile__bg","boxShadow","tile__bg2","tile__details","PageTilesBsyc","idx","colorTheme","data-aos","SingleBanner","alignV","Contact","emailReceiver","fileAttachment","mailchimpApiKey","mailchimpAudienceKey","phone","enquiry","attachments","mailChimpError","setMailChimpError","mailChimpErrorMemo","results","MailChimpError","formData","FormData","append","file","uploadFile","ContactForm","YoutubeBannerMobilePopup","countPlayedRef","popupOpened","setPopupOpened","countPlayed","channel","isOpen","onClose","SearchResult","keyword","q","pages","PageList","searchHighlight","TextWithJavScript","javaScriptCode","substring","nonjavaScriptCode","javaScriptTopCode","javaScriptInsideCode","_src","async","defer","_functionName","functionName","Code","codeJson","BlogPosts","numOfTileLines","parseInt","tilesPerLine","step","tilesToShow","setTilesToShow","showMore","BlogPostTitle","postDate","VideoHolder","VideoItem","captionTitleYoutube","shortDesc","reverse","columnWidths","mobileColumnWidths","countItem","countD","countM","col","panelWidth","ExpandableHtml","open","setOpen","buttonTitle","icon","iconOpen","iconClosed","panelCollapsed","panelOpen","thumbnails","thumbnail","bg","_images","_thumbImages","_texts","_text","testimonialPanel","testimonialItem","borderBottom","testimonialItem_title","testimonialItem_star","testimonialItem_desc","testimonialItem_bottom","TestimonialItem","ratingValue","rating","TestimonialPanel","startRatingColor","testimonialItems","exTextItem","ExpandablePanel","data-anchor-status","data-cms-item-anchor","MultiColumnPanelNew","columnLaptop","useMediaQuery","_tileType","PageMemo","memo","sectionItems","section","Section","sectionName","getMetaTag","pageTypeCode","prevProps","nextProps","ViewPage","pageLoaded","setPageLoaded","setData","embedStatus","setEmbedStatus","loadEmbedJs","instgrm","Embeds","useInstagram","redirectTo","CmsRadioSender","controller","cloned","postMessage","htmlChanges","sendMessageToParent","returnTo","CmsRadioReceiver","self","selectItem","mediaSelectedCKEditor","getAllDirtyHtml","sender","returnAllDirtyHtml","getHtml","returnHtml","tools","callFunction","funcNum","selectedPath","selectItemFromController","CmsHtmlEditor","ckeditorConfig","startupFocus","filebrowserBrowseUrl","filebrowserImageBrowseUrl","extraPlugins","toolbar","groups","extraAllowedContent","ckeditorStylesSet","attributes","$editor","CKEDITOR","disableAutoInline","editor","stylesSet","on","evt","ed","markDirtyHtml","instances","cmsCurrentEditor","getData","destroy","CmsPageController","viewOnly","receiver","htmlEditor","$","initGlobalVars","prop","off","attr","is","change","_value","ctrlKey","which","saveAllDirtyHtml","$item","fromController","doubleclicked","cke_top","closeEditingItem","findItem","removeAttr","depth","showHtmlEditor","each","selectControllerItem","openEdit","editableParent","parents","first","close","dataCmsItemId2","show","extend","htmleditor","getAnchors","anchors","htmlbody","floor","animate","$section","getCurrentHtml","ItemId","SectionId","Content","SectionId2","Content2","itemid","formvals","cms_replace_item_html","EditPage","publishVer","editVer","pageId","cmsPageController","catch","GlobalNav","NavBar","currentLocation","menuItemElts","MenuItem","onCloseMenu","subMenuOpened","setSubMenuOpened","SubMenuItem","toggleSubmenu","BackButton","rs","barW","barH","space","line","transitionProperty","transitionDuration","transitionDelay","transitionTimingFunction","outline","font","buttonScrolled","hamburger","line1","line2","line3","lineActive1","lineActive2","lineActive3","Hamburger","opened","toggleMenu","scrolled","aria-label","topScrolled","logo","logoImg","logoScrolled","phoneIcon","TopHeader","menuOpened","setMenuOpened","setScrolled","useScrollPosition","prevPos","currPos","behavior","BottomDrawer","defaults","slider","currentTranslateY","inititialised","tsEventHandled","showHidePaddingBar","hammer","Hammer","Manager","Pan","direction","DIRECTION_VERTICAL","threshold","switch","deltaY","moveDeltaTmp","initEvent","bar","delta","getBaseY","move","targetY","getTargetY","fromTo","links","barHeight","dy","BottomDock","isCurrent","linkElts","iconHover","bottomMenu","touchAction","userSelect","CommonVideoPopup","setSources","onOpen","AppRouteChanged","parallax","anchor","AppLayout","AOS","App","isLocalhost","Boolean","serviceUpdateCheckerInterval","registerValidSW","swUrl","serviceWorker","register","updateViaCache","registration","scope","waiting","update","preventDevToolsReloadLoop","getRegistration","active","oldSw","ev","newSw","onupdatefound","installing","installingWorker","onstatechange","onUpdate","onSuccess","ready","URL","contentType","unregister","checkValidServiceWorker"],"mappings":"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","file":"static/js/main.8b37b608.chunk.js","sourcesContent":["const settings = {\n  //                         xs,    sm,    md,    lg,    xl,    xxl          <-- only sample, check your breakpoints settings.\n  //                         <      576    768    992    1200   1600\n  breakpointNames:          ['xs', 'sm',  'md',  'lg',  'xl',  'xxl'],\n  numOfTilesPerBreakpoints: [2,     2,     2,     3,     4,     6],\n  marginLR:                 [14,    20,    20,    20,    20,    20],\n  marginTB:                 [14,    20,    20,    20,    20,    20],\n}\n\nexports.settings = settings","// closest\r\n\r\nif (!Element.prototype.matches) {\r\n  Element.prototype.matches = Element.prototype.msMatchesSelector || \r\n                              Element.prototype.webkitMatchesSelector;\r\n}\r\n\r\nif (!Element.prototype.closest) {\r\n  Element.prototype.closest = function(s) {\r\n    var el = this;\r\n\r\n    do {\r\n      if (el.matches(s)) return el;\r\n      el = el.parentElement || el.parentNode;\r\n    } while (el !== null && el.nodeType === 1);\r\n    return null;\r\n  };\r\n}\r\n\r\n\r\n// getBoundingClientRect","import React from 'react';\n\nexport function NotFound(props) {\n  const debugInfo = props.debugInfo;\n\n  function refreshPage(e) {\n    e.preventDefault();\n    if (typeof window !== `undefined`) {\n      window.location.reload();\n    }\n  }\n\n  function goBack(e) {\n    e.preventDefault();\n    if (typeof window !== `undefined`) {\n      window.history.back();\n    }\n  }\n\n  return (\n    <div className=\"error-panel\">\n      <div className=\"container\">\n        <h1>404 Error</h1>\n\n        <p>Please <a href=\"/\" onClick={(e) => refreshPage(e)}>refresh</a> your browser.</p>\n        <div>\n          <button onClick={(e) => goBack(e)}>or Go Back</button>\n        </div>\n\n        {\n          debugInfo &&\n          <pre style={{ marginTop: '3rem', color: 'chocolate', fontSize: '0.7rem' }}\n          >Error message: {debugInfo.pageUrl} - {debugInfo.loadFrom} </pre>\n        }\n\n      </div>\n\n    </div>\n\n  )\n}","const config = {\n  isProd: process.env.NODE_ENV === \"production\",\n  locale: getLocale(),\n  siteName: process.env.REACT_APP_SITENAME,\n  titleSuffix: process.env.REACT_APP_TITLESUFFIX,\n  siteCode: process.env.REACT_APP_SITECODE,\n  apiBase: process.env.REACT_APP_API_ENDPOINT,\n  resourceBase: process.env.REACT_APP_RESOURCE_BASEURL,\n  baseOrigin: getBaseUrl(),\n  cmsEndpoint: process.env.REACT_APP_CMS_ENDPOINT,\n  ver: process.env.REACT_APP_VERSION,\n  updateDate: process.env.REACT_APP_UPDATED_AT,\n  stripeKey: process.env.REACT_APP_STRIPE_KEY\n  \n  //bvClientId: process.env.REACT_APP_BAZZAR_CLIENT_ID,\n  //bvSiteId: process.env.REACT_APP_BAZZAR_SITE_ID,\n  //bvEnv: process.env.REACT_APP_BAZZAR_ENV,\n  //bvLocale: getLocale() === 'nz' ? 'en_NZ' : 'en_AU',\n}\n\nfunction getLocale() {\n  return process.env.REACT_APP_COUNTRY_LOCALE || getCountry()\n}\n\nfunction getCountry() {\n  if (typeof window !== `undefined`) {\n    if (window.location.hostname.toLowerCase().indexOf(\".nz\") >= 0) return 'nz';\n    if (window.location.hostname.toLowerCase().indexOf(\"-nz\") >= 0) return 'nz';\n    if (window.location.search === '?nz=true') return 'nz';\n  }\n  return 'au';\n}\n\nfunction getBaseUrl() {\n  if (typeof window !== `undefined`) {\n  return window.location.origin;\n  }\n  return process.env.GATSBY_BASEURL;\n}\n\nconsole.log(process.env, config)\nexport default {\n  ...config,\n  getDevCartId: function() {\n    return !config.isProd && typeof window !== `undefined` ? window.localStorage.getItem('cart') : null\n  },\n  setDevCartId: function(cartId) {\n    if(!config.isProd && typeof window !== `undefined`) window.localStorage.setItem('cart', cartId)\n  }\n}","import React from 'react';\r\nimport env from '../../env';\r\n\r\nexport function AppVersion(props) {\r\n\r\n  const [checkStatus, setCheckStatus] = React.useState('idle')\r\n  //const [secs, setSecs] = React.useState(10)\r\n  const ver = env.ver;\r\n  const updateDate = env.updateDate;\r\n\r\n  React.useEffect(() => {\r\n    console.log(checkStatus);\r\n    if (checkStatus === 'checking') {\r\n      if (typeof window !== `undefined`) {\r\n        window.updateSW().then(function () {\r\n          console.log('sw update called');\r\n          setCheckStatus('checked')\r\n        })\r\n      }\r\n\r\n      let timer = setTimeout(() => {\r\n        if (typeof window !== `undefined`) {\r\n          window.location.reload()\r\n        }\r\n      }, 5000)\r\n      return () => { clearTimeout(timer) }\r\n    }\r\n  }, [checkStatus])\r\n\r\n  function checkUpdates(e) {\r\n    if (typeof window !== `undefined`) {\r\n      if (window.updateSW) {\r\n        setCheckStatus('checking')\r\n      } else {\r\n        window.location.reload();\r\n      }\r\n    }\r\n  }\r\n\r\n  function refreshApp(e) {\r\n    if (typeof window !== `undefined`) {\r\n      window.location.reload();\r\n    }\r\n  }\r\n\r\n  let button = null\r\n  if (checkStatus === 'checking') {\r\n    button = <button className=\"btn btn-primary\" type=\"button\">Checking App Version...</button>;\r\n  } else if (checkStatus === 'checked') {\r\n    button = <><button className=\"btn btn-primary\" type=\"button\" onClick={refreshApp}>Reloading App...</button> <div>(If this does't reload automatically, please click the above button)</div></>;\r\n  } else {\r\n    button = <button className=\"btn btn-primary\" type=\"button\" onClick={checkUpdates}>Update App (Refresh)</button>;\r\n  }\r\n\r\n  return (\r\n    <div className=\"appInfo htmlPanel\">\r\n      <div className=\"appInfo__ver\">\r\n        <b>Version</b>: {ver} ({updateDate})\r\n      </div>\r\n      <div style={{ marginTop: '1rem' }}>\r\n        {button}\r\n      </div>\r\n    </div>\r\n  );\r\n}\r\n\r\nexport function AppVersionPage(props) {\r\n  return (\r\n    <div style={{ margin: '5rem auto', width: '900px' }}>\r\n      <AppVersion />\r\n    </div>);\r\n}","import React from 'react';\n\nexport function Button({onClick, status, children, btnStyle='primary', className}) {\n  let buttonStyle = 'btn-' + btnStyle;\n  return (\n    <button className={`btn ${buttonStyle} ${className}`} onClick={onClick} type=\"button\" disabled={status === 'pending'}>\n      {status === 'pending' && <span className=\"spinner-grow spinner-grow-sm\" role=\"status\" aria-hidden=\"true\"></span>}\n      {children}\n    </button>\n  );\n}","import React from 'react';\r\n\r\nexport const ErrorMessage = ({ errors, summaryMessage = null }) => {\r\n  if (!errors) return null;\r\n  if (typeof errors.length !== 'undefined' && errors.length === 0) return null;\r\n\r\n  if (summaryMessage)\r\n    return (\r\n      <div className='error' role='alert'>\r\n        {summaryMessage}\r\n      </div>\r\n    );\r\n  let message = errors;\r\n  if (Array.isArray(errors)) {\r\n    if (errors.length === 0) return null;\r\n    message = errors.map((error, index) => <div key={index}>{error}</div>);\r\n  }\r\n\r\n  return (\r\n    <div className='error' role='alert'>\r\n      {message}\r\n    </div>\r\n  );\r\n};\r\n","//import React from 'react';\r\n/** @jsx jsx */\r\nimport { css, jsx } from '@emotion/core'\r\n\r\nexport const ErrorPopup = (props) => {\r\n  const title = props.title || 'Errors';\r\n  const errors = props.errors;\r\n  let messages = [];\r\n  if (errors) {\r\n    if (Array.isArray(errors)) {\r\n      messages = errors;\r\n    } else {\r\n      messages.push(errors);\r\n    }\r\n  }\r\n\r\n  const style = css({\r\n    position: 'fixed',\r\n    padding: '3rem',\r\n    width: '800px',\r\n    maxWidth: '90vw',\r\n    maxHeight: '90vw',\r\n    background: 'white',\r\n    color: 'red',\r\n    top: '50%',\r\n    left: '50%',\r\n    transform: 'translate(-50%, -50%)',\r\n    zIndex: '1000'\r\n  })\r\n\r\n  return <div css={style}>\r\n    <h3>{title}</h3>\r\n    {props.children}\r\n    {messages.map((error, inx) => (\r\n      <div key={inx} dangerouslySetInnerHTML={{ __html: error }}></div>\r\n    ))}\r\n    \r\n  </div>\r\n}\r\n","import React from \"react\";\r\n\r\nfunction SvgNarrowRight(props) {\r\n  return (\r\n    <svg viewBox=\"0 0 100 240\" {...props}>\r\n      <path\r\n        fill=\"currentColor\"\r\n        d=\"M26 20l50 100-50 100v-10l44-90-44-90z\"\r\n      />\r\n    </svg>\r\n  );\r\n}\r\n\r\nexport default SvgNarrowRight;\r\n","const overloading = {\n  breakpointNames: ['sm', 'md', 'lg', 'xl', 'xxl'],\n  breakpoints: [576, 768, 992, 1200, 1600]\n}\n\nconst colors = {\n  blueColor : '#0158D7',\n  darkGrayColor : '#3b3b3b',\n  lightGrayColor : '#ebebeb',\n  greenColor : '#27b90f'\n}\n\nconst variables = {\n  familyBase: '\"proxima-nova\",sans-serif',\n  familyHeader: '\"proxima-nova\",serif',\n\n  primaryColor: colors.blueColor,\n  fontColor: colors.darkGrayColor,\n  bgColor: '#ebebeb',\n\n  ...colors,\n  ...overloading\n}\n\nexport default variables;","import variables from './cssInJs/variables';\n\nconst cssEmotion = {\n  breakpointNames: variables.breakpointNames,\n  breakpoints: variables.breakpoints\n}\n\nexport default {\n  cssEmotion\n}","import * as React from \"react\";\r\nimport siteConfig from '../../../config';\r\n\r\nconst iconColors = (siteConfig && siteConfig.iconColors) || { primary: \"#eee\", secondary: \"#000\" }\r\n\r\nfunction SvgLoading(props) {\r\n  return (\r\n    <svg\r\n      width={200}\r\n      height={200}\r\n      viewBox=\"0 0 100 100\"\r\n      preserveAspectRatio=\"xMidYMid\"\r\n      {...props}\r\n    >\r\n      <circle\r\n        cx={50}\r\n        cy={50}\r\n        r={29.973}\r\n        fill=\"none\"\r\n        stroke={iconColors.primary}\r\n        strokeWidth={8}\r\n      >\r\n        <animate\r\n          attributeName=\"r\"\r\n          repeatCount=\"indefinite\"\r\n          dur=\"1.8518518518518516s\"\r\n          values=\"0;40\"\r\n          keyTimes=\"0;1\"\r\n          keySplines=\"0 0.2 0.8 1\"\r\n          calcMode=\"spline\"\r\n          begin=\"-0.9259259259259258s\"\r\n        />\r\n        <animate\r\n          attributeName=\"opacity\"\r\n          repeatCount=\"indefinite\"\r\n          dur=\"1.8518518518518516s\"\r\n          values=\"1;0\"\r\n          keyTimes=\"0;1\"\r\n          keySplines=\"0.2 0 0.8 1\"\r\n          calcMode=\"spline\"\r\n          begin=\"-0.9259259259259258s\"\r\n        />\r\n      </circle>\r\n      <circle\r\n        cx={50}\r\n        cy={50}\r\n        r={8.673}\r\n        fill=\"none\"\r\n        stroke={iconColors.secondary}\r\n        strokeWidth={8}\r\n      >\r\n        <animate\r\n          attributeName=\"r\"\r\n          repeatCount=\"indefinite\"\r\n          dur=\"1.8518518518518516s\"\r\n          values=\"0;40\"\r\n          keyTimes=\"0;1\"\r\n          keySplines=\"0 0.2 0.8 1\"\r\n          calcMode=\"spline\"\r\n        />\r\n        <animate\r\n          attributeName=\"opacity\"\r\n          repeatCount=\"indefinite\"\r\n          dur=\"1.8518518518518516s\"\r\n          values=\"1;0\"\r\n          keyTimes=\"0;1\"\r\n          keySplines=\"0.2 0 0.8 1\"\r\n          calcMode=\"spline\"\r\n        />\r\n      </circle>\r\n    </svg>\r\n  );\r\n}\r\n\r\nexport default SvgLoading;","import React from \"react\";\r\nimport { LoadingCircle } from \"../../icons\";\r\n/** @jsx jsx */\r\nimport { css, jsx } from \"@emotion/core\";\r\n\r\nexport function Loading({ children = undefined }) {\r\n  const [loaded, setLoaded] = React.useState(false);\r\n\r\n  const style = {\r\n    loading: css({\r\n      minHeight: \"300px\",\r\n      display: \"flex\",\r\n      justifyContent: \"center\",\r\n      alignItems: \"center\",\r\n      opacity: \"0\",\r\n      transition: \"all 1s\",\r\n    }),\r\n    loaded: css({\r\n      opacity: \"1\",\r\n    }),\r\n  };\r\n\r\n  React.useEffect(() => {\r\n    let timer = setTimeout(() => setLoaded(true), 500);\r\n    return () => {\r\n      clearTimeout(timer);\r\n    };\r\n  }, []);\r\n\r\n  return (\r\n    <div css={[style.loading, loaded ? style.loaded : {}]}>\r\n      <div>\r\n        <LoadingCircle />\r\n        {children}\r\n      </div>\r\n    </div>\r\n  );\r\n}\r\n","export function isExternalLink(link){\r\n  return link && (link.indexOf('https://') === 0 || link.indexOf('http://') === 0 || link.indexOf('://') === 0);\r\n}\r\n\r\nexport function getLinkFromElement(el){\r\n  if (!el) return null;\r\n  const linkEl = el.closest('a');\r\n  //console.log(el, linkEl);\r\n  if (linkEl){\r\n    return linkEl.getAttribute('href');\r\n  }\r\n  return null;\r\n}\r\n\r\n\r\n// router utils\r\nexport function getLinkInfo(link) {\r\n  if (!link) return null;\r\n\r\n  const origin = typeof window !== `undefined` && window.location && window.location.origin;\r\n  const currentPath = typeof window !== `undefined` && window.location && window.location.pathname;\r\n  let linkFiltered = link.replace(origin, '').replace(currentPath + '#', '#');\r\n  let linkLower = link.toLowerCase();\r\n\r\n  //if (isStaticFile(linkLower)) return null;\r\n  const isExternal = isExternalLink(linkFiltered);\r\n  const isHash = linkFiltered.indexOf('#') === 0;\r\n  const isTel = linkFiltered.indexOf('tel:') === 0;\r\n  const isMailTo = linkFiltered.indexOf('mailto:') === 0;\r\n  const type = (isHash && 'hash') || (isTel && 'tel') || (isMailTo && 'mailto') || \r\n    (isStaticFile(linkLower) && 'static') || (isExternal && 'external') || 'internal';\r\n\r\n  return { url: linkFiltered, type: type, ext: getExtension(link) };\r\n}\r\n\r\nvar exts = ['.pdf', '.jpg', '.png', '.gif', '.docx', '.doc']\r\nfunction isStaticFile(path) {\r\n  for(let i = 0; i < exts.length; i++) {\r\n    if (path.indexOf(exts[i]) >= 0) return true;\r\n  }\r\n  return false;\r\n}\r\n\r\nexport function getExtension(filename) {\r\n  if (!filename || filename.indexOf('.') < 0) return null;\r\n  return filename.split('.').pop().toLowerCase();\r\n}\r\n\r\nexport function getFilename(url) {\r\n  return url.split('/').pop().split('?')[0];\r\n}\r\n\r\nexport function getFolderPath(url, parentDepth = -1) {\r\n  return url.split('/').slice(0, parentDepth).join('/');\r\n}\r\n\r\n//\r\nexport function toQueryString(params) {\r\n  var queryString = Object.keys(params).map((key) => {\r\n      return encodeURIComponent(key) + '=' + encodeURIComponent(params[key])\r\n  }).join('&');\r\n  return queryString;\r\n}\r\n\r\nexport function getYoutubeId(url){\r\n  url = url.split(/(vi\\/|v=|\\/v\\/|youtu\\.be\\/|\\/embed\\/)/);\r\n  return (url[2] !== undefined) ? url[2].split(/[^0-9a-z_-]/i)[0] : url[0];\r\n}\r\n\r\nexport function getSlug(text){\r\n  return text.toLowerCase().replace(/ /g,'-').replace(/[-]+/g, '-').replace(/[^\\w-]+/g,'');\r\n}\r\n\r\nexport function getWebUrl(url, schema = 'https://'){\r\n  if (!url) return null;\r\n  if (url.indexOf('https:') >= 0 || url.indexOf('http:') >= 0 || url.indexOf(':') >= 0) {\r\n    return url;\r\n  }\r\n  return schema + url;\r\n}","//#region error json parsing\r\nexport const getErrors = (result) => {\r\n  let errors = [];\r\n  if (result && result.errors && result.errors.length > 0) {\r\n    result.errors.forEach(err => {\r\n      errors.push(err.errorMessage);\r\n    });\r\n  }\r\n  return errors;\r\n}\r\n\r\nexport const getErrorMessage = (result) => {\r\n  let errors = getErrors(result);\r\n  return errors.join(\" \");\r\n}\r\n//#endregion","//#region conversion between array and object\r\nexport const convertToObject = (array, key) => {\r\n  const initialValue = {};\r\n  return array.reduce((obj, item) => {\r\n    return {\r\n      ...obj,\r\n      [item[key]]: item,\r\n    };\r\n  }, initialValue);\r\n};\r\n\r\nexport const convertToKeyValues = (array, key, value) => {\r\n  const initialValue = {};\r\n  return array.reduce((obj, item) => {\r\n    return {\r\n      ...obj,\r\n      [item[key]]: item[value],\r\n    };\r\n  }, initialValue);\r\n};\r\n//#endregion\r\n\r\n//#region array helper functions\r\nexport const moveItem = (list, fromIndex, toIndex) => {\r\n  //const list = Array.from(array);\r\n  const [removed] = list.splice(fromIndex, 1);\r\n  list.splice(toIndex, 0, removed);\r\n\r\n  return list;\r\n};\r\n\r\nexport const removeItem = (list, index) => {\r\n  //const list = Array.from(array);\r\n  list.splice(index, 1);\r\n\r\n  return list;\r\n};\r\n\r\nexport const insertItem = (list, index, item) => {\r\n  //const list = Array.from(array);\r\n  list.splice(index, 0, item);\r\n\r\n  return list;\r\n};\r\n\r\n\r\nexport const find = (list, fn) => {\r\n  if (!list) return null;\r\n  for (let i = 0; i < list.length; i++) {\r\n    if (fn(list[i])) {\r\n      return list[i];\r\n    }\r\n  }\r\n  return null;\r\n};\r\n\r\nexport const findIndex = (list, fn) => {\r\n  if (!list) return -1;\r\n  for (let i = 0; i < list.length; i++) {\r\n    if (fn(list[i])) {\r\n      return i;\r\n    }\r\n  }\r\n  return -1;\r\n};\r\n\r\nexport const contains = (list, fn) => {\r\n  return findIndex(list, fn) >= 0;\r\n}\r\n\r\n// utils.array.distinct(images, (x, y) => x.imageUrl === y.imageUrl)\r\nexport const distinct = (list, comparer) => {\r\n  const filtered = []\r\n  for (let i = 0; i < list.length; i++) {\r\n    if (!contains(filtered, (x) => comparer(x, list[i]))) {\r\n      filtered.push(list[i])\r\n    }\r\n  }\r\n  return filtered;\r\n}\r\n\r\nexport const sum = (list, fn) => {\r\n  if (!list) return 0;\r\n  let total = 0;\r\n  for (let i = 0; i < list.length; i++) {\r\n    total += fn(list[i]) || 0\r\n  }\r\n  return total\r\n}\r\n\r\nexport const equal = (list1, list2, fn) => {\r\n  if (!list1 && !list2) return true;\r\n  if (!list1 || !list2) return false;\r\n  if (list1.length !== list2.length) return false;\r\n  for (let i = 0; i < list1.length; i++) {\r\n    let found = false;\r\n    for (let j = 0; j < list2.length; j++) {\r\n      if(fn(list1[i], list2[i])) {\r\n        found = true;\r\n        break;\r\n      }\r\n    }\r\n    if (!found) return false;\r\n  }\r\n  return true;\r\n}\r\n//#endregion\r\n\r\n//#region sorting helpers\r\nexport const caseInsensitiveCompare = function (a, b) {\r\n  return a.toLowerCase().localeCompare(b.toLowerCase());\r\n}\r\n\r\n// put the null items at the end.\r\nexport const compareIgnoreEmpty = function (asc) {\r\n  return asc ?\r\n    function (a, b) {\r\n      return (a === null || isNaN(a)) - (b === null || isNaN(b)) || +(a > b) || -(a < b);\r\n    }\r\n    :\r\n    function (a, b) {\r\n      return (a === null || isNaN(a)) - (b === null || isNaN(b)) || -(a > b) || +(a < b);\r\n    }\r\n}\r\n//#endregion","import parse from \"date-fns/parse\";\r\nimport parseISO from \"date-fns/parseISO\";\r\nimport format from \"date-fns/format\";\r\n\r\n//#region manipulation\r\nexport const addDays = (date, days) => {\r\n  var result = new Date(date);\r\n  result.setDate(result.getDate() + days);\r\n  return result;\r\n};\r\n//#endregion\r\n\r\n//#region format\r\nexport function formatDate(dateObj, formatStr) {\r\n  const date = toDate(dateObj);\r\n  if (!date) return \"\";\r\n  return format(date, formatStr);\r\n}\r\n\r\nexport function formatYYYYMMDDToday() {\r\n  const date = new Date();\r\n  //console.log(dateObj, date)\r\n  if (!date) return '';\r\n  var dd = date.getDate();\r\n  var mm = date.getMonth() + 1; //January is 0!\r\n\r\n  var yyyy = date.getFullYear();\r\n  if (dd < 10) {\r\n    dd = '0' + dd;\r\n  } \r\n  if (mm < 10) {\r\n    mm = '0' + mm;\r\n  } \r\n  return (`${yyyy}-${mm}-${dd}`)\r\n}\r\n\r\nexport function formatYYYYMMDD(dateObj) {\r\n  const date = toDate(dateObj);\r\n  //console.log(dateObj, date)\r\n  if (!date) return \"\";\r\n  var dd = date.getDate();\r\n  var mm = date.getMonth() + 1; //January is 0!\r\n\r\n  var yyyy = date.getFullYear();\r\n  if (dd < 10) {\r\n    dd = \"0\" + dd;\r\n  }\r\n  if (mm < 10) {\r\n    mm = \"0\" + mm;\r\n  }\r\n  return `${yyyy}-${mm}-${dd}`;\r\n}\r\n\r\nexport function formatDDMMYYYY(dateObj) {\r\n  const date = toDate(dateObj);\r\n  //console.log(dateObj, date)\r\n  if (!date) return \"\";\r\n  var dd = date.getDate();\r\n  var mm = date.getMonth() + 1; //January is 0!\r\n\r\n  var yyyy = date.getFullYear();\r\n  if (dd < 10) {\r\n    dd = \"0\" + dd;\r\n  }\r\n  if (mm < 10) {\r\n    mm = \"0\" + mm;\r\n  }\r\n  return `${dd}-${mm}-${yyyy}`;\r\n}\r\n//#endregion\r\n\r\n//#region parse\r\nexport function toDate(dateObj) {\r\n  if (!dateObj) return null;\r\n  if (typeof dateObj === \"string\") {\r\n    return (\r\n      parseDate(dateObj, \"yyyy-MM-dd\") ||\r\n      parseDate(dateObj, \"yyyy-M-d\") ||\r\n      parseDate(dateObj, \"dd/MM/yyyy\") ||\r\n      parseDate(dateObj, \"d/M/yyyy\") ||\r\n      parseISO(dateObj)\r\n    );\r\n  } else {\r\n    return dateObj;\r\n  }\r\n}\r\n\r\nexport function toDateTime(dateObj) {\r\n  if (!dateObj) return null;\r\n  if (typeof dateObj === \"string\") {\r\n    return (\r\n      parseDate(dateObj, \"yyyy-MM-dd'T'HH:mm:ss.SSSxxx\") ||\r\n      parseDate(dateObj, \"yyyy-MM-dd HH:mm:ss.SSSxxx\") ||\r\n      parseDate(dateObj, \"yyyy-M-d HH:mm:ss.SSSxxx\") ||\r\n      parseDate(dateObj, \"dd/MM/yyyy HH:mm:ss.SSSxxx\") ||\r\n      parseDate(dateObj, \"d/M/yyyy HH:mm:ss.SSSxxx\") ||\r\n      parseISO(dateObj)\r\n    );\r\n  } else {\r\n    return dateObj;\r\n  }\r\n}\r\n\r\nexport function parseDate(dateStr, format) {\r\n  const date = parse(dateStr, format, new Date());\r\n  return date && isValidDate(date) ? date : null;\r\n}\r\n\r\nexport function isValidDate(d) {\r\n  return d instanceof Date && !isNaN(d);\r\n}\r\n//#endregion\r\n","//#region background images\r\nexport const bgUrl = (imageUrl) => {\r\n  return `background-image:url(\"` + encodeURI(decodeURI(imageUrl)) + `\")`\r\n}\r\n\r\nexport const bgUrlStyle = (imageUrl) => {\r\n  return `url(\"` + encodeURI(decodeURI(imageUrl)) + `\")`\r\n}\r\n//#endregion\r\n\r\n//#region screen/element size\r\nexport const screenWidth = () => {\r\n  if (typeof window !== `undefined`) { \r\n    return window.innerWidth ||\r\n      document.documentElement.clientWidth ||\r\n      document.body.clientWidth\r\n  } else {\r\n    return 0;\r\n  }\r\n}\r\n\r\nexport const screenHeight = () => {\r\n  if (typeof window !== `undefined`) { \r\n    return window.innerHeight ||\r\n      document.documentElement.clientHeight ||\r\n      document.body.clientHeight\r\n  } else {\r\n    return 0;\r\n  }\r\n}\r\n\r\nexport const outerWidth = el => el.offsetWidth\r\nexport const outerHeight = el => el.offsetHeight\r\n//#endregion\r\n\r\n//#region css class\r\n/**\r\n * Check if element has the css class on it.\r\n */\r\nexport const hasClass = (el, className) => {\r\n  if (el.classList) {\r\n    return el.classList.contains(className)\r\n  }\r\n\r\n  return !!el.className.match(new RegExp(`(\\\\s|^)${className}(\\\\s|$)`))\r\n}\r\n\r\n/**\r\n * Adds the provided css className to the element.\r\n */\r\nexport const addClass = (el, className) => {\r\n  if (el.classList) {\r\n    el.classList.add(className)\r\n    return\r\n  }\r\n\r\n  if (!hasClass(el, className)) {\r\n    el.className += ` ${className}`\r\n  }\r\n}\r\n\r\n/**\r\n * Remove the provided css className from the element.\r\n */\r\nexport const removeClass = (el, className) => {\r\n  if (el.classList) {\r\n    el.classList.remove(className)\r\n    return\r\n  }\r\n\r\n  if (hasClass(el, className)) {\r\n    const reg = new RegExp(`(\\\\s|^)${className}(\\\\s|$)`)\r\n    el.className = el.className.replace(reg, ' ')\r\n  }\r\n}\r\n\r\n/**\r\n * Adds or removes a class name on the input depending on the status flag.\r\n */\r\nexport const toggleClass = (el, className, status) => {\r\n  if (!el || !className) return\r\n\r\n  if (status) {\r\n    return addClass(el, className)\r\n  }\r\n\r\n  removeClass(el, className)\r\n}\r\n//#endregion","import { gsap } from 'gsap';\r\nimport { ScrollToPlugin } from 'gsap/ScrollToPlugin';\r\n\r\ngsap.registerPlugin(ScrollToPlugin);\r\n\r\nexport function scrollTo(selector, duration = 750, delay = 0) {\r\n  const el = findElement(selector);\r\n  if (el) {\r\n    setTimeout(() => {\r\n      //console.log(element);\r\n      const offset = elementOffset(el);\r\n      //console.log(offset)\r\n      //window.scrollTo(0, offset.top - 300);\r\n\r\n      gsap.to(window, {duration: (duration/1000), scrollTo: offset.top - 100, ease: 'power1'});\r\n\r\n    }, delay);\r\n      //el.scrollIntoView({ block: 'start', inline: 'nearest', behavior: 'smooth' }); }, timeout);\r\n    return true;\r\n  }\r\n  return false;\r\n}\r\n\r\nexport function findElement(selector) {\r\n  if (typeof selector !== 'string') return selector;\r\n\r\n  let found = querySelectorOrNull(selector)\r\n    || querySelectorOrNull('#' + selector)\r\n    || querySelectorOrNull('.' + selector)\r\n  \r\n  return found;\r\n}\r\n\r\nexport function querySelectorOrNull(selector) {\r\n  try {\r\n    return document.querySelector(selector);\r\n  } catch(e){\r\n    return null;\r\n  };\r\n}\r\n\r\nexport function elementOffset(el) {\r\n  var rect = el.getBoundingClientRect(),\r\n    scrollLeft = typeof window !== `undefined` ? (window.pageXOffset || document.documentElement.scrollLeft) : 0,\r\n    scrollTop = typeof window !== `undefined` ? (window.pageYOffset || document.documentElement.scrollTop) : 0;\r\n\r\n  return { top: rect.top + scrollTop, left: rect.left + scrollLeft, width: el.offsetWidth, height: el.offsetHeight }\r\n}\r\n\r\nexport function isElementInViewport (el) {\r\n  if (typeof window !== `undefined`) {\r\n    var rect = el.getBoundingClientRect();\r\n\r\n    return (\r\n        rect.top >= 0 &&\r\n        rect.left >= 0 &&\r\n        rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /* or $(window).height() */\r\n        rect.right <= (window.innerWidth || document.documentElement.clientWidth) /* or $(window).width() */\r\n    );\r\n  } else {\r\n    return true;\r\n  }\r\n}\r\n\r\nexport function getCurrentBreakpoint() {\r\n  if (typeof window === `undefined`) return null;\r\n  \r\n  const bpHolder = document.querySelector('.devMediaQueryStatus__current');\r\n  if (!bpHolder) return null;\r\n  return window.getComputedStyle(bpHolder, ':before').getPropertyValue('content').replace(/[\"']/g, '');\r\n}\r\n\r\n","export function formatMoney(number, fraction = 0) {\r\n  var formatter = new Intl.NumberFormat('en-AU', {\r\n    style: 'currency',\r\n    currency: 'AUD',\r\n    minimumFractionDigits: fraction,\r\n  });\r\n\r\n  return formatter.format(number);\r\n}\r\n\r\nexport function toMonthlyCost(amount, frequency) {\r\n  if (!amount) return 0;\r\n  if (frequency === 'Week') {\r\n    return amount * 52.1429 / 12.0;\r\n  } else if (frequency === 'Fortnight') {\r\n    return amount * 52.1429 / 2.0 / 12.0;\r\n  } else if (frequency === 'Month') {\r\n    return amount;\r\n  } else if (frequency === 'Quarter') {\r\n    return amount * 4.0 / 12.0;\r\n  } else if (frequency === 'Year') {\r\n    return amount / 12.0;\r\n  } else {\r\n    return amount;\r\n  }\r\n}\r\n","export function isBlank(str) {\r\n  return (!str || /^\\s*$/.test(str))\r\n}\r\n\r\nexport function isEmpty(str) {\r\n  return (!str || str.length === 0)\r\n}\r\n\r\nexport function isNumeric(num){\r\n  return !isNaN(num)\r\n}\r\n\r\nexport function capitalize(expression) {\r\n  return expression.charAt(0).toUpperCase() + expression.slice(1);\r\n}\r\n\r\nexport function toFieldName(str) {\r\n  if (!str) return null;\r\n  return capitalize((str.replace(/([A-Z]+)/g, ' $1').replace(/([A-Z][a-z])/g, ' $1')).trim());\r\n}\r\n\r\nexport function toHtml(str) {\r\n  if (!str) return null;\r\n  return str.replace(/[\\n\\r]/g, '<br/>')\r\n}\r\n\r\n// Shorten a string to less than maxLen characters without truncating words.\r\nexport function truncateWords(str, maxLen, separator = ' ', ellipsis = '...') {\r\n  if (str.length <= maxLen) return str\r\n  var pos = str.lastIndexOf(separator, maxLen)\r\n  return str.substr(0, pos) + ellipsis\r\n}\r\n\r\nexport function numberWithCommas(x) {\r\n  var parts = x.toString().split(\".\");\r\n  parts[0] = parts[0].replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\");\r\n  return parts.join(\".\");\r\n}\r\n\r\nexport const formatNumber = (value) => {\r\n  if (value === 0) return '0';\r\n  if (!value) return '';\r\n  return Math.round(value * 100) / 100\r\n}\r\n\r\nexport const toTelephoneNumber = (str) => {\r\n  return (str || []).replace(/[^+\\d]+/g, \"\");\r\n\r\n}\r\n\r\n// utils.text.like('text here', '%keyword%')\r\nexport const like = (str, search) => {\r\n  if (typeof search !== 'string' || str === null) { return false; }\r\n  // Remove special chars\r\n  search = search.replace(new RegExp(\"([\\\\.\\\\\\\\\\\\+\\\\*\\\\?\\\\[\\\\^\\\\]\\\\$\\\\(\\\\)\\\\{\\\\}\\\\=\\\\!\\\\<\\\\>\\\\|\\\\:\\\\-])\", \"g\"), \"\\\\$1\");\r\n  // Replace % and _ with equivalent regex\r\n  search = search.replace(/%/g, '.*').replace(/_/g, '.');\r\n  // Check matches\r\n  return RegExp('^' + search + '$', 'gi').test(str);\r\n\r\n}","import shortid from 'shortid';\r\nimport uuid from 'uuid/v4';\r\n\r\nexport function shortId() {\r\n  return shortid();\r\n}\r\n\r\nexport function guid() {\r\n  return uuid();\r\n}","export function toCamel(o) {\r\n  var newO, origKey, newKey, value\r\n  if (o instanceof Array) {\r\n    return o.map(function(value) {\r\n        if (typeof value === \"object\") {\r\n          value = toCamel(value)\r\n        }\r\n        return value\r\n    })\r\n  } else {\r\n    newO = {}\r\n    for (origKey in o) {\r\n      if (o.hasOwnProperty(origKey)) {\r\n        newKey = (origKey.charAt(0).toLowerCase() + origKey.slice(1) || origKey).toString()\r\n        value = o[origKey]\r\n        if (value instanceof Array || (value !== null && value.constructor === Object)) {\r\n          value = toCamel(value)\r\n        }\r\n        newO[newKey] = value\r\n      }\r\n    }\r\n  }\r\n  return newO\r\n}","import { getFilename } from './url';\r\nimport { contains } from './array';\r\nexport function getImageSetPath(url, setId) {\r\n  const info = getPathDetails(url)\r\n  if (!info) return url;\r\n  //console.log(url, info);\r\n  return info.baseFolder + \"/@\" + setId + '/' + info.filename\r\n}\r\n\r\nexport function getPathDetails(url, setIds) {\r\n  if (!url) return null;\r\n  const parts = url.split('/').slice(0, -1);\r\n  if (parts.length <= 1) return { baseFolder: '/', setId: null, filename: getFilename(url) };\r\n\r\n  const lastFolder = parts[parts.length - 1];\r\n  const hasSet = setIds && setIds.length > 0 ? contains(setIds, x => x === lastFolder) : lastFolder.indexOf('@') === 0;\r\n\r\n  return hasSet ?\r\n    { baseFolder: parts.slice(0, -1).join('/'), setId: lastFolder, filename: getFilename(url) } :\r\n    { baseFolder: parts.join('/'), setId: null, filename: getFilename(url) }\r\n}","import classNames from 'classnames';\r\nimport * as url from './url';\r\nimport * as form from './form';\r\nimport * as array from './array';\r\nimport * as date from './date';\r\nimport * as css from './css';\r\nimport * as ui from './ui';\r\nimport * as money from './money';\r\nimport * as text from './text';\r\nimport * as random from './random';\r\nimport * as object from './object';\r\nimport * as media from './media';\r\n\r\nexport default { classNames, url, form, array, date, css, ui, money, text, random, object, media};","import facepaint from 'facepaint'\r\nimport siteConfig from '../../config';\r\n\r\nconst config = siteConfig.cssEmotion\r\nconst breakpointNames = (config && config.breakpointNames) || ['sm', 'md', 'lg', 'xl', 'xxl']\r\nconst breakpoints = (config && config.breakpoints) || [576, 768, 992, 1200, 1600]\r\n\r\nconst mq = facepaint(\r\n  breakpoints.map(bp => `@media (min-width: ${bp}px)`)\r\n)\r\n\r\nconst mqMin = {};\r\nbreakpointNames.forEach((bp, index) => mqMin[bp] = `@media (min-width: ${breakpoints[index]}px)`)\r\n\r\nconst mqMax = {};\r\nbreakpointNames.forEach((bp, index) => mqMax[bp] = `@media (max-width: ${breakpoints[index] - 1}px)`)\r\n//console.log(mqMin, mqMax)\r\n\r\nconst matches = (mediaQuery) => !!window.matchMedia(mediaQuery).matches\r\nconst isMin = {};\r\nbreakpointNames.forEach((bp, index) => isMin[bp] = () => matches(`(min-width: ${breakpoints[index]}px)`))\r\n\r\nconst isMax = {};\r\nbreakpointNames.forEach((bp, index) => isMax[bp] = () => matches(`(max-width: ${breakpoints[index] - 1}px)`))\r\n\r\nexport { mq, mqMin, mqMax, isMin, isMax }","export function overlay() {\r\n  return {\r\n    content: `''`,\r\n    position: 'absolute',\r\n    top:0,\r\n    bottom:0,\r\n    left: 0,\r\n    right: 0,\r\n    transition: 'all 0.5s'\r\n  }\r\n}","import utils from \"../utils\";\nimport env from '../env';\nimport { isMin } from '../lib/css-emotion'\n\nexport const isMobile = () => {\n  // isMin.md() ==> min-width: 768px\n  return !isMin.md()\n}\n\nexport function resourcePath(url){\n  if (!url) return null;\n  if (url && url.indexOf('/assets/') === 0) return url;\n  return utils.url.isExternalLink(url)? url : env.resourceBase + url;\n}\n\nexport function fullUrl(url){\n  return utils.url.isExternalLink(url)? url : env.baseOrigin + url;\n}\n\n\nexport const isNZ = env.locale === 'nz'\n\n","import coreUtils from '../lib/utils-core';\nimport * as site from '../site/siteUtils';\n\nexport default { ...coreUtils, site };","import { useState, useEffect } from 'react';\r\nimport utils from '../../utils';\r\nimport siteConfig from '../../config';\r\n\r\nexport function useApi(fn) {\r\n  //console.log('useApi')\r\n  const [response, setResponse] = useState({});\r\n  const [errors, setErrors] = useState([]);\r\n  const [status, setStatus] = useState('ready');\r\n  const [request, setRequest] = useState(null);\r\n\r\n  useEffect(() => {\r\n    if (!request) return;\r\n\r\n    //console.log('fetch now')\r\n    setResponse(null);\r\n    setErrors([]);\r\n    setStatus('ready');\r\n\r\n    const fetchData = async () => {\r\n      setStatus('pending');\r\n      try {\r\n        //console.log(request);\r\n        const options = request.options || {}\r\n        siteConfig.apiNetJwt && await siteConfig.apiNetJwt(options);\r\n\r\n        const res = await fetch(request.url, options);\r\n        //console.log(res);\r\n\r\n        if (!res.ok) {\r\n          try {\r\n            const json = await res.json();\r\n            console.log(json);\r\n\r\n            if (json.message) {\r\n              setErrors([json.message]);\r\n              setStatus('error')\r\n              return;\r\n            }\r\n          } catch (e) { }\r\n\r\n          const statusText = res.status === 401 ? 'Permission denied. Please login first.' : res.statusText\r\n          setErrors(['Error - [' + res.status + ']' + (statusText && (' - ' + statusText))]);\r\n          setStatus('error')\r\n          return;\r\n        }\r\n\r\n        //const json = await res.json();\r\n        const text = await res.text();\r\n        const json = text && text.length ? JSON.parse(text) : null;\r\n        //console.log(json);\r\n\r\n        // check if ajax result from c#\r\n        if (json && json.errors && json.errors.length > 0) {\r\n          setErrors(utils.form.getErrors(json));\r\n          setStatus('error')\r\n          return;\r\n        }\r\n\r\n        setResponse(json);\r\n        setStatus('done')\r\n      } catch (err) {\r\n        //console.log(error, error.toString(), typeof error, JSON.stringify(error))\r\n        setErrors([err.toString()]);\r\n        setStatus('error')\r\n      }\r\n    };\r\n    fetchData();\r\n  }, [request]);\r\n\r\n  const containsErrorMessage = (msg) => {\r\n    const finding = (msg || '').toLowerCase()\r\n    return errors.some(x => (x || '').toLowerCase().indexOf(finding) >= 0)\r\n  }\r\n\r\n  //return [ response, error, status, (...args) => setRequest(fn(...args)) ];\r\n  return {\r\n    request: request,\r\n    response: response,\r\n    errors: errors,\r\n    status: status,\r\n    hasErrors: () => status === 'error',\r\n    containsErrorMessage: containsErrorMessage,\r\n    addErrors: (errs) => {\r\n      setErrors(...errors, ...errs)\r\n      setStatus('error')\r\n    },\r\n    done: () => status === 'done',\r\n    send: (...args) => { setStatus('ready'); setRequest(fn(...args)) },\r\n    sendRaw: (httpOptionFn, ...args) => { setStatus('ready'); setRequest(httpOptionFn(...args)) },\r\n    setResult: (json) => { setResponse(json); setStatus('done') },\r\n    reset: () => {\r\n      setStatus('ready');\r\n      setErrors([]);\r\n    }\r\n  };\r\n}\r\n\r\nexport function usePost() {\r\n  const formDataFn = (url, data, options = {}) =>\r\n    ({\r\n      url: url,\r\n      options: {\r\n        ...options,\r\n        method: 'POST',\r\n        body: data // FormData\r\n      }\r\n    });\r\n  const post = useApi((url, data, options = {}) =>\r\n    ({\r\n      url: url,\r\n      options: {\r\n        ...options,\r\n        method: 'POST',\r\n        headers: { 'Content-Type': 'application/json' },\r\n        body: JSON.stringify(data)\r\n      }\r\n    })\r\n  );\r\n  return {\r\n    ...post,\r\n    loading: () => post.status === 'ready' || post.status === 'pending',\r\n    sending: () => post.status === 'pending',\r\n    sendFormData: (...args) => post.sendRaw(formDataFn, ...args)\r\n  }\r\n}\r\n\r\nexport function useGet() {\r\n  const get = useApi((url, options = {}) =>\r\n    ({\r\n      url: url,\r\n      options: {\r\n        ...options,\r\n        method: 'GET'\r\n      }\r\n    })\r\n  );\r\n  return {\r\n    ...get,\r\n    loading: () => get.status === 'ready' || get.status === 'pending'\r\n  }\r\n}\r\n\r\n//https://medium.com/@jaryd_34198/seamless-api-requests-with-react-hooks-part-2-3ab42ba6ad5c","import React from 'react';\r\nimport env from '../../env';\r\n\r\nexport function MediaQueryStatus(props) {\r\n  return (\r\n    <div className=\"devMediaQueryStatus\" style={{display: env.isProd ? 'none' : 'block'}}>\r\n      <div className=\"devMediaQueryStatus__current\"></div>\r\n    </div>\r\n  );\r\n}\r\n","import React from 'react';\r\nimport { Helmet } from 'react-helmet-async';\r\n\r\nexport function MetaTag({ data: seoData }) {\r\n  //console.log(seoData)\r\n  const data = Object.assign({}, {\r\n    title: ''\r\n  }, seoData)\r\n\r\n  return (<>\r\n    <Helmet>\r\n      <title>{data.title}</title>\r\n      {data.description && <meta name=\"description\" content={data.description} /> }\r\n      {data.keywords && <meta name=\"keywords\" content={data.keywords} /> }\r\n      {data.language && <meta name=\"language\" content={data.language} /> }\r\n      {data.country && <meta name=\"country\" content={data.country} /> }\r\n      {\r\n        (data.faceBookDomainVerifi && data.faceBookDomainVerifi !== '') &&\r\n        <meta name=\"facebook-domain-verification\" content={data.faceBookDomainVerifi} />\r\n      }\r\n      <meta name=\"twitter:card\" content={!data.heroImageUrl ? \"summary\" : \"summary_large_image\"} />\r\n      <meta name=\"twitter:site\" content={data.siteName} />\r\n      <meta name=\"twitter:title\" content={data.title} />\r\n      {data.description && <meta name=\"twitter:description\" content={data.description} /> }\r\n      {data.heroImageUrl && <meta name=\"twitter:image\" content={data.heroImageUrl} /> }\r\n\r\n      <meta name=\"og:title\" content={data.title} />\r\n      <meta name=\"og:site_name\" content={data.siteName} />\r\n      <meta name=\"og:url\" content={data.url} />\r\n      {data.description && <meta name=\"og:description\" content={data.description} /> }\r\n      {data.heroImageUrl && <meta name=\"og:image\" content={data.heroImageUrl} /> }\r\n\r\n\r\n      <link rel=\"canonical\" href={data.canonical || data.url} />\r\n\r\n      {(data.alternates || []).map((x, index) => <link rel=\"alternate\" key={index} hreflang={x.hreflang} href={x.href} />  )}\r\n\r\n    </Helmet>\r\n  </>)\r\n}\r\n\r\n\r\n// function MetaContent({ name, content }) {\r\n//   console.log(name, content)\r\n//   if (!content) return null;\r\n//   return <Helmet><meta name={name} content={content}></meta></Helmet>\r\n// }\r\n\r\n","import env from '../../env';\r\n\r\nexport const pageView = (url) => {\r\n  if (process.env.NODE_ENV === 'development') {\r\n    console.warn(`Tracking is deprecated.`, `Use seperate tracking helper instead`);\r\n  }\r\n  if (hasGTM()) gtmPageView(url)\r\n  if (hasGtag()) gaPageView(url)\r\n  if (hasFBPixel()) fbPageView(url)\r\n}\r\n\r\nexport const sendFormEvent = (formName, params) => {\r\n  if (process.env.NODE_ENV === 'development') {\r\n    console.warn(`Tracking is deprecated.`, `Use seperate tracking helper instead`);\r\n  }\r\n  const p = Object.assign({ 'gtm.elementId': formName }, params || {})\r\n\r\n  if (hasGTM()) gtmSendEvent('form', p)\r\n  if (hasGtag()) gaSendEvent('form', p)\r\n  if (hasFBPixel()) fbSendEvent('form', p)\r\n}\r\n\r\nexport const sendEvent = (eventName, params) => {\r\n  if (process.env.NODE_ENV === 'development') {\r\n    console.warn(`Tracking is deprecated.`, `Use seperate tracking helper instead`);\r\n  }\r\n  if (hasGTM()) gtmSendEvent(eventName, params)\r\n  if (hasGtag()) gaSendEvent(eventName, params)\r\n  if (hasFBPixel()) fbSendEvent(eventName, params)\r\n}\r\n\r\n//#region GTM\r\nexport const hasGTM = () => {\r\n  return !!(typeof window !== `undefined` && window.dataLayer);\r\n}\r\n\r\nexport const gtmPageView = (url) => {\r\n  if (typeof window !== `undefined`) {\r\n    window.dataLayer.push({\r\n      event: 'pageview',\r\n      page: {\r\n        path: url\r\n      }\r\n    })\r\n  }\r\n}\r\nexport const gtmSendEvent = (eventName, params) => {\r\n  if (typeof window !== `undefined`) {\r\n    window.dataLayer.push(Object.assign({ event: eventName }, params || {}))\r\n  }\r\n}\r\n//#endregion\r\n\r\n//#region Gtag / GA\r\nexport const hasGtag = () => {\r\n  return !!(typeof window !== `undefined` && window.gtag);\r\n}\r\n\r\nexport const gaPageView = (url) => {\r\n  if (typeof window !== `undefined`) {\r\n    if (env.gaAccounts) {\r\n      env.gaAccounts.forEach(id => {\r\n        window.gtag('config', id, { 'page_path': url });\r\n      })\r\n    }\r\n  }\r\n}\r\n\r\nexport const gaSendEvent = (eventName, params) => {\r\n  if (typeof window !== `undefined`) {\r\n    if (env.gaAccounts && env.gaAccounts.length > 0) {\r\n      window.gtag('event', eventName, params || {});\r\n    }\r\n  }\r\n}\r\n//#endregion\r\n\r\n//#region Facebook Pixel\r\nexport const hasFBPixel = () => {\r\n  return !!(typeof window !== `undefined` && window.fbq);\r\n}\r\n\r\nexport const fbPageView = (url) => {\r\n  if (typeof window !== `undefined`) {\r\n    window.fbq('track', 'PageView');\r\n  }\r\n}\r\n\r\nexport const fbSendEvent = (eventName, params) => {\r\n  if (typeof window !== `undefined`) {\r\n    window.fbq('track', eventName, params || {});\r\n  }\r\n}\r\n//#endregion\r\n\r\n\r\n\r\n","import  utils from '../../utils';\r\n\r\nexport const MAX = 100000;\r\nexport const MIN = -100000;\r\n\r\nexport function getScrollProgress(el) {\r\n  if (typeof window !== `undefined`) {\r\n    const scroll = window.scrollY || window.pageYOffset\r\n    if (!el) {\r\n      console.log('not exists', el)\r\n      return {\r\n        progress: 0,\r\n        top: scroll\r\n      }\r\n    }\r\n    const boundsTop = el.getBoundingClientRect().top + scroll\r\n\r\n    const viewport = {\r\n      top: scroll,\r\n      bottom: scroll + window.innerHeight,\r\n      height: window.innerHeight\r\n    }\r\n\r\n    const bounds = {\r\n      top: boundsTop,\r\n      bottom: boundsTop + el.clientHeight,\r\n      height: el.clientHeight\r\n    }\r\n\r\n    //const scrollTop = window.scrollY || window.pageYOffset || document.documentElement.scrollTop;\r\n\r\n    // const status = {\r\n    //   viewport: viewport,\r\n    //   bound: bounds,\r\n    //   inViewport: (bounds.bottom >= viewport.top && bounds.bottom <= viewport.bottom)\r\n    //   || (bounds.top <= viewport.bottom && bounds.top >= viewport.top)\r\n    // }\r\n\r\n    //console.log((viewport.bottom - bounds.top) / (bounds.height + viewport.height))\r\n    return {\r\n      progress: (viewport.bottom - bounds.top) / (bounds.height + viewport.height),\r\n      top: (viewport.bottom - bounds.top) / (viewport.height)\r\n    }\r\n  } else {\r\n    return {\r\n      progress: 0,\r\n      top: 0\r\n    }\r\n  }\r\n}\r\n\r\n//au.setClass(section, 'animated', pr, [0.3, au.MAX])\r\nexport function setClass(el, className, pr, range)\r\n{\r\n  if (pr >= range[0] && pr <= range[1]) {\r\n    utils.css.addClass(el, className);\r\n  } else {\r\n    utils.css.removeClass(el, className);\r\n  }\r\n}\r\n\r\nexport function prVal(min, max, pr, range = [0, 1]) {\r\n  //console.log(min, max, typeof min, typeof to)\r\n  if (pr < range[0]) return min;\r\n  if (pr > range[1]) return max;\r\n  return min + (max - min) * ((pr - range[0])/(range[1] - range[0]));\r\n}\r\n\r\nexport function transform(el, x, y) {\r\n  el.style.transform = 'translate(' + x + ',' + y + ')';\r\n}\r\n\r\nexport function removeTransform(el) {\r\n\r\n}\r\n\r\n// requestAnimationFrame\r\n// const raf =\r\n//   (<any>window).requestAnimationFrame ||\r\n//   (<any>window).webkitRequestAnimationFrame ||\r\n//   (<any>window).mozRequestAnimationFrame ||\r\n//   function (callback) {\r\n//     (<any>window).setTimeout(callback, 1000 / 60)\r\n//   }\r\nexport function getScreenSize() {\r\n  const w = utils.css.screenWidth()\r\n  const h = utils.css.screenHeight()\r\n  return { width: w, height: h };\r\n}\r\n","const defaultHolder = typeof window !== `undefined` ? window : {};\r\nconst storeName = '__j6_lazy_js'\r\n\r\nexport function loadJs(...scripts) {\r\n  const promises = [];\r\n  scripts.forEach((script) => promises.push(loadScript(script, defaultHolder)));\r\n  return Promise.all(promises);\r\n}\r\n\r\nexport function loadedJs(url, holder = defaultHolder) {\r\n  if (!holder[storeName]) return false;\r\n  return holder[storeName][url] && holder[storeName][url].loaded\r\n}\r\n\r\nexport function loadScript(url, holder_, forceToReload = false) {\r\n  const holder = holder_ || defaultHolder\r\n  if (!holder[storeName]) holder[storeName] = {};\r\n\r\n  return new Promise((resolve, reject) => {\r\n    //resolve if already loaded\r\n    if (!forceToReload && holder[storeName][url] && holder[storeName][url].loaded) {\r\n      resolve({ script: url, loaded: true, networkLoaded: false , status: 'Already Loaded' });\r\n    }\r\n    else {\r\n      // remove previous\r\n      const existing = document.querySelector('script[src=\"' + url +'\"]')\r\n      if (existing) existing.remove();\r\n\r\n      // load script\r\n      let script = document.createElement('script');\r\n      script.type = 'text/javascript';\r\n      script.src = url;\r\n      script.onload = () => {\r\n        holder[storeName][url] = { loaded: true };\r\n        resolve({ script: url, loaded: true, networkLoaded: true, status: 'Loaded' });\r\n      };\r\n      script.onerror = (error) => resolve({ script: url, loaded: false, status: 'Load failed' });\r\n      document.getElementsByTagName('head')[0].appendChild(script);\r\n    }\r\n  });\r\n}","import { useLayoutEffect } from 'react';\r\n//import useWindowScroll from '@react-hook/window-scroll';\r\nimport { au } from '../../components';\r\n\r\n/* background image height =\r\n  + cutoff padding = always hidden padding - usually 10 px\r\n    + panel height (desired parallax panel height)\r\n    + padding height = panel height * padding height ratio\r\n  + cutoff padding = always hidden padding - usually 10 px\r\n*/\r\n\r\nconst defaultSettings = {\r\n  cutoffPadding: 10,\r\n  speed: 15, // 5% of image/100px scroll\r\n  //paddingHeightRatio: 0.3\r\n  //screenSize\r\n}\r\n\r\nexport const ParallaxData = {\r\n  settings: {\r\n    screenSize: null\r\n  },\r\n  panels: [\r\n    { selector: '.parallax', imageRatio: 1080 / 1920, panelHeight: 'auto' },\r\n  ],\r\n  elements: [],\r\n  timeoutId: null\r\n}\r\n\r\nexport function useParallax() {\r\n  const handleScroll = () => {\r\n    //console.log('useParallax - scrolling')\r\n    onScroll(ParallaxData);\r\n  }\r\n\r\n  const reset = () => {\r\n    //console.log('useParallax - reset');\r\n    setTimeout(() => { init(ParallaxData); handleScroll(); }, 300)\r\n  }\r\n\r\n  useLayoutEffect(() => {\r\n    //console.log('useParallax - effect');\r\n    setTimeout(() => { init(ParallaxData); handleScroll(); }, 300)\r\n    if (typeof window !== `undefined`) {\r\n      window.addEventListener('scroll', handleScroll)\r\n      window.addEventListener('resize', reset)\r\n    }\r\n    return () => {\r\n      //console.log('useParallax - removed');\r\n      if (typeof window !== `undefined`) {\r\n        window.removeEventListener('scroll', handleScroll)\r\n        window.removeEventListener('resize', reset)\r\n      }\r\n    }\r\n\r\n    // eslint-disable-next-line \r\n  }, []);\r\n\r\n  return { reset };\r\n};\r\n\r\n// export function useParallax(opt) {\r\n//   // const settings = Object.assign({}, defaultSettings, opt);\r\n\r\n//   const [resetCounter, setResetCounter] = useState(0);\r\n//   const [parallaxData,] = useState(ParallaxData);\r\n\r\n//   //const scrollY = useWindowScroll(60 /*fps*/)\r\n//   const reset = () => {\r\n//     setResetCounter(resetCounter + 1);\r\n//   }\r\n\r\n//   const handleScroll = () => {\r\n//     onScroll(parallaxData);\r\n//   }\r\n\r\n//   useLayoutEffect(() => {\r\n//     console.log('useParallax - effect');\r\n\r\n//     setTimeout(() => { init(parallaxData); handleScroll(); }, 300)\r\n\r\n//     //const handleScroll = (): void => setThrottledScroll(getScrollY())\r\n//     window.addEventListener('scroll', handleScroll)\r\n//     window.addEventListener('resize', handleScroll)\r\n//     return (): void => {\r\n//       window.removeEventListener('scroll', handleScroll)\r\n//       window.removeEventListener('resize', handleScroll)\r\n//     }\r\n\r\n//     // eslint-disable-next-line \r\n//   }, [resetCounter]);\r\n//   //console.log(scrollY, resetCounter)\r\n\r\n//   return { reset };\r\n// };\r\n\r\nexport function init(data) {\r\n  //console.log('parallax init');\r\n  const screenSize = data.settings.screenSize = au.getScreenSize();\r\n  data.settings = Object.assign({}, defaultSettings, data.settings)\r\n  let cnt = 0;\r\n  data.panels.forEach(panel => {\r\n    const elements = document.querySelectorAll(panel.selector) || [];\r\n    for (let i = 0; i < elements.length; i++) {\r\n      cnt++;\r\n      const el = elements[i];\r\n      //const el = document.querySelector(panel.selector);\r\n      //console.log(panel.selector, el)\r\n      //if (!el) { panel.el = null; return; }\r\n      const autoPanelHeight = !panel.panelHeight || panel.panelHeight === 'auto';\r\n      const panelHeight = autoPanelHeight ? el.offsetHeight : parseFloat(panel.panelHeight);\r\n      //console.log(autoPanelHeight, panelHeight)\r\n\r\n      const calculated = { shadowHeight: 0, shadowWidth: 0, fromTop: 0, toTop: 0 };\r\n      // calculated.shadowHeight = panelHeight * (1 + data.settings.paddingHeightRatio) + 2 * data.settings.cutoffPadding;\r\n      // calculated.shadowWidth = calculated.shadowHeight / panel.imageRatio;\r\n      // if (calculated.shadowWidth < data.settings.screenSize.width) {\r\n      //   // magnifying the background image to fix the full width of the browser\r\n      //   calculated.shadowWidth = data.settings.screenSize.width;\r\n      //   calculated.shadowHeight = calculated.shadowWidth * panel.imageRatio;\r\n      // }\r\n\r\n      const speed = data.settings.speed * (screenSize.width > 1000 ? 1 : 2) \r\n      let baseHeight = data.settings.screenSize.width * panel.imageRatio > panelHeight ? data.settings.screenSize.width * panel.imageRatio : panelHeight\r\n      baseHeight = baseHeight + (data.settings.screenSize.height + panelHeight) * (speed * 0.01)\r\n      calculated.shadowHeight = baseHeight + 2 * data.settings.cutoffPadding;\r\n      calculated.shadowWidth = calculated.shadowHeight / panel.imageRatio;\r\n      if (calculated.shadowWidth < data.settings.screenSize.width) {\r\n        // magnifying the background image to fix the full width of the browser\r\n        calculated.shadowWidth = data.settings.screenSize.width;\r\n        calculated.shadowHeight = calculated.shadowWidth * panel.imageRatio;\r\n      }\r\n\r\n      calculated.fromTop = -data.settings.cutoffPadding;\r\n      calculated.toTop = -calculated.shadowHeight + panelHeight + data.settings.cutoffPadding;\r\n\r\n      if (!autoPanelHeight)\r\n        (el).style.height = panel.panelHeight + 'px';\r\n\r\n      (el).style.backgroundSize = calculated.shadowWidth + 'px ' + calculated.shadowHeight + 'px'\r\n\r\n      //panel.el = el;\r\n      panel.calculated = calculated;\r\n      data.elements.push({ el: el, calculated: calculated });\r\n      //console.log(panelHeight, baseHeight, calculated)\r\n    }\r\n  })\r\n\r\n  //console.log('parallax init - ' + cnt)\r\n  if (cnt === 0) {\r\n    if (data.timeoutId) {\r\n      try {\r\n        if (typeof window !== `undefined`) { \r\n          window.clearTimeout(data.timeoutId)\r\n        }\r\n      } catch(e){}\r\n    }\r\n    // reschedule\r\n    if (typeof window !== `undefined`) { \r\n      data.timeoutId = window.setTimeout(() => init(data), 500)\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport function onScroll(data) {\r\n  //console.log(data);\r\n  data.elements.forEach(element => {\r\n    if (!element.el) return;\r\n    const pr = au.getScrollProgress(element.el).progress;\r\n    //console.log(pr);\r\n\r\n    const min = element.calculated.fromTop;\r\n    const max = element.calculated.toTop;\r\n    const top = au.prVal(min, max, pr, [0, 1]);\r\n    //console.log(top);\r\n    (element.el).style.backgroundPositionY = top + 'px'\r\n  })\r\n\r\n}","import { useMemo } from 'react';\r\nimport { useParams, useLocation, useHistory, useRouteMatch, Redirect } from 'react-router-dom';\r\nimport queryString from 'query-string';\r\n\r\nexport function useRouter() {\r\n  const params = useParams();\r\n  const location = useLocation();\r\n  const history = useHistory();\r\n  const match = useRouteMatch();\r\n\r\n  // Return our custom router object\r\n  // Memoize so that a new object is only returned if something changes\r\n  return useMemo(() => {\r\n    return {\r\n      // For convenience add push(), replace(), pathname at top level\r\n      navigate: history.push,\r\n      push: history.push,\r\n      Redirect: Redirect,\r\n      replace: history.replace,\r\n      pathname: location.pathname,\r\n      path: location.pathname + location.hash + location.search,\r\n      // Merge params and parsed query string into single \"query\" object\r\n      // so that they can be used interchangeably.\r\n      // Example: /:topic?sort=popular -> { topic: \"react\", sort: \"popular\" }\r\n      query: {\r\n        ...queryString.parse(location.search), // Convert string to object\r\n        ...params\r\n      },\r\n      // Include match, location, history objects so we have\r\n      // access to extra React Router functionality if needed.\r\n      match,\r\n      location,\r\n      history\r\n    };\r\n  }, [params, match, location, history]);\r\n}","const initialState = {\r\n  page: null,\r\n  menu: null,\r\n  popup: null,\r\n  history: null\r\n};\r\n\r\nconst reducer = (state = initialState, action) => {\r\n  //console.log('reducer', action)\r\n  switch (action.type) {\r\n    case 'SET_PAGE':\r\n      return {\r\n        ...state,\r\n        page: action.payload\r\n      };\r\n    case 'SET_MENU':\r\n      return {\r\n        ...state,\r\n        menu: action.payload\r\n      };\r\n    case 'SET_POPUP':\r\n      return {\r\n        ...state,\r\n        popup: action.payload\r\n      };\r\n    case 'SET_HISTORY':\r\n      return {\r\n        ...state,\r\n        history: action.payload\r\n      };\r\n    case 'SET_STATE':\r\n      return {\r\n        ...state,\r\n        ...action.payload\r\n      };\r\n    default:\r\n      throw new Error(\"Unexpected action\");\r\n  }\r\n};\r\n\r\nexport { initialState, reducer };","import React, { createContext, useReducer, useContext, useEffect } from 'react';\r\nimport { initialState, reducer } from '../../store';\r\n\r\nconst StoreContext = createContext(initialState);\r\n\r\nconst StoreProvider = ({ children }) => {\r\n  // Get state and dispatch from Reacts new API useReducer. \r\n  const [state, dispatch] = useReducer(reducer, initialState);\r\n  //console.log('StoreProvider')\r\n  // Log new state\r\n  useEffect(() => {\r\n    //console.log('-- new state', state);\r\n    //console.trace();\r\n  }, [state]);\r\n  // Render state, dispatch and special case actions\r\n  return (\r\n    <StoreContext.Provider value={{ state, dispatch }}>\r\n      {children}\r\n    </StoreContext.Provider>\r\n  );\r\n};\r\nexport { StoreContext, StoreProvider };\r\n\r\nexport const useStore = () => useContext(StoreContext);","import { useStore } from '../../store';\r\n\r\n// loc data: {path:'', title:''}\r\nexport function useHistoryStore() {\r\n  const { state, dispatch } = useStore();\r\n  const history = state.history || [];\r\n\r\n  function push(loc) {\r\n    const same = history.length > 0 \r\n      && (JSON.stringify(history[history.length - 1]) === JSON.stringify(loc))\r\n    if (!same) {\r\n      // console.log(JSON.stringify(history[history.length - 1]), JSON.stringify(loc))\r\n      setHistory([...history, loc]);\r\n    }\r\n  }\r\n\r\n  function setHistory(history){\r\n    // console.log('history set', history)\r\n    dispatch({ type: 'SET_HISTORY', payload: history })\r\n  }\r\n\r\n  const last = () => {\r\n    // console.log('last history', history)\r\n    if (history.length < 2) return null;\r\n    return history[history.length - 2].path;\r\n  }\r\n\r\n  const pop = () => {\r\n    if (history.length === 0) return null;\r\n    history.pop(); // remove the current first\r\n    const item = history.pop();\r\n    return item;\r\n  }\r\n\r\n  return { history, push, pop, last };\r\n};","import utils from '../../utils';\r\n\r\nexport function handleElementLink(el, externalHandler) {\r\n  // externalHandler = (url) => {\r\n  //   if (typeof window !== `undefined`) window.location.href = url;\r\n  // }\r\n\r\n  const link = utils.url.getLinkFromElement(el);\r\n  const linkInfo = utils.url.getLinkInfo(link);\r\n  //console.log(link, linkInfo)\r\n  if (!linkInfo) return { handled: false, linkInfo: linkInfo };\r\n\r\n  if (linkInfo.type === 'hash') {\r\n    utils.ui.scrollTo(linkInfo.url);\r\n  } else if (linkInfo.type === 'tel' || linkInfo.type === 'mailto') {\r\n\r\n  } else if (linkInfo.type === 'external' && externalHandler) {\r\n    // let the external handler process.\r\n    externalHandler(linkInfo.url);\r\n    return { handled: true, linkInfo: linkInfo };;\r\n  }\r\n  return { handled: false, linkInfo: linkInfo };\r\n}","import React from \"react\";\r\nimport { Link } from \"react-router-dom\";\r\nimport utils from \"../../utils\";\r\nimport { handleElementLink } from \"./handleLink\";\r\n\r\nexport function SiteLink(props) {\r\n  const { children, to, target, onClick, ...other } = props;\r\n\r\n  function goToLink(e) {\r\n    try {\r\n      const isCmsEdit = document.querySelector(\"body\").classList.contains(\"cmsedit\");\r\n      if (isCmsEdit) {\r\n        e.preventDefault();\r\n        return;\r\n      }\r\n    } catch (e) {}\r\n\r\n    //console.log(e, e.target);\r\n    if (onClick) onClick(e);\r\n    const processed = handleElementLink(e.target);\r\n    //console.log(processed)\r\n    if (processed.handled) {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    }\r\n  }\r\n\r\n  return utils.url.isExternalLink(to) ? (\r\n    <a href={to} target=\"_blank\" rel=\"noopener noreferrer\" onClick={(e) => goToLink(e)} {...other}>\r\n      {children}\r\n    </a>\r\n  ) : (\r\n    <Link to={to} onClick={(e) => goToLink(e)} {...other}>\r\n      {children}\r\n    </Link>\r\n  );\r\n}\r\n","import { css } from '@emotion/core'\r\nimport { mixin, mq } from '../../cssInJs'\r\n\r\nexport default {\r\n  tiles: css(mq({\r\n    marginLeft: [0, -5, null, -10],\r\n    marginRight: [0, -5, null, -10],\r\n    display: 'flex',\r\n    justifyContent: 'center',\r\n    flexWrap: 'wrap'\r\n  })),\r\n  tile: css(mq({\r\n    flexBasis: ['50%', '33.33%', '25%', '25%', '20%', '16.66%'],\r\n    padding: [0, 5, null, 10],\r\n    cursor: 'pointer'\r\n  })),\r\n  tileImage: css({\r\n    position: 'relative',\r\n    display: 'block',\r\n    ':after': { ...mixin.overlay() },\r\n    ':hover, :focus': {\r\n      ':after': {\r\n        backgroundColor: 'rgba(0, 0, 0, 0.2)'\r\n      }\r\n    }\r\n  }),\r\n  tileIcon: css({\r\n    position: 'absolute',\r\n    top: 10,\r\n    right: 10,\r\n    fontSize: 30,\r\n    color: 'white',\r\n    zIndex: 1\r\n  })\r\n}","import React from 'react';\r\n/** @jsx jsx */\r\nimport { jsx } from '@emotion/core'\r\nimport env from '../../env';\r\nimport utils from '../../utils';\r\nimport { useGet, ErrorPopup, Loading } from '../../components';\r\nimport style from './feedStyle';\r\nimport {FaRegCaretSquareRight, FaRegClone} from 'react-icons/fa';\r\n\r\nexport function InstagramFeed(props){\r\n  const get = useGet();\r\n\r\n  React.useEffect(() => {\r\n    get.send(env.apiBase + `/api/instagram/GetInstagramFeeds`);\r\n    // eslint-disable-next-line\r\n  }, []);\r\n\r\n  if (get.loading()) {\r\n    return <Loading />\r\n  } else if (get.hasErrors()) {\r\n    return <ErrorPopup title=\"Loading Error\" errors={get.errors} />\r\n  }\r\n\r\n  // console.log(get)\r\n  const data = get.response;\r\n  if (data.length === 0) return null\r\n  return (\r\n    <Feeds posts={data} />\r\n  );\r\n}\r\n\r\nfunction Feeds({posts}) {\r\n  const numOfTileLines = 2;\r\n  const bp = utils.ui.getCurrentBreakpoint();\r\n  const tilesPerLine = {xs:2, sm:3, md:4, lg:4, xl:5, xxl:6}\r\n  const numOfPost = numOfTileLines * (tilesPerLine[bp] || 6);\r\n  console.log(bp, numOfTileLines, numOfPost)\r\n  const displayingPosts = posts.length > numOfPost ? posts.slice(0, numOfPost) : posts;\r\n\r\n  return (\r\n    <div css={style.tiles}>\r\n      {displayingPosts.map((item, index) =>\r\n      <Feed key={index} item={item} />)}\r\n    </div>\r\n  )\r\n}\r\n\r\nfunction Feed({item}) {\r\n  return (\r\n    <div css={style.tile}>\r\n      {/* {item.link} */}\r\n      <a href={item.link} target=\"_blank\" rel=\"noopener noreferrer\" css={style.tileImage}>\r\n        <img src={utils.site.resourcePath(`/instagram/${item.filename}`)} alt={item.filename} />\r\n        {item.type === 'video' && <FaRegCaretSquareRight css={style.tileIcon} />}\r\n        {item.type === 'carousel' && <FaRegClone css={style.tileIcon} />}\r\n      </a>\r\n    </div>\r\n  )\r\n}","// https://www.pluralsight.com/guides/re-render-react-component-on-window-resize\r\nexport function debounce(fn, ms) {\r\n  let timer\r\n  return _ => {\r\n    clearTimeout(timer)\r\n    timer = setTimeout(_ => {\r\n      timer = null\r\n      fn.apply(this, arguments)\r\n    }, ms)\r\n  };\r\n}","import utils from '../../utils';\r\n\r\nexport function loadApi(onApiReady) {\r\n  \r\n  if (typeof window !== `undefined` && !window.YT) { // If not, load the script asynchronously\r\n    const tag = document.createElement('script');\r\n    tag.src = 'https://www.youtube.com/iframe_api';\r\n    tag.id = 'youtubeIframeApJaba';\r\n\r\n    // onYouTubeIframeAPIReady will load the video after the script is loaded\r\n    window.onYouTubeIframeAPIReady = () => onApiReady(true);\r\n\r\n    const firstScriptTag = document.getElementsByTagName('script')[0];\r\n    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\r\n  } else { // If script is already there, load the video directly\r\n    onApiReady(false);\r\n  }\r\n\r\n}\r\n\r\n// export function player(playerId, videoId, playerVars = {}, events = {}) {\r\n//   //let player = null;\r\n//   const defaultPlayerVars = {\r\n//     'autoplay': 1,\r\n//     'controls': 0,\r\n//     'loop': 1,\r\n//     'showinfo': 0,\r\n//     'rel': 0,\r\n//     'modestbranding': 1,\r\n//     'origin': window.location.origin,\r\n//     'allowfullscreen': true,\r\n//     'wmode': 'transparent'\r\n//   }\r\n//   const defaultEvents = {\r\n//     'onStateChange': (e) => { },\r\n//     'onReady': (e) => { console.log('onReady'); player.mute() },\r\n//     'onError': (e) => { console.log(e) }\r\n//   }\r\n\r\n//   const player = new window.YT.Player(playerId, {\r\n//     videoId: videoId,\r\n//     playerVars: Object.assign({}, defaultPlayerVars, playerVars),\r\n//     events: Object.assign({}, defaultEvents, events),\r\n//   });\r\n//   return player;\r\n// }\r\n\r\nexport function thumbnailMax(videoId){\r\n  return `https://img.youtube.com/vi/${videoId}/maxresdefault.jpg`\r\n}\r\n\r\n// onPlayerStateChange(event){\r\n//   switch (event.data){\r\n//     case window['YT'].PlayerState.PLAYING:\r\n//       //console.log('Playing');\r\n//       //this.player.mute();\r\n//       break;\r\n//     case window['YT'].PlayerState.PAUSED:\r\n//       //console.log('Pafdsu');\r\n//       break;\r\n//     case window['YT'].PlayerState.ENDED:\r\n//       //console.log('ended ');\r\n//       //this.player.playVideo();\r\n//       this.player.stopVideo();\r\n//       break;\r\n//   }\r\n// }\r\n\r\n// toggleBannerYoutueInCMS(toggleItem:string){ \r\n//   if(toggleItem == 'youtube'){\r\n//     //location.reload();\r\n//     this.toggleBannerOrYoutube = toggleItem;\r\n//     this.player.playVideo();\r\n//     this.init();\r\n//   }\r\n//   else{\r\n//     this.toggleBannerOrYoutube = toggleItem;\r\n//     this.player.stopVideo();\r\n//   }\r\n// }\r\n\r\n\r\nexport function getYoutubeCode(src) {\r\n  // if (src.indexOf('http') >= 0) {\r\n  //   if (src.indexOf('v=') >= 0) {\r\n  //     return src.split('v=')[1];\r\n  //   }\r\n  // }\r\n  // return src;\r\n  return utils.url.getYoutubeId(src);\r\n}","import React from 'react';\r\nimport utils from '../../utils';\r\nimport * as yt from './iframeApi';\r\nimport { FaRegPlayCircle } from 'react-icons/fa';\r\nimport { useStore } from '../../store';\r\n\r\nexport function YoutubeEmbedPopup({ url, title, posterUrl }) {\r\n  const { dispatch } = useStore();\r\n\r\n  const videoId = yt.getYoutubeCode(url);\r\n  const posterImageUrl = utils.site.resourcePath(posterUrl || yt.thumbnailMax(videoId));\r\n  const [popupIndex, setPopupIndex] = React.useState(0);\r\n\r\n  function openVideo() {\r\n    setPopupIndex(popupIndex + 1);\r\n    dispatch({ type: 'SET_POPUP', payload: { sources: [\r\n      // <iframe width=\"560\" height=\"315\" src={`https://www.youtube.com/embed/${videoId}`} frameborder=\"0\" allow=\"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\r\n      'https://www.youtube.com/watch?v=' + videoId\r\n    ], popupIndex: popupIndex + 1} });\r\n  }\r\n  return (\r\n    <div className=\"ytEmdPopup__poster\" style={{ backgroundImage: utils.css.bgUrlStyle(posterImageUrl) }} onClick={openVideo}>\r\n      <FaRegPlayCircle className=\"ytEmdPopup__playIcon\" />\r\n    </div>\r\n  );\r\n}\r\n","function payload(item, key, defaultVal = '') {\n  const found = item.payloads.find(x => x.key === key);\n  return found ? found.value : defaultVal;\n}\n\nfunction getCodeJson(item) {\n  const code = payload(item, 'Code');\n  const codeType = payload(item, 'CodeType');\n  if (codeType === 'Json') {\n    const codeJson = JSON.parse(code);\n    return codeJson\n  }\n  return null\n}\n\n\nfunction hasItemInPageDataByItemTypeCode(pageData, itemTypeCode) {\n  return hasItemInPageData(pageData, item => item.itemTypeCode === itemTypeCode);\n}\n\n// hasItemInPageData(cmsOption.pageData, '')\n// matchFn = (item) => item.itemTypeCode === itemTypeCode\nfunction hasItemInPageData(pageData, matchFn) {\n  if (!pageData) return false;\n  for (let i = 0; i < pageData.sections.length; i++) {\n    if (hasItemInItems(pageData.sections[i].items, matchFn)) return true;\n  }\n  return false;\n}\n\nfunction hasItemInItems(items, matchFn) {\n  if (!items) return false;\n  for (let i = 0; i < items.length; i++) {\n    if (matchFn(items[i])) return true;\n    if (hasItemInItems(items[i].items, matchFn)) return true;\n  }\n  return false;\n}\n\nexport default { payload, getCodeJson, hasItemInPageData, hasItemInItems, hasItemInPageDataByItemTypeCode };","import React from 'react';\nimport cmsUtils from '../cmsUtils';\nimport { InstagramFeed } from 'components';\nimport { isOffline } from '@site/_offline';\n\nexport const renderRule = {\n  match: (item, cmsOption) => (cmsUtils.getCodeJson(item) || {})['control'] === 'instagram', \n  itemElt: (item, cmsOption) => (!isOffline() && <InstagramFeed />)\n}","// export { getOfflinePage, getOperators, getOperator, getOperatorById, getFeaturedOperators, getDestination, getExpTypes, getExpType } from './dbSelect'\n// export { indexOfflineData } from './dbInsert'\n// export { addCache, checkCache, existInCache, getAllImagesInCache } from './cache'\n// export { getOfflineMedia } from './media'\n// export { initInstallEventHandler, isInPWA } from './pwa'\n// export { isIOS } from './device'\n\nexport function isOffline() {\n  // return true;\n  return !navigator.onLine;\n}\n\n\nexport async function getStorageInfo() {\n  const messages = []\n  if (!('indexedDB' in window)) {\n    console.log('not supported')\n  }\n  if ('caches' in window) {\n    messages.push('Cache available')\n  }\n  if (navigator.storage && navigator.storage.estimate) {\n    const quota = await navigator.storage.estimate();\n    // quota.usage -> Number of bytes used.\n    // quota.quota -> Maximum number of bytes available.\n    const percentageUsed = ((quota.usage / quota.quota) * 100).toFixed(2);\n    messages.push(`You've used ${percentageUsed}% of the available storage.`);\n    const remaining = ((quota.quota - quota.usage) / 1024 / 1024).toFixed(2);\n    messages.push(`You can write up to ${remaining} more MBs.`);\n  }\n\n  if (navigator.storage && navigator.storage.persist) {\n    const persistent = await navigator.storage.persist();\n    if (persistent)\n      messages.push(\"Storage will not be cleared except by explicit user action\");\n    else\n      messages.push(\"Storage may be cleared by the UA under storage pressure.\");\n  }\n\n  return messages;\n}\n","export function findControl(controlNameOrIndex, root) {\r\n  if (typeof controlNameOrIndex === 'number' && root && root.controls.length > controlNameOrIndex) return root.controls[controlNameOrIndex];\r\n  return findControlTraverse(controlNameOrIndex, root);\r\n}\r\n\r\nfunction findControlTraverse(controlName, control) {\r\n  if (!control) return null;\r\n  if (control.name === controlName) return control;\r\n  if (control.controls && control.controls.length > 0) {\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      const found = findControlTraverse(controlName, control.controls[i]);\r\n      if (found) {\r\n        return found;\r\n      }\r\n    }\r\n  }\r\n  return null;\r\n}\r\n\r\nexport function findControlById(id, root) {\r\n  return findControlByIdTraverse(id, root);\r\n}\r\n\r\nfunction findControlByIdTraverse(id, control) {\r\n  if (!control) return null;\r\n  if (control.id === id) return control;\r\n  if (control.controls && control.controls.length > 0) {\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      const found = findControlByIdTraverse(id, control.controls[i]);\r\n      if (found) {\r\n        return found;\r\n      }\r\n    }\r\n  }\r\n  return null;\r\n}\r\n\r\nexport function getValue(root) {\r\n  //console.log(root)\r\n  return getValueTraverse(root);\r\n}\r\n\r\nconst helperFns = {\r\n  getValueTraverse: getValueTraverse,\r\n  getFilesTraverse: getFilesTraverse\r\n}\r\n\r\nfunction getKeyValueTraverse(control) {\r\n  let keyValue = {};\r\n  keyValue[control.name] = getValueTraverse(control);\r\n  return keyValue\r\n}\r\n\r\nfunction getValueTraverse(control) {\r\n  //console.log(control);\r\n  if (control.controlType === 'control') {\r\n    if (control.customValueFn)\r\n      return control.customValueFn(control, helperFns);\r\n\r\n    return control.value;\r\n  } else if (control.controlType === 'group') {\r\n    if (control.customValueFn)\r\n      return control.customValueFn(control, helperFns);\r\n\r\n    let value = {};\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      value = { ...value, ...getKeyValueTraverse(control.controls[i]) };\r\n    }\r\n    return value;\r\n  } else if (control.controlType === 'array') {\r\n    if (control.customValueFn)\r\n      return control.customValueFn(control, helperFns);\r\n\r\n    const array = [];\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      array.push(getValueTraverse(control.controls[i]))\r\n    }\r\n    return array;\r\n  }\r\n  return null;\r\n}\r\n\r\nexport function getFiles(root) {\r\n  //console.log(root)\r\n  return getFilesTraverse(root);\r\n}\r\n\r\nfunction getFilesTraverse(control) {\r\n  if (control.controlType === 'control') {\r\n    return control.files ? [{ name: control.name, files: control.files }] : [];\r\n  } else if (control.controlType === 'group') {\r\n    let files = [];\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      files.push(...getFilesTraverse(control.controls[i]));\r\n    }\r\n    return files;\r\n  } else if (control.controlType === 'array') {\r\n    let files = [];\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      files.push(...getFilesTraverse(control.controls[i]));\r\n    }\r\n    return files;\r\n  }\r\n  return [];\r\n}","//import uuid from 'uuid/v4';\r\nimport shortid from 'shortid';\r\nimport * as formModelHelper from './formModelHelper';\r\n\r\n//#region helpers\r\nfunction findIndexById(id) {\r\n  for (let i = 0; i < this.controls.length; i++) {\r\n    if (this.controls[i].id === id) return i;\r\n  }\r\n  return -1;\r\n}\r\n//#endregion\r\n\r\nconst group = (controls) => {\r\n  const controlArray = [];\r\n  //console.log('group', controls, typeof controls);\r\n  if (controls && typeof controls === 'object') {\r\n    Object.keys(controls).forEach((key) => {\r\n      controlArray.push(abstractControl(key, controls[key]));\r\n    });\r\n  }\r\n\r\n  const ctrl = {\r\n    controlType: 'group',\r\n    id: shortid(),\r\n    controls: controlArray,\r\n    find: (name) => controlArray.find((x) => x.name === name),\r\n    customValueFn: null, // function\r\n    disableValidators: false,\r\n  };\r\n  ctrl.getValue = () => formModelHelper.getValue(ctrl);\r\n  ctrl.controls.forEach((x) => (x.parent = ctrl));\r\n\r\n  return ctrl;\r\n};\r\n\r\nconst array = (controls) => {\r\n  //console.log('array', controls);\r\n  const ctrl = {\r\n    controlType: 'array',\r\n    id: shortid(),\r\n    controls: controls,\r\n    findIndexById: findIndexById,\r\n  };\r\n  ctrl.getValue = () => formModelHelper.getValue(ctrl);\r\n  ctrl.controls.forEach((x) => (x.parent = ctrl));\r\n\r\n  return ctrl;\r\n};\r\n\r\nconst abstractControl = (name, controlObject) => {\r\n  //console.log('abstractControl', name, controlObject);\r\n  if (!controlObject) return null;\r\n  // array or group\r\n  if (controlObject.controlType) {\r\n    controlObject.name = name;\r\n    return controlObject;\r\n  } else {\r\n    return control(name, controlObject);\r\n  }\r\n};\r\n\r\nconst control = (name, [value, validators, controlOptions]) => {\r\n  //const { label, type, options, style } = controlOptions || {};\r\n  //console.log(value, validators, label, type, options)\r\n  return {\r\n    ...{\r\n      controlType: 'control',\r\n      id: shortid(),\r\n      name: name,\r\n      value: value,\r\n      validators: validators || [],\r\n      touched: false,\r\n      incomplete: false,\r\n      findValidator: (type) => (validators || []).find((x) => x.type === type),\r\n      // label: label,\r\n      // type: type,\r\n      // options: options,\r\n      // style: style\r\n    },\r\n    ...controlOptions,\r\n  };\r\n};\r\n\r\nexport default { group, array };\r\n","import utils from '../../utils';\r\n\r\nexport function hasRequiredValidator(control) {\r\n  if (!control) return false;\r\n  return !!control.findValidator('required')\r\n}\r\n\r\nexport function getNameForValidator(label, name) {\r\n  return utils.text.toFieldName(label || name);\r\n}\r\n\r\nexport function getValidatorOptions(params) {\r\n  const defaultOpt = { continueToValidate: false }\r\n  return params ? { ...defaultOpt, ...params } : defaultOpt;\r\n}\r\n\r\nexport function createValidator(type, message, opt, validate) {\r\n  const validator =\r\n  {\r\n    type: type,\r\n    disabled: false,\r\n    ...getValidatorOptions(opt),\r\n    message: message,\r\n    validate: validate\r\n  }\r\n  return validator;\r\n}","import { createValidator, getNameForValidator } from '../validatorHelper';\r\n\r\nexport function Required(message = null, opt = null) {\r\n  return createValidator('required', message, opt, function(control, e, validateOpt) {\r\n    if (validateOpt.triggeredByChange && control.incomplete) return null;\r\n    return isEmpty(control.value) ? (message || (getNameForValidator(control.label, control.name) + ' is required.')) : null\r\n  })\r\n}\r\n\r\nfunction isEmpty(val) {\r\n  if (Array.isArray(val))\r\n    return val.length === 0;\r\n  return !val && val !== 0;\r\n}\r\n","import { createValidator, getNameForValidator } from '../validatorHelper';\r\n\r\nexport function Email(message = null, opt = null) {\r\n  return createValidator('email', message, opt, function(control, e, validateOpt) {\r\n    if (validateOpt.triggeredByChange && control.incomplete) return null;\r\n    // only validate for blur keydown tab\r\n    if (e && e.type === 'change') return null;\r\n    return !isEmpty(control.value) && !isValidEmail(control.value) ? (message || (getNameForValidator(control.label, control.name) + ' - Invalid email.')) : null\r\n  })\r\n}\r\n\r\n\r\nexport const isValidEmail = mail => {\r\n  const regex = /^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\r\n  return regex.test(mail);\r\n}\r\n\r\nfunction isEmpty(val) {\r\n  if (Array.isArray(val))\r\n    return val.length === 0;\r\n  return !val && val !== 0;\r\n}\r\n","import { createValidator, getNameForValidator } from '../validatorHelper';\r\nimport utils from '../../../utils';\r\n\r\nexport function ValidateDate(message = null, opt = null) {\r\n  return createValidator('date', message, opt, function (control, e, validateOpt) {\r\n    if (validateOpt.triggeredByChange && control.incomplete) return null;\r\n    return !isDate(control.value) ? message || getNameForValidator(control.label, control.name) + ' is invalid.' : null;\r\n  });\r\n}\r\n\r\nexport function PastDate(message = null, opt = null) {\r\n  return createValidator('past-date', message, opt, function (control, e, validateOpt) {\r\n    if (validateOpt.triggeredByChange && control.incomplete) return null;\r\n    return !isPast(control.value) ? message || getNameForValidator(control.label, control.name) + ' is invalid.' : null;\r\n  });\r\n}\r\n\r\nexport function PastDateNullAllowed(message = null, opt = null) {\r\n  return createValidator('past-date', message, opt, function (control, e, validateOpt) {\r\n    if (validateOpt.triggeredByChange && control.incomplete) return null;\r\n    return control.value && !isPast(control.value) ? message || getNameForValidator(control.label, control.name) + ' is invalid.' : null;\r\n  });\r\n}\r\n\r\nfunction isDate(val) {\r\n  if (val) {\r\n    const date = utils.date.toDate(val);\r\n    return !!date;\r\n  }\r\n  return false;\r\n}\r\n\r\nfunction isPast(val) {\r\n  if (val) {\r\n    const date = utils.date.toDate(val);\r\n    //console.log(date, typeof date)\r\n    if (date) {\r\n      const now = new Date();\r\n      return date.getTime() < now.getTime();\r\n    }\r\n  }\r\n  return false;\r\n}\r\n","import { createValidator, getNameForValidator } from '../validatorHelper';\r\n\r\nexport function Length(message = null, opt = null) {\r\n  return createValidator('email', message, opt, function(control, e, validateOpt, validator) {\r\n    if (validateOpt.triggeredByChange && control.incomplete) return null;\r\n    return !isValidLength(control.value, validator) ? (message || (getNameForValidator(control.label, control.name) + ' - Invalid length.')) : null\r\n  })\r\n}\r\n\r\n\r\nexport const isValidLength = (text, validator) => {\r\n  const length = (text || '').length;\r\n  if (validator.min && length < validator.min) return false;\r\n  if (validator.max && length > validator.max) return false;\r\n  return true;\r\n}\r\n","import { Required } from './validators/required';\r\nimport { Email } from './validators/email';\r\nimport { ValidateDate, PastDate, PastDateNullAllowed } from './validators/date';\r\nimport { Length } from './validators/length';\r\n\r\nconst validateControl = (control, e, validateOpt) => {\r\n  const errors = [];\r\n  const validators = control.validators || [];\r\n  for (let i = 0; i < validators.length; i++) {\r\n    const validator = validators[i];\r\n    if (!validator.disabled) {\r\n      const error = validator.validate && validator.validate(control, e, validateOpt, validator);\r\n      if (error) {\r\n        errors.push(error);\r\n        //console.log(error, control, validator, e)\r\n\r\n        if (!validator.continueToValidate) break;\r\n      }\r\n    }\r\n  }\r\n  control.errors = errors;\r\n  return errors;\r\n};\r\n\r\nexport default {\r\n  Required,\r\n  Email,\r\n  Date: ValidateDate,\r\n  PastDate,\r\n  PastDateNullAllowed,\r\n  Length,\r\n  validateControl,\r\n};\r\n","import utils from '../../utils';\r\nimport React from 'react';\r\nimport { hasRequiredValidator } from './validatorHelper';\r\n\r\nexport function getLabel(control, formOption) {\r\n  //console.log(label, label == null, label === null, name, label || name)\r\n  const { label, name } = control\r\n  const requiredMark = hasRequiredValidator(control) && (formOption.requiredMark || '*')\r\n  if (label === null) return \"\";\r\n  return <>\r\n    <span dangerouslySetInnerHTML={{ __html: label || utils.text.toFieldName(name) }}></span>\r\n    {requiredMark && <span className=\"req\">{requiredMark}</span>}\r\n  </>;\r\n}\r\n\r\nexport function getLabelAsString(control, formOption) {\r\n  //console.log(label, label == null, label === null, name, label || name)\r\n  const { label, name } = control\r\n  const requiredMark = hasRequiredValidator(control) && (formOption.requiredMark || '*')\r\n  if (label === null) return \"\";\r\n  \r\n  return (label || utils.text.toFieldName(name)) + (requiredMark ? requiredMark : '');\r\n}","import React from 'react';\r\n\r\nconst ValidationAlert = ({ errors }) => {\r\n    if (!errors || errors.length === 0) return null;\r\n    return <div className=\"invalid\" role=\"alert\" dangerouslySetInnerHTML={{ __html: errors.join('<br/>') }}></div>\r\n}\r\n\r\nexport default ValidationAlert;","import * as React from 'react';\r\nimport ValidationAlert from '../components/ValidationAlert';\r\nimport utils from '../../../utils';\r\nimport { getLabel, getLabelAsString } from '../formRenderHelper';\r\n\r\nfunction TextInput({ control, handleChange, formOption }) {\r\n    const { name, label, type, value, errors, style, helpText, attrs, forceUsePlaceholder } = control;\r\n    //const { template = 'bootstrap', usePlaceholder = false } = formOption;\r\n    const fieldId = utils.random.shortId();\r\n    const { usePlaceholder = false } = formOption;\r\n    const fieldLabel = getLabel(control, formOption);\r\n    //console.log(control, formOption)\r\n    const placeHolder = usePlaceholder ? getLabelAsString(control, formOption) : null;\r\n    let valueStr = value === 0 ? 0 : (value || \"\");\r\n    if (type === 'date' && value) {\r\n        valueStr = utils.date.formatYYYYMMDD(value);\r\n    }\r\n\r\n    let prependText = null;\r\n    if (style && style.prependText) {\r\n        prependText = style.prependText\r\n    }\r\n    //console.log(name, !!(style && style.autoFocus))\r\n    //const autoFocus = !!(style && style.autoFocus)\r\n\r\n    function keyDown(e) {\r\n        //console.log(e.key)\r\n        if (e.key === \"Enter\" || e.key === 'Tab') {\r\n            handleChange(e, control)\r\n        }\r\n    }\r\n    function changed(e) {\r\n        //console.log('changed', name, e.target.value)\r\n        handleChange(e, control)\r\n    }\r\n    function blur(e) {\r\n        //console.log('blur', name, e.target.value)\r\n        handleChange(e, control)\r\n    }\r\n\r\n    // function focus(e) {\r\n    //     console.log('focus', name, e.target.value)\r\n    // }\r\n\r\n    return (\r\n        <div className={`ff ff--${type} form-group ${style && style.className}`}>\r\n            {!usePlaceholder && fieldLabel && <label htmlFor={fieldId} className=\"label\">{fieldLabel}</label>}\r\n            <div className={`ff__input ${prependText && 'input-group'}`}>\r\n                {prependText && <div className=\"input-group-prepend\">\r\n                    <div className=\"input-group-text\">{prependText}</div>\r\n                </div>\r\n                }\r\n\r\n                <input id={fieldId} name={name} type={type} value={valueStr} //onChange={(e) => handleChange(e, control)} \r\n                    // onBlur={(e) => handleChange(e, control, true)}\r\n                    onChange={changed}\r\n                    onKeyDown={keyDown}\r\n                    onBlur={blur}\r\n                    autoComplete=\"new-password\"\r\n                    //onFocus={focus}\r\n                    //autoFocus={autoFocus}\r\n                    placeholder={(forceUsePlaceholder && forceUsePlaceholder !== '') ? forceUsePlaceholder : placeHolder}\r\n                    className={\"form-control\" + (errors && errors.length > 0 ? ' is-invalid' : '')} {...attrs} />\r\n            </div>\r\n            {helpText && <div className=\"ff__help\" dangerouslySetInnerHTML={{ __html: helpText }}></div>}\r\n            <ValidationAlert errors={errors} />\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default TextInput;","import React from 'react';\r\nimport ValidationAlert from '../components/ValidationAlert';\r\nimport utils from '../../../utils';\r\nimport { getLabel } from '../formRenderHelper';\r\n\r\nfunction RadioListInput({ control, handleChange, formOption }) {\r\n    const { name, label, value, errors, style, options, helpText, helpLabelText, attrs } = control;\r\n    const fieldId = utils.random.shortId();\r\n    const fieldLabel = getLabel(control, formOption);\r\n    return (\r\n        <div className={`ff ff--radiolist form-group ${style && style.className}`}>\r\n            {fieldLabel && <label className=\"label\">\r\n                {fieldLabel}\r\n                {\r\n                    helpLabelText &&\r\n                    <span className='help__label__text'>{helpLabelText}</span>\r\n                }      \r\n            </label>}\r\n            <div className=\"ff__input controlOptions\">\r\n                {options && options.map((option, index) =>\r\n                    <div className={`form-check ${style && style.inline && 'form-check-inline'}`} key={option.value}>\r\n                        <input className=\"form-check-input\" name={name} type=\"radio\"\r\n                            checked={checked(value, option.value)}\r\n                            onChange={(e) => handleChange(e, control)}\r\n                            value={option.value} id={fieldId + '_' + index} {...attrs} />\r\n                        <label className=\"form-check-label\" htmlFor={fieldId + '_' + index}>\r\n                            {option.name}\r\n                        </label>\r\n                        {\r\n                            (option.helpText && option.helpText !== '') &&\r\n                            <label className={`form-check-label help-text ${(option.id && option.id !== '') && option.id}`} dangerouslySetInnerHTML={{ __html: option.helpText }}></label>\r\n                        }\r\n                    </div>)}\r\n            </div>\r\n            {helpText && <div className=\"ff__help\" dangerouslySetInnerHTML={{ __html: helpText }}></div>}\r\n            <ValidationAlert errors={errors} />\r\n        </div>\r\n    )\r\n}\r\n\r\nfunction checked(value, optionValue) {\r\n    if (optionValue === null || typeof optionValue === 'undefined') return false;\r\n    return value === optionValue;\r\n}\r\n\r\nexport default RadioListInput;","import React from 'react';\r\nimport ValidationAlert from '../components/ValidationAlert';\r\nimport utils from '../../../utils';\r\nimport { getLabel } from '../formRenderHelper';\r\n\r\nconst CheckboxListInput = ({ control, handleChange, formOption }) => {\r\n    const { name, label, value, errors, style, options, helpText, attrs } = control;\r\n    const fieldId = utils.random.shortId();\r\n    const fieldLabel = getLabel(control, formOption);\r\n    const values = value ? [...value] : [];\r\n    return (\r\n        <div className={`ff ff--checkbox form-group ${style && style.className}`}>\r\n            {fieldLabel && <label className=\"label\">{fieldLabel}</label>}\r\n            <div className=\"ff__input\">\r\n                <div className=\"controlOptions\">\r\n                    {options && options.map((option, index) =>\r\n                        <div className={`form-check ${style && style.inline && 'form-check-inline'}`} key={option.value} >\r\n                            <input className=\"form-check-input\" name={name} type=\"checkbox\"\r\n                                checked={checked(values, option.value)}\r\n                                onChange={(e) => handleChange(e, control)}\r\n                                value={option.value} id={fieldId + '_' + index} {...attrs}/>\r\n                            <label className=\"form-check-label\" htmlFor={fieldId + '_' + index}>\r\n                                {option.name}\r\n                            </label>\r\n                        </div>)}\r\n\r\n                </div>\r\n            </div>\r\n            {helpText && <div className=\"ff__help\" dangerouslySetInnerHTML={{ __html: helpText }}></div>}\r\n            <ValidationAlert errors={errors} />\r\n        </div>\r\n    )\r\n}\r\n\r\nfunction checked(values, value) {\r\n    if (value === null || typeof value === 'undefined') return false;\r\n    return values.includes(value);\r\n}\r\n\r\nexport default CheckboxListInput;","import * as React from 'react';\r\nimport ValidationAlert from '../components/ValidationAlert';\r\nimport utils from '../../../utils';\r\nimport { getLabel } from '../formRenderHelper';\r\n\r\nfunction DateSeparateInput({ control, handleChange, formOption }) {\r\n    //const { name, label, value, errors, style } = control;\r\n    const { name, label, errors, style, helpText, attrs } = control;\r\n    const thisYear = (new Date()).getFullYear();\r\n    //console.log(name, value)\r\n    const [year, setYear] = React.useState('')\r\n    const [month, setMonth] = React.useState('')\r\n    const [day, setDay] = React.useState('')\r\n\r\n    //const { template = 'bootstrap', usePlaceholder = false } = formOption;\r\n    const fieldId = utils.random.shortId();\r\n    const { usePlaceholder = false } = formOption;\r\n    const fieldLabel = getLabel(control, formOption);\r\n    //console.log(label, name + '|'+ fieldLabel)\r\n    //const placeHolder = usePlaceholder ? fieldLabel : null;\r\n    // let valueStr = value === 0 ? 0 : (value || \"\");\r\n    // if (type === 'date' && value) {\r\n    //     valueStr = utils.date.formatYYYYMMDD(value);\r\n    // }\r\n\r\n    function handleChangeDay(e) {\r\n        setDay(e.target.value)\r\n        handleChangeInner(year, month, e.target.value)\r\n    }\r\n\r\n    function handleChangeMonth(e) {\r\n        setMonth(e.target.value)\r\n        handleChangeInner(year, e.target.value, day)\r\n    }\r\n\r\n    function handleChangeYear(e) {\r\n        setYear(e.target.value)\r\n        handleChangeInner(e.target.value, month, day)\r\n    }\r\n\r\n    function handleChangeInner(yyyy, mm, dd) {\r\n        control.incomplete = !(yyyy !== '' && mm !== '' && dd !== '')\r\n        const newVal = yyyy + '-' + mm + '-' + dd;\r\n        //console.log(newVal)\r\n        //mimic event\r\n        handleChange({\r\n            persist: () => { },\r\n            target: { name: name, value: newVal, checked: false }\r\n        }, control)\r\n    }\r\n\r\n    //const monthsFull = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']\r\n    const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']\r\n    const selectStyle = { width: 'auto', display: 'inline-block', marginRight: '0.5em' };\r\n\r\n    const fromYear = style && style.recentYear ? thisYear : thisYear - 10;\r\n    const recentYear = style && style.recentYear ? style.recentYear : 100;\r\n    return (\r\n        <div className=\"ff ff--dateSeperate form-group\">\r\n            {!usePlaceholder && fieldLabel && <label htmlFor={fieldId} className=\"label\">{fieldLabel}</label>}\r\n            <div className=\"ff__input\">\r\n                <select style={selectStyle} id={`day_${fieldId}`} value={day} onChange={(e) => handleChangeDay(e)}\r\n                    className={\"form-control\" + (errors && errors.length > 0 ? ' is-invalid' : '')} {...attrs}>\r\n                    <option value=''>Day</option>\r\n                    {[...Array(31).keys()].map(i => i + 1).map(d => <option key={d} value={d}>{d}</option>)}\r\n                </select>\r\n                <select style={selectStyle} id={`month_${fieldId}`} value={month} onChange={(e) => handleChangeMonth(e)}\r\n                    className={\"form-control\" + (errors && errors.length > 0 ? ' is-invalid' : '')} {...attrs}>\r\n                    <option value=''>Month</option>\r\n                    {[...Array(12).keys()].map(m => <option key={m} value={m + 1}>{months[m]}</option>)}\r\n                </select>\r\n                <select style={selectStyle} id={`year_${fieldId}`} value={year} onChange={(e) => handleChangeYear(e)}\r\n                    className={\"form-control\" + (errors && errors.length > 0 ? ' is-invalid' : '')} {...attrs}>\r\n                    <option value=''>Year</option>\r\n                    {[...Array(recentYear).keys()].map(y => fromYear - y).map(y => <option key={y} value={y}>{y}</option>)}\r\n                </select>\r\n            </div>\r\n            {helpText && <div className=\"ff__help\" dangerouslySetInnerHTML={{ __html: helpText }}></div>}\r\n            <ValidationAlert errors={errors} />\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default DateSeparateInput;","import * as React from 'react';\r\nimport ValidationAlert from '../components/ValidationAlert';\r\nimport utils from '../../../utils';\r\nimport { getLabel } from '../formRenderHelper';\r\n\r\nfunction FileInput({ control, handleChange, formOption }) {\r\n    const { name, label, type, value, errors, style, helpText, attrs } = control;\r\n    //const { template = 'bootstrap', usePlaceholder = false } = formOption;\r\n    const fieldId = utils.random.shortId();\r\n    const { usePlaceholder = false } = formOption;\r\n    const fieldLabel = getLabel(control, formOption);\r\n    //console.log(label, control)\r\n    const placeHolder = usePlaceholder ? fieldLabel : null;\r\n    let valueStr = value === 0 ? 0 : (value || \"\");\r\n    if (type === 'date' && value) {\r\n        valueStr = utils.date.formatYYYYMMDD(value);\r\n    }\r\n    return (\r\n        <div className={`ff ff--file form-group ${style && style.className}`}>\r\n            {!usePlaceholder && fieldLabel && <label htmlFor={fieldId} className=\"label\">{fieldLabel}</label>}\r\n            <div className=\"ff__input\">\r\n                <input style={{display: 'none'}} id={fieldId} name={name} type='file' value={valueStr} onChange={(e) => handleChange(e, control)} onBlur={(e) => handleChange(e, control)}\r\n                    placeholder={placeHolder}\r\n                    className={\"form-control-file\" + (errors && errors.length > 0 ? ' is-invalid' : '')} {...attrs}/>\r\n                <div className='choose-file-container'>\r\n                    <label htmlFor={fieldId} className='choose-file-label'> CHOOSE FILE </label>\r\n                    <div className='file__attach__text'> \r\n                        { valueStr === '' ? 'No File Chosen' : valueStr.replace(/^.*\\\\/, \"\")}\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            {helpText && <div className=\"ff__help\" dangerouslySetInnerHTML={{ __html: helpText }}></div>}\r\n            <ValidationAlert errors={errors} />\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default FileInput;","import TextInput from './TextInput';\r\nimport RadioListInput from './RadioListInput';\r\nimport TextareaInput from './TextareaInput';\r\nimport CheckboxInput from './CheckboxInput';\r\nimport CheckboxListInput from './CheckboxListInput';\r\nimport SelectInput from './SelectInput';\r\nimport HiddenInput from './HiddenInput';\r\n//import HtmlInput from './HtmlInput';\r\nimport DateSeparateInput from './DateSeparateInput';\r\nimport FileInput from './FileInput';\r\n\r\nconst Components = { TextInput, RadioListInput, TextareaInput, CheckboxInput, CheckboxListInput, SelectInput, HiddenInput, DateSeparateInput, FileInput };\r\n\r\nconst capitalize = expression => expression.charAt(0).toUpperCase() + expression.slice(1);\r\n\r\nexport function getControl(control, formOption) {\r\n  let Component = null;\r\n  if (control.type === 'number' || control.type === 'email' || control.type === 'date' || control.type === 'password' || control.type === 'tel')\r\n    Component = TextInput;\r\n  else if (control.type === \"dob\")\r\n    Component = DateSeparateInput;\r\n  else\r\n    Component = Components[capitalize(control.type || '') + 'Input'];\r\n\r\n  return Component;\r\n}\r\n\r\n","import React from \"react\";\r\nimport ValidationAlert from \"../components/ValidationAlert\";\r\nimport utils from \"../../../utils\";\r\nimport { getLabel, getLabelAsString } from \"../formRenderHelper\";\r\n\r\nfunction TextareaInput({ control, handleChange, formOption }) {\r\n  const { name, label, type, value, errors, style, helpText, attrs } = control;\r\n  const fieldId = utils.random.shortId();\r\n  const fieldLabel = getLabel(control, formOption);\r\n  //const { template = 'bootstrap', usePlaceholder = false } = formOption;\r\n  const { usePlaceholder = false } = formOption;\r\n  const placeHolder = usePlaceholder\r\n    ? getLabelAsString(control, formOption)\r\n    : null;\r\n  const valueStr = value === 0 ? 0 : value || \"\";\r\n\r\n  const textAreaRef = React.useRef(null);\r\n  const [textAreaHeight, setTextAreaHeight] = React.useState(\"auto\");\r\n  const [parentHeight, setParentHeight] = React.useState(\"auto\");\r\n\r\n  React.useEffect(() => {\r\n    const disableAutoHeight = (style && style.disableAutoHeight) || false;\r\n    if (!disableAutoHeight) {\r\n      if (textAreaRef.current) {\r\n        const h =\r\n          textAreaRef.current.scrollHeight > 60\r\n            ? textAreaRef.current.scrollHeight\r\n            : 60;\r\n        setParentHeight(`${h}px`);\r\n        setTextAreaHeight(`${h}px`);\r\n      }\r\n    }\r\n  }, [valueStr, style]);\r\n\r\n  function onChangeInternal(e) {\r\n    const disableAutoHeight = (style && style.disableAutoHeight) || false;\r\n    if (!disableAutoHeight) {\r\n      setTextAreaHeight(\"auto\");\r\n      if (textAreaRef.current) {\r\n        const h =\r\n          textAreaRef.current.scrollHeight > 60\r\n            ? textAreaRef.current.scrollHeight\r\n            : 60;\r\n        setParentHeight(`${h}px`);\r\n      }\r\n    }\r\n    handleChange(e, control);\r\n  }\r\n\r\n  return (\r\n    <div className={`ff ff--textarea form-group ${style && style.className}`}>\r\n      {!usePlaceholder && fieldLabel && (\r\n        <label htmlFor={fieldId} className=\"label\">\r\n          {fieldLabel}\r\n        </label>\r\n      )}\r\n      <div className=\"ff__input\" style={{ minHeight: parentHeight }}>\r\n        <textarea\r\n          id={fieldId}\r\n          name={name}\r\n          value={valueStr}\r\n          type={type}\r\n          onChange={onChangeInternal}\r\n          placeholder={placeHolder}\r\n          rows={style && style.rows}\r\n          ref={textAreaRef}\r\n          style={{ height: textAreaHeight }}\r\n          className={\r\n            \"form-control\" + (errors && errors.length > 0 ? \" is-invalid\" : \"\")\r\n          }\r\n          {...attrs}\r\n        ></textarea>\r\n      </div>\r\n      {helpText && (\r\n        <div\r\n          className=\"ff__help\"\r\n          dangerouslySetInnerHTML={{ __html: helpText }}\r\n        ></div>\r\n      )}\r\n      <ValidationAlert errors={errors} />\r\n    </div>\r\n  );\r\n}\r\n\r\nexport default TextareaInput;\r\n","import React from \"react\";\r\nimport ValidationAlert from \"../components/ValidationAlert\";\r\nimport utils from \"../../../utils\";\r\nimport { getLabel } from \"../formRenderHelper\";\r\nimport { SiteLink } from \"../../../components\";\r\n\r\nconst CheckboxInput = ({ control, handleChange, formOption }) => {\r\n  const {\r\n    name,\r\n    label,\r\n    type,\r\n    value,\r\n    errors,\r\n    style,\r\n    helpText,\r\n    attrs,\r\n    link,\r\n    linkText,\r\n  } = control;\r\n  const fieldId = utils.random.shortId();\r\n  const fieldLabel = getLabel(control, formOption);\r\n  return (\r\n    <div className={`form-group form-check ${style && style.className}`}>\r\n      <input\r\n        id={fieldId}\r\n        name={name}\r\n        type={type}\r\n        value={value || \"\"}\r\n        checked={value || false}\r\n        onChange={(e) => handleChange(e, control)}\r\n        className={\"form-check-input\"}\r\n        {...attrs}\r\n      />\r\n      <label htmlFor={fieldId} className=\"form-check-label\">\r\n        {fieldLabel}\r\n        {link &&\r\n          link !== \"\" &&\r\n          linkText &&\r\n          linkText !== \"\" &&\r\n          (link.includes(\".pdf\") ? (\r\n            <a href={link} className=\"checkbox_link_text\">\r\n              {\" \"}\r\n              {linkText}{\" \"}\r\n            </a>\r\n          ) : (\r\n            <SiteLink to={link} className=\"checkbox_link_text\">\r\n              {\" \"}\r\n              {linkText}{\" \"}\r\n            </SiteLink>\r\n          ))}\r\n      </label>\r\n\r\n      {helpText && (\r\n        <div\r\n          className=\"ff__help\"\r\n          dangerouslySetInnerHTML={{ __html: helpText }}\r\n        ></div>\r\n      )}\r\n      <ValidationAlert errors={errors} />\r\n    </div>\r\n  );\r\n};\r\n\r\nexport default CheckboxInput;\r\n","import React from 'react'\r\nimport ValidationAlert from '../components/ValidationAlert'\r\nimport utils from '../../../utils'\r\nimport { getLabel } from '../formRenderHelper'\r\n\r\nfunction SelectInput({ control, handleChange, formOption }) {\r\n  // eslint-disable-next-line\r\n  const { name, label, type, value, errors, style, options, helpText, attrs } =\r\n    control\r\n  const fieldId = utils.random.shortId()\r\n  const fieldLabel = getLabel(control, formOption)\r\n  //   console.log(value, typeof value);\r\n  let mainCategory = ''\r\n  if (options.filter((option) => option.selected)) {\r\n    if (\r\n      options.filter((option) => option.selected).length !== 0 &&\r\n      options.filter((option) => option.selected)[0].hasOwnProperty('name')\r\n    ) {\r\n      mainCategory = options.filter((option) => option.selected)[0].name\r\n    }\r\n  }\r\n\r\n  return (\r\n    <div className={`ff ff--select form-group ${style && style.className}`}>\r\n      {fieldLabel && (\r\n        <label htmlFor={fieldId} className=\"label\">\r\n          {fieldLabel}\r\n        </label>\r\n      )}\r\n      <div className=\"ff__input\">\r\n        <select\r\n          id={fieldId}\r\n          name={name}\r\n          type={type}\r\n          //   value={value === null ? '' : value}\r\n          onChange={(e) => handleChange(e, control)}\r\n          defaultValue={mainCategory === null ? '' : value}\r\n          className={\r\n            'form-control' + (errors && errors.length > 0 ? ' is-invalid' : '')\r\n          }\r\n          {...attrs}\r\n        >\r\n          <option value={mainCategory}>{mainCategory}</option>\r\n          {options &&\r\n            options.map((option) =>\r\n              option.name !== mainCategory ? (\r\n                <option\r\n                  key={option.value}\r\n                  value={option.value}\r\n                  disabled={!!option.disabled}\r\n                >\r\n                  {option.name}\r\n                </option>\r\n              ) : (\r\n                ''\r\n              )\r\n            )}\r\n        </select>\r\n      </div>\r\n      {helpText && (\r\n        <div\r\n          className=\"ff__help\"\r\n          dangerouslySetInnerHTML={{ __html: helpText }}\r\n        ></div>\r\n      )}\r\n      <ValidationAlert errors={errors} />\r\n    </div>\r\n  )\r\n}\r\n\r\nexport default SelectInput\r\n","import * as React from 'react';\r\nimport utils from '../../../utils';\r\n\r\nfunction TextInput({ control, handleChange, formOption }) {\r\n    const { name, value } = control;\r\n    const fieldId = utils.random.shortId();\r\n    let valueStr = value === 0 ? 0 : (value || \"\");\r\n\r\n\r\n    return (\r\n        <input id={fieldId} name={name} type=\"hidden\" value={valueStr} />\r\n    )\r\n}\r\n\r\nexport default TextInput;","import React from 'react';\r\nimport * as formModelHelper from './formModelHelper';\r\nimport { getControl } from './controls';\r\nimport { getSiteControl } from '../../form';\r\n\r\nexport function renderControlDirect(control, handleChange, formOption) {\r\n  if (control === null) return null;\r\n  let Component = getSiteControl(control, formOption) || getControl(control, formOption);\r\n  if (!Component) return control.value;\r\n  return <Component key={control.name} control={control} handleChange={handleChange} formOption={formOption} />;\r\n}\r\n\r\n\r\nexport function renderControl(formRoot, nameOrIndex, handleChange, formOption) {\r\n  //console.log(formRoot, name);\r\n  const control = formModelHelper.findControl(nameOrIndex, formRoot);\r\n  //console.log(control, formRoot, name, handleChange, formOption)\r\n  if (control) {\r\n    return renderControlDirect(control, handleChange, formOption);\r\n  }\r\n}\r\n\r\nexport default { renderControl, renderControlDirect }","import validators from './validators';\r\n\r\nexport function validate(root, validateOpt = {}) {\r\n  //console.log({...{ triggeredByChange: false }, ...validateOpt})\r\n  //console.log(root, validateOpt)\r\n  const errors = validateTraverse(root, {...{ triggeredByChange: false }, ...validateOpt});\r\n  return errors;\r\n}\r\n\r\nfunction validateTraverse(control, validateOpt) {\r\n  if (!control) return [];\r\n  //console.log(!!control.disableValidators, control)\r\n  if (!!control.disableValidators) { control.errors =[]; return []; }\r\n  const errors = [];\r\n  const errorsFromControl = validators.validateControl(control, null, validateOpt);\r\n  errors.push(...errorsFromControl);\r\n  //console.log(errorsFromControl, errors)\r\n  if (control.controls && control.controls.length > 0) {\r\n    for (let i = 0; i < control.controls.length; i++) {\r\n      const errorsFromSub = validateTraverse(control.controls[i], validateOpt);\r\n      errors.push(...errorsFromSub);\r\n    }\r\n  }\r\n  control.errors = errors;\r\n  return errors;\r\n}\r\n\r\n","import { useState } from 'react';\r\nimport controlRenderer from './controlRenderer';\r\nimport * as formModelHelper from './formModelHelper';\r\nimport * as formValidate from './formValidate';\r\nimport validators from './validators';\r\n\r\nconst useForm = (initialFormModel, option) => {\r\n  const [formModel, setFormModel] = useState(initialFormModel);\r\n  const formOption = {\r\n    ...{\r\n      template: 'bootstrap',\r\n      usePlaceholder: false,\r\n      requiredMark: '*',\r\n      onControlChanged: null,\r\n    },\r\n    ...option,\r\n  };\r\n\r\n  const handleChange = (e, controlFromEvent) => {\r\n    e.persist();\r\n    const control =\r\n      controlFromEvent || formModelHelper.findControl(e.target.name, formModel);\r\n    //console.log(control)\r\n    // const control = controlId? formModelHelper.findControlById(controlId, formModel)\r\n    //   : formModelHelper.findControl(e.target.name, formModel);\r\n    if (!control) return;\r\n\r\n    //console.log(control.value, e.target)\r\n    control.touched = true;\r\n    control.value = getControlValue(control, e.target);\r\n    if (control.type === 'file') {\r\n      control.files = e.target.files;\r\n    }\r\n\r\n    // parseInput(control);\r\n    if (control.onBeforeUpdateValue) {\r\n      control.onBeforeUpdateValue(control, formModel);\r\n    }\r\n\r\n    validators.validateControl(control, e, { triggeredByChange: true });\r\n    setFormModel({ ...formModel });\r\n\r\n    if (formOption.onControlChanged) {\r\n      formOption.onControlChanged(e, control);\r\n    }\r\n  };\r\n\r\n  const validateForm = (e, successHandler, errorHandler) => {\r\n    validateGroup(formModel, e, successHandler, errorHandler);\r\n  };\r\n\r\n  const validateGroup = (control, e, successHandler, errorHandler) => {\r\n    e && e.preventDefault();\r\n    const errors = formValidate.validate(control);\r\n\r\n    if (errors.length === 0) successHandler && successHandler();\r\n    else {\r\n      setFormModel({ ...formModel });\r\n      errorHandler && errorHandler(errors);\r\n    }\r\n  };\r\n\r\n  const reset = (model) =>\r\n    setFormModel(model ? { ...model } : { ...formModel });\r\n\r\n  // const parseInput = input => input.value = input.parseFun ? input.parseFun(input.value) : input.value;\r\n\r\n  const renderControl = (name, formRoot) =>\r\n    controlRenderer.renderControl(\r\n      formRoot || formModel,\r\n      name,\r\n      handleChange,\r\n      formOption\r\n    );\r\n  const renderControlDirect = (control) =>\r\n    controlRenderer.renderControlDirect(control, handleChange, formOption);\r\n\r\n  const getValue = (formRoot) =>\r\n    formModelHelper.getValue(formRoot || formModel);\r\n\r\n  const getFiles = (formRoot) =>\r\n    formModelHelper.getFiles(formRoot || formModel);\r\n\r\n  const findControl = (name, formRoot) => {\r\n    const control = formModelHelper.findControl(name, formRoot || formModel);\r\n    return control;\r\n  };\r\n  //return [controls, handleChange, handleSubmit, getValue]\r\n  return {\r\n    model: formModel,\r\n    errors: formModel.errors,\r\n    reset: reset,\r\n    renderControl: renderControl,\r\n    renderControlDirect: renderControlDirect,\r\n    findControl: findControl,\r\n    validateForm: validateForm,\r\n    validateGroup: validateGroup,\r\n    getValue: getValue,\r\n    getFiles: getFiles,\r\n  };\r\n};\r\n\r\nfunction getControlValue(control, el) {\r\n  //console.log(control, el)\r\n  if (control.type === 'checkboxList') {\r\n    const options = el.closest('.controlOptions');\r\n    if (options) {\r\n      return [...options.querySelectorAll('input:checked')].map((x) => x.value);\r\n    }\r\n    return [];\r\n  } else if (control.type === 'radioList') {\r\n    const options = el.closest('.controlOptions');\r\n    if (options) {\r\n      const val = [...options.querySelectorAll('input:checked')].map(\r\n        (x) => x.value\r\n      );\r\n      return val && val.length > 0 ? val[0] : null;\r\n    }\r\n    return null;\r\n  }\r\n  return control.type === 'checkbox' ? el.checked : el.value;\r\n}\r\n\r\nexport { useForm };\r\n","//#region GTM\r\nexport const hasGTM = () => {\r\n  return !!(typeof window !== `undefined` && window.dataLayer);\r\n}\r\n\r\nexport const pageView = (url, pageTitle = null) => {\r\n  if (!hasGTM()) return;\r\n\r\n  const pageOpt = pageTitle ? {\r\n    path: url,\r\n    title: pageTitle\r\n  } : { path: url }\r\n  //console.log(url, pageOpt)\r\n  window.dataLayer.push({\r\n    event: 'pageview',\r\n    page: pageOpt\r\n  })\r\n}\r\n\r\n// \r\nexport const sendEvent = (eventName, params) => {\r\n  if (!hasGTM()) return;\r\n  window.dataLayer.push(Object.assign({ event: eventName }, params || {}))\r\n}\r\n\r\nexport const sendGAEvent = (category, action, label, value) => {\r\n  if (!hasGTM()) return;\r\n  window.dataLayer.push(Object.assign({ event: 'gaEvent' }, { category: category || '', action: action || '', label: label || '', value: value || '' }))\r\n}\r\n//#endregion\r\n\r\n\r\n","import { css } from '@emotion/core'\nimport { variables, mq } from '../../cssInJs';\nimport { darken } from 'polished';\n\nconst buttonColor = variables.primaryColor;\n\nconst baseStyle = {\n  button: mq({\n    color: 'white',\n    padding: '0.7rem 1.5rem 1rem 1.5rem',\n    position: 'relative',\n    overflow: 'hidden',\n    display: 'inline-block',\n    appearance: 'none',\n    '-webkit-appearance': 'none',\n    //margin: '0 0.5rem',\n    '&:hover .buttonBg': {\n      background: darken(0.1, buttonColor),\n    },\n    '&:hover': {\n      color: 'white',\n      textDecoration: 'none',\n    }\n  }),\n  buttonBg: {\n    transition: 'all 0.3s',\n    borderRadius: '100%',\n    position: 'absolute',\n    background: buttonColor,\n    right: '-200px',\n    left: '-200px',\n    top: '-200px',\n    content: '\"\"',\n    bottom: '0',\n    zIndex: '0',\n  },\n  buttonTxt: {\n    zIndex: '1',\n    position: 'relative',\n  }\n}\n\nconst smallStyle = {\n  button: css(baseStyle.button, {\n    fontSize: '0.85rem',\n    fontWeight: 600,\n    letterSpacing: 1,\n    padding: '0.3rem 1.5rem 0.3rem 1.5rem',\n    '&:hover .buttonBg': {\n      background: darken(0.1, buttonColor),\n    },\n  }),\n  buttonBg: css(baseStyle.buttonBg, {\n    background: buttonColor,\n  }),\n  buttonTxt: baseStyle.buttonTxt\n}\n\nexport function getButtonStyle(type) {\n  if (type === 'small') {\n    return smallStyle\n  }\n  return baseStyle\n} \n","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport { getButtonStyle } from './buttonStyle';\n\nexport function FormButton({ onClick, status, children, buttonStyle, overridingStyle, to, ...other }) {\n  const s = getButtonStyle(buttonStyle);\n  const ss = overridingStyle || {};\n  return <a css={[s.button, ss.button]} href=\"/\" onClick={onClick} type=\"button\" disabled={status === 'pending'} {...other}>\n    <span css={[s.buttonBg, ss.buttonBg]} className=\"buttonBg\"></span>\n    <span css={[s.buttonTxt, ss.buttonTxt]}>\n      {status === 'pending' && <span className=\"spinner-grow spinner-grow-sm\" role=\"status\" aria-hidden=\"true\"></span>}\n      {children}</span>\n  </a>\n}\n","import React from 'react';\nimport env from '../../../env';\nimport { usePost } from '../../../components';\nimport { useForm } from '../../../form';\nimport { ErrorMessage } from '../../../components';\nimport { getModel } from './subscribeFormModel';\nimport { gtm } from '../../../lib/tracking';\nimport { FormButton } from '../../button/formButton';\nimport { variables } from 'cssInJs';\n\nimport { darken } from 'polished';\n\nexport function Subscribe() {\n\n  const model = getModel({});\n  const form = useForm(model, { usePlaceholder: true });\n  const [sendingStatus, setSendingStatus] = React.useState(null);\n  const post = usePost();\n\n  function onSubmit(e) {\n    e.preventDefault();\n    e.stopPropagation();\n    form.validateForm(e, () => {\n      const value = { ...form.getValue() };\n      post.send(env.apiBase + \"/api/contact/subscribe\", value);\n      setSendingStatus('pending')\n    })\n  }\n\n\n  if (post.done() && sendingStatus === 'pending') {\n    var value = form.getValue();\n    gtm.sendEvent('subscribeFormSubmitted', {contactEmail: value.email} )\n    form.reset(model)\n    setSendingStatus(null)\n  }\n\n  const render = (name) => form.renderControl(name, null);\n\n  const overridingStyle = {\n    button: {\n      '&:hover .buttonBg': {\n        background: darken(0.1, variables.colorBlue),\n      },\n    },\n    buttonBg: {\n      background: variables.colorBlue,\n    },\n    buttonTxt: {\n      fontWeight: 900,\n      color: 'white'\n    },\n  }\n\n  return (\n    <form className=\"contactForm\">\n      <div className=\"form-row\">\n        <div className=\"col-md-6 mb-2\">{render('name')}</div>\n        {/* <div className=\"col-md-4 mb-2\">{render('phone')}</div> */}\n        <div className=\"col-md-6 mb-2\">{render('email')}</div>\n      </div>\n      <div className=\"form-row\">\n        <div className=\"col-md-12 mb-2\">\n          \n<p style={{ textAlign: 'center'}}>By subscribing to Ecotourism Australia’s monthly newsletter, you accept the terms of our <a href=\"/privacy\" target=\"_blank\" rel=\"noopener noreferrer\">Privacy Policy</a></p>\n          <div className=\"actions\">\n            <h4><FormButton onClick={onSubmit} status={post.status} overridingStyle={overridingStyle}>SUBSCRIBE NOW</FormButton></h4>\n            <ErrorMessage errors={form.errors} summaryMessage=\"Please review the errors.\" />\n            <ErrorMessage errors={post.errors} />\n            {post.done() && <span style={{marginLeft: '1.5rem', color:'red', fontWeight: 'bold'}}>Successfully registered!</span>}\n          </div>\n        </div>\n      </div>\n    </form>\n  );\n}","import { fb, validators } from '../../../lib/form';\n\nexport function getModel(data) {\n  const model = fb.group({\n    name: [data.name || '', [validators.Required()], { label: 'Name', type: 'text' }],\n    //phone: [data.phone || '', [validators.Required()], { label: 'Phone', type: 'text' }],\n    email: [data.email || '', [validators.Required(), validators.Email()], { label: 'Email', type: 'email' }],\n  }); \n  return model;\n}","import React from 'react';\nimport cmsUtils from '../cmsUtils';\nimport { Subscribe } from './subscribe';\n\nexport const renderRule = {\n  match: (item, cmsOption) => (cmsUtils.getCodeJson(item) || {})['control'] === 'subscribe', \n  itemElt: (item, cmsOption) => <Subscribe />\n}","import React from 'react';\nimport parse, { domToReact, attributesToProps } from 'html-react-parser';\nimport utils from '../../../../utils';\nimport env from '../../../../env';\n\n//https://github.com/remarkablemark/html-react-parser\n\nconst options = {\n  replace\n};\nlet _embedDataList = []\nlet _cmsOption = {}\n\nexport function renderHtml(html, cmsOption) {\n  _cmsOption = cmsOption\n  if (!cmsOption.isCmsEdit || cmsOption.cmsViewMode === 'viewonly') {\n    _embedDataList = cmsOption?.pageData?.embedDataList;\n    return parse(html || '', options)\n  } else {\n    return parse(html || '', {})\n  }\n}\n\nfunction replace(node) {\n  //console.log(node)\n  if (!env.isProd && node.type === 'tag' && node.name === 'img') {\n    return replaceImg(node)\n  } else if (node.type === 'tag' && node.attribs.class === 'button') {\n    return replaceButton(node)\n  } else if (node.type === 'tag' && node.attribs['data-embed-jaba']) {\n    return replaceEmbedCode(node)\n  }\n\n}\n\nfunction replaceImg(node) {\n  if (node.attribs && node.attribs.src) {\n    const props = attributesToProps(node.attribs)\n    props.src = utils.site.resourcePath(node.attribs.src)\n    // eslint-disable-next-line\n    return <img {...props} />\n  }\n  return null\n}\n\nfunction replaceButton(node) {\n  if (node.children && node.children.some(x => x.name === 'span')) return null;\n  const props = attributesToProps(node.attribs)\n  return React.createElement(node.name, props, <span>{domToReact(node.children, options)}</span>);\n}\n\nfunction replaceEmbedCode(node) {\n  const id = node.attribs['data-embed-jaba'];\n  const found = utils.array.find(_embedDataList, x => x.id === id);\n  if (found) {\n    //console.log(found)\n    return <div className={`codeType_${found.codeType}`}>{renderHtml(found.code, _cmsOption)}</div>\n  }\n  else return null;\n}","import React, { useRef } from 'react';\nimport cmsUtils from '../../cmsUtils';\nimport utils from '../../../../utils';\n\nimport { useRouter } from '../../../../components';\n\nimport { handleElementLink } from '../../../../components';\nimport env from '../../../../env';\nimport { renderHtml } from './renderHtml';\n\n//import { Document, Page } from 'react-pdf'\n//import { Document, Page } from 'react-pdf/dist/entry.webpack';\n\nexport function Html(props) {\n  const ver = env.ver;\n  const item = props.item;\n  //const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n  const { history } = useRouter();\n  //const [ pdfViewPath, setPdfViewPath ] = React.useState(null)\n  //console.log('item', item, cmsOption);\n\n  const year = (new Date()).getFullYear();\n  let content = cmsOption.isCmsEdit ?\n    cmsUtils.payload(item, 'Content') :\n    cmsUtils.payload(item, 'Content')\n      .replace(/__year__/g, year)\n      .replace(\"__version__\", \"<a href = '/app' class = 'app_version'> PWA \" + ver + \"</a>\");\n\n\n  const cssClass = utils.classNames('cms_item', 'htmlPanel', cmsOption.isCmsEdit && 'html', item.cssClass || item.anchorName || '');\n\n  //let itemElt = (<div dangerouslySetInnerHTML={{ __html: content }}></div>);\n\n  function handleClick(e) {\n\n    let target = \"\";\n    if (e.target.closest('a')) {\n      target = e.target.closest('a').getAttribute('target');\n    }\n    const processed = (target === \"_blank\" ? handleElementLink(e.target, null) : handleElementLink(e.target));\n    //const link = utils.url.getLinkFromElement(e.target);\n    //console.log('clicked', e, e.target, processed);\n\n    if (processed.handled) {\n      e.preventDefault();\n      e.stopPropagation();\n    } else if (processed.linkInfo && processed.linkInfo.type === 'internal') {\n      e.preventDefault();\n      e.stopPropagation();\n      history.push(processed.linkInfo.url)\n    } else {\n      //e.preventDefault();\n      //e.stopPropagation();\n      // setPdfViewPath(utils.site.resourcePath(link))\n\n      if (e.target.closest('a')) {\n        let href = e.target.closest('a').getAttribute('href') + \"\";\n        if (href === '#calendly') {\n          \n          const _calendly = window['Calendly'];\n          if(_calendly){\n            window['Calendly'].initPopupWidget({url: 'https://calendly.com/info-40816'});\n          }\n          \n          e.preventDefault();\n          e.stopPropagation();\n        }\n        else if (href.indexOf('#') !== -1) {\n          let _href = href.split('#');\n          console.log(\"_href\", _href);\n          let el = document.querySelector('section[data-cms-item-anchor=\"' + _href[1] + '\"]');\n          if (el) {\n            let anchorStatus = el.getAttribute('data-anchor-status');\n            if (anchorStatus === \"collapse\") {\n              el.setAttribute('data-anchor-status', 'expand');\n              el.classList.add(\"expand\");\n            }\n            else {\n              el.setAttribute('data-anchor-status', 'collapse');\n              el.classList.remove(\"expand\");\n            }\n          }\n          e.preventDefault();\n          e.stopPropagation();\n        }\n\n\n      }\n\n    }\n  }\n\n  const htmlBlock = useRef(null);\n  return (\n    <>\n      <div ref={htmlBlock} className={cssClass} data-cms-html=\"true\"\n        data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n        onClick={(e) => handleClick(e)}>\n        {renderHtml(content, cmsOption)}\n      </div>\n    </>\n  )\n}\n","import React from 'react';\nimport { Html } from './view/html';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'Html', \n  itemElt: (item, cmsOption) => <Html item={item} cmsOption={cmsOption} />\n}","import facepaint from 'facepaint'\n//                  'sm', 'md', 'lg', 'xl', 'xxl'\nconst breakpoints = [576,  768,  992,  1200, 1600, 1900, 2200] \n\nexport const mqBanner = facepaint(\n  breakpoints.map(bp => `@media (min-width: ${bp}px)`)\n)\n\n//                                  576, 768, 992, 1200, 1600, 1900, 2200\nexport const bannerThin =     [180, 190, 200, 220, 250,  270,  290,  300]\nexport const bannerStandard = [350, 350, 400, 450, 500,  550,  600,  700]\n\nexport const getBannerSize = (setName) => {\n  if (setName === 'standard')\n    return bannerStandard\n  else if (setName === 'thin')\n    return bannerThin\n  else\n    return bannerStandard\n}","import { mqBanner, getBannerSize } from 'site/bannerSize/bannerSize';\n\nexport function getImageBannerStyle(heightSet) {\n  const bannerSize = getBannerSize(heightSet);\n\n  return {\n    bannerHeight: mqBanner({\n      height: bannerSize,\n      backgroundPositionX: 'center'\n    }),\n    photoCredit: mqBanner({\n      color: 'white',\n      fontSize: '0.8rem',\n      transform: 'rotate(-90deg) translate(-50%, 10px)',\n      position: 'absolute',\n      top: '50%',\n      left: '0',\n      textAlign: 'center',\n      transformOrigin: 'left top',\n      maxWidth: bannerSize.map(x => x * 0.9),\n      '&:hover, &:active': {\n        color: 'white'\n      }\n    })\n  }\n}","import React from 'react';\nimport { au } from 'components';\n\nexport function useParallax(panelRef, _settings) {\n  const [settings,] = React.useState(getSettings(_settings));\n  const handleScroll = () => {\n    //console.log('useParallax - scrolling')\n    onScroll(settings, panelRef.current);\n  }\n\n  const reset = () => {\n    //console.log('useParallax - reset');\n    setTimeout(() => { onResize(settings, panelRef.current); handleScroll(); }, 300)\n  }\n\n  React.useEffect(() => {\n\n    reset();\n    if (typeof window !== `undefined`) {\n      window.addEventListener('scroll', handleScroll)\n      window.addEventListener('resize', reset)\n    }\n    return () => {\n      if (typeof window !== `undefined`) {\n        window.removeEventListener('scroll', handleScroll)\n        window.removeEventListener('resize', reset)\n      }\n    }\n    // eslint-disable-next-line \n  }, []);\n  return { reset };\n}\n\nfunction getSettings(settings) {\n  const defaultSettings = {\n    cutoffPadding: 10,//px\n    paddingHeightRatio: 1,\n    stretchToFit: true,\n    actionRange: [0.1, 0.9],\n    imageRatio: 1080 / 1920,\n    panelHeight: 'auto',\n    cutTop: 0,\n    cutBottom: 0\n  }\n  return Object.assign({}, defaultSettings, settings);\n}\n\n\nexport function onResize(settings, el) {\n  const screenSize = au.getScreenSize();\n  const autoPanelHeight = !settings.panelHeight || settings.panelHeight === 'auto';\n  const panelHeight = autoPanelHeight ? el.offsetHeight : parseFloat(settings.panelHeight);\n  //console.log(autoPanelHeight, panelHeight)\n\n  let bgHeight = 0, bgWidth = 0;\n  bgHeight = panelHeight * (1 + settings.paddingHeightRatio) + 2 * settings.cutoffPadding;\n  bgWidth = (bgHeight * (1 + settings.cutTop + settings.cutBottom)) / settings.imageRatio;\n  //console.log(panelHeight, settings.paddingHeightRatio, bgHeight, bgWidth)\n  if (settings.stretchToFit && bgWidth < screenSize.width) {\n    // magnifying the background image to fix the full width of the browser\n    bgHeight = screenSize.width * settings.imageRatio;\n    bgWidth = (bgHeight * (1 + settings.cutTop + settings.cutBottom)) / settings.imageRatio;\n    //console.log('magnified', bgHeight, bgWidth, screenSize)\n  }\n  \n  const cutTopPx = bgHeight * (1 + settings.cutTop + settings.cutBottom) * settings.cutTop\n  const cutBottomPx = bgHeight * (1 + settings.cutTop + settings.cutBottom) * settings.cutBottom\n  let fromTop = -settings.cutoffPadding;\n  let toTop = -(bgHeight - panelHeight - settings.cutoffPadding);\n  fromTop += (fromTop - toTop) > cutTopPx ? cutTopPx : 0\n  toTop += (fromTop - toTop) > cutBottomPx ? cutBottomPx : 0\n  //console.log('shift', cutTopPx, cutBottomPx, bgHeight, fromTop, toTop)\n\n  el.setAttribute('data-fromTop', fromTop)\n  el.setAttribute('data-toTop', toTop)\n\n  if (!autoPanelHeight)\n    el.style.height = settings.panelHeight + 'px';\n\n  el.style.backgroundSize = bgWidth + 'px ' + bgHeight + 'px'\n}\n\nexport function onScroll(settings, el) {\n  const pr = au.getScrollProgress(el).progress;\n  //console.log(pr, panel.calculated);\n\n  const min = parseFloat(el.getAttribute('data-fromTop'));\n  const max = parseFloat(el.getAttribute('data-toTop'));\n  const top = au.prVal(min, max, pr, settings.actionRange/*[0, 1]*/);\n  //console.log(min, max, top);\n  el.style.backgroundPositionY = top + 'px'\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport React from 'react';\nimport cmsUtils from '../../cmsUtils';\nimport utils from 'utils';\nimport { SiteLink } from 'components';\nimport { getImageBannerStyle } from './imagePanelStyle';\nimport { useParallax } from 'site/useParallax/useParallax';\n\nexport function ImagePanel(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n  //console.log(cmsOption)\n  //console.log('item', item);\n  const heightSet = cmsUtils.payload(item, 'HeightSet') || 'standard';\n  const photoCredit = cmsUtils.payload(item, 'PhotoCredit');\n  const photoCreditUrl = cmsUtils.payload(item, 'PhotoCreditUrl');\n  const hideTop = cmsUtils.payload(item, 'HideTop') || '0';\n  const hideBottom = cmsUtils.payload(item, 'HideBottom') || '0';\n  \n  const cssClass = utils.classNames('cms_item', 'imagePanel', 'parallax_notused', `bannerSize_notused--${heightSet}`, item.cssClass || item.anchorName || '');\n  \n  const bgUrl = cmsOption.pageOptions && cmsOption.pageOptions.imagePath ?\n    utils.site.resourcePath(cmsOption.pageOptions.imagePath):\n    utils.site.resourcePath(cmsUtils.payload(item, 'ImageUrl'));\n\n  const htmlBlock = React.useRef(null);\n  const cssClass2 = utils.classNames('cms_item', 'htmlPanel', cmsOption.isCmsEdit && 'html', item.cssClass || item.anchorName || '');\n  const content = cmsUtils.payload(item, 'Content');\n\n  const parallaxSetting = {\n    cutoffPadding: 10,//px\n    paddingHeightRatio: 1,\n    stretchToFit: true,\n    actionRange: [0.1, 0.9],\n    imageRatio: 1080 / 1920,\n    panelHeight: 'auto',\n    cutTop: hideTop? parseFloat(hideTop) : 0,\n    cutBottom: hideBottom? parseFloat(hideBottom) : 0\n  }\n  //console.log(parallaxSetting)\n  \n  const panelRef = React.useRef(null);\n  useParallax(panelRef, parallaxSetting);\n\n  const s = getImageBannerStyle(heightSet);\n\n  return (\n    <div className={cssClass} css={s.bannerHeight} ref={panelRef}\n      style={{ backgroundImage: utils.css.bgUrlStyle(bgUrl) }}>\n      <div ref={htmlBlock} className={cssClass2} data-cms-html=\"true\" data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n        dangerouslySetInnerHTML={{ __html: content }}>\n      </div>\n      \n      {(photoCredit && !photoCreditUrl) && <div css={s.photoCredit}>{photoCredit}</div>}\n      {(photoCredit && photoCreditUrl) && <SiteLink to={photoCreditUrl} css={s.photoCredit}>{photoCredit}</SiteLink>}\n    </div>\n  );\n}\n","import React from 'react';\nimport { ImagePanel } from './view/imagePanel';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'ImagePanel', \n  itemElt: (item, cmsOption) => <ImagePanel item={item} cmsOption={cmsOption} />\n}","import { mq } from \"cssInJs\";\n\nexport default {\n  container: mq({\n    //border: '1px solid red',\n    //maxWidth: ['1700px'],\n    maxWidth: [\"100%\"],\n    paddingLeft: \"0px\",\n    paddingRight: \"0px\",\n    \".row\": {\n      marginRight: \"0px\",\n      marginLeft: \"0px\",\n    },\n    \".col__item\": {\n      paddingRight: \"0\",\n      paddingLeft: \"0\",\n      alignSelf: \"center\"\n    },\n    \".col__item.change__flex__order\": mq({\n      order: [\"0\", null, \"unset\"],\n      //order: [\"0\", null, \"unset\"],\n    }),\n    \".col__item.change__flex__order__two\": mq({\n      order: [\"-1\", null, \"unset\"],\n      //order: [\"0\", null, \"unset\"],\n    }),\n    \".bannerSize--standard, .bannerSize, .youtubePlayer\": mq({\n      //height: ['460px']\n      aspectRatio: \"16/9\",\n      height: \"auto\",\n    }),\n\n    \".bannerPanel .slick-slider .slick-track\": {\n      backgroundColor: \"transparent\",\n    },\n  }),\n  html__wrapper: {\n    display: \"flex\",\n    height: \"100%\",\n    justifyContent: \"center\",\n    flexDirection: \"column\",\n  },\n  html__container: mq({\n    //backgroundColor: variables.lightGray,\n    //height: '100%',\n    //flex: '1 0 auto',\n    //position: 'relative',\n    display: \"flex\",\n    flexDirection: \"column\",\n    height: \"100%\",\n    paddingLeft: \"2rem\",\n    paddingRight: \"2rem\",\n    justifyContent: \"center\",\n    maxHeight: [\"100%\", null, \"100%\"],\n    overflow: \"hidden\",\n\n    \"&.top\": { justifyContent: \"flex-start\" },\n    \"&.middle\": {\n      justifyContent: \"center\",\n    },\n    \"&.bottom\": { justifyContent: \"flex-end\" },\n    \"&.left\": {\n      alignItems: \"flex-start\",\n    },\n    \"&.centre\": {\n      alignItems: \"center\",\n    },\n    \"&.right\": {\n      alignItems: \"flex-end\",\n    },\n\n    \"&.check_other_panel_banner, &.check_other_panel_youtube\": mq({\n      marginTop: [\"1rem\", null, \"unset\"],\n      height: [\"100%\", null, \"100%\"],\n    }),\n  }),\n  html__item: {\n    //position: 'absolute',\n    width: \"100%\",\n    margin: \"unset\",\n    \"&.width__short\": {\n      maxWidth: \"250px\",\n    },\n    \"&.width__middle\": {\n      maxWidth: \"400px\",\n    },\n    \"&.width__wild\": {\n      //maxWidth:'100%'\n      maxWidth: \"620px\",\n    },\n  },\n};\n","import React from 'react';\nimport parse, { domToReact, attributesToProps } from 'html-react-parser';\nimport utils from '../../../../utils';\nimport env from '../../../../env';\n\n//https://github.com/remarkablemark/html-react-parser\n\nconst options = {\n  replace\n};\nlet _embedDataList = []\nlet _cmsOption = {}\n\nexport function renderHtml(html, cmsOption) {\n  _cmsOption = cmsOption\n  if (!cmsOption.isCmsEdit || cmsOption.cmsViewMode === 'viewonly') {\n    _embedDataList = cmsOption?.pageData?.embedDataList;\n    return parse(html || '', options)\n  } else {\n    return parse(html || '', {})\n  }\n}\n\nfunction replace(node) {\n  //console.log(node)\n  if (!env.isProd && node.type === 'tag' && node.name === 'img') {\n    return replaceImg(node)\n  } else if (node.type === 'tag' && node.attribs.class === 'button') {\n    return replaceButton(node)\n  } else if (node.type === 'tag' && node.attribs['data-embed-jaba']) {\n    return replaceEmbedCode(node)\n  }\n\n}\n\nfunction replaceImg(node) {\n  if (node.attribs && node.attribs.src) {\n    const props = attributesToProps(node.attribs)\n    props.src = utils.site.resourcePath(node.attribs.src)\n    // eslint-disable-next-line\n    return <img {...props} />\n  }\n  return null\n}\n\nfunction replaceButton(node) {\n  if (node.children && node.children.some(x => x.name === 'span')) return null;\n  const props = attributesToProps(node.attribs)\n  return React.createElement(node.name, props, <span>{domToReact(node.children, options)}</span>);\n}\n\nfunction replaceEmbedCode(node) {\n  const id = node.attribs['data-embed-jaba'];\n  const found = utils.array.find(_embedDataList, x => x.id === id);\n  if (found) {\n    //console.log(found)\n    return <div className={`codeType_${found.codeType}`}>{renderHtml(found.code, _cmsOption)}</div>\n  }\n  else return null;\n}","export default {\n  videoContainer: {\n    position: \"relative\",\n    margin: \"auto\",\n  },\n  videolink: {\n    position: \"absolute\",\n    left: \"50%\",\n    top: \"50%\",\n    transform: \"translate(-50%, -50%)\",\n    zIndex: \"2\",\n  },\n  playIcon: {\n    position: \"absolute\",\n    left: \"50%\",\n    top: \"50%\",\n    transform: \"translate(-50%, -50%)\",\n    zIndex: \"1\",\n    width: \"100px\",\n    height: \"100px\",\n    color: \"white\",\n    cursor: \"pointer\",\n    transition: \"all 0.5s ease-out\",\n    \"&:hover\": {\n      color: \"#0158d7\",\n      transition: \"all 0.5s ease-out\",\n    },\n  },\n  backImgContainer: {\n    position: \"absolute\",\n    left: \"50%\",\n    top: \"50%\",\n    transform: \"translate(-50%, -50%)\",\n    zIndex: \"1\",\n    height: \"100%\",\n  },\n};\n","/** @jsx jsx */\nimport { jsx } from \"@emotion/core\";\nimport style from \"./VideoPanelStyle\";\nimport { MdPlayCircleOutline } from \"react-icons/md\";\n\nexport function VideoPanelNew({ openVideo, videoId, posterFrameUrl }) {\n  return (\n    <section>\n      <div css={style.videoContainer}>\n        <a\n          href={`https://www.youtube.com/embed/${videoId}?autoplay=1&mute=1`}\n          className='youtube-videos'\n          onClick={(e) => {\n            e.preventDefault();\n            openVideo(0);\n          }}\n        >\n          <MdPlayCircleOutline css={style.playIcon} />\n        </a>\n        <img\n          src={\n            \"https://ctfiltration.com.au/sites/ctfiltration/media/gallery/video-thumbnail-images/\" +\n            posterFrameUrl\n          }\n          style={{ width: \"100%\" }}\n          alt='v1'\n        />\n      </div>\n    </section>\n  );\n}\n","/** @jsx jsx */\n// eslint-disable-next-line\nimport React from \"react\";\nimport { jsx } from \"@emotion/core\";\nimport cmsUtils from \"../../cmsUtils\";\nimport utils from \"../../../../utils\";\nimport style from \"./multiColumnPanel2Style\";\nimport { renderHtml } from \"./renderHtml\";\nimport Slider from \"react-slick\";\nimport { handleElementLink, useRouter, SiteLink } from \"../../../../components\";\nimport { useState } from \"react\";\nimport FsLightbox from \"fslightbox-react\";\n// import { YoutubeBannerMobilePopup } from \"../../../../lib/youtube/youtubeBanner--mobilePopup\";\n// import { YoutubeBannerNew } from \"cms/items/youtubeBannerNew/view\";\nimport { VideoPanelNew } from \"cms/items/videoPanelNew/view\";\nimport * as yt from \"./iframeApi\";\n\nexport function MultiColumnPanel(props) {\n  const item = props.item;\n\n  const cmsOption = props.cmsOption || {};\n  const bgColor = cmsUtils.payload(item, \"BgColor\");\n  const bgTheme = cmsUtils.payload(item, \"TextColorTheme\") || \"white\";\n  const cssClass = utils.classNames(\n    \"cms_item\",\n    \"contentPanel\",\n    \"multiColumnPanelv2\",\n    \"contentPanel--\" + bgTheme,\n    item.cssClass || item.anchorName || \"\"\n  );\n  const imageUrl = cmsUtils.payload(item, \"ImageUrl\");\n  const backgroundTile = cmsUtils.payload(item, \"BackgroundTile\");\n\n  const leftPanel = cmsUtils.payload(item, \"LeftPanel\") || \"text\"; //text, banner\n  const leftPanelBanner = cmsUtils.payload(item, \"LeftPanelBanner\") || \"\";\n  const leftTextVertical =\n    cmsUtils.payload(item, \"LeftTextVertical\") || \"middle\"; //top, middle, bottom\n  const leftTextHorizontal =\n    cmsUtils.payload(item, \"LeftTextHorizontal\") || \"centre\"; // left, centre, right\n  const leftTextBgColor =\n    cmsUtils.payload(item, \"LeftTextBgColor\") || \"transparent\";\n  const leftTextWidth = cmsUtils.payload(item, \"LeftTextWidth\") || \"middle\"; //short, middle, wild\n  const leftYoutube = cmsUtils.payload(item, \"LeftYoutube\") || \"\";\n  const leftPosterFrameUrl = cmsUtils.payload(item, \"LeftPosterFrameUrl\") || \"\";\n\n  const rightPanel = cmsUtils.payload(item, \"RightPanel\") || \"text\";\n  const rightPanelBanner = cmsUtils.payload(item, \"RightPanelBanner\") || \"\";\n  const rightTextVertical =\n    cmsUtils.payload(item, \"RightTextVertical\") || \"middle\"; //top, middle, bottom\n  const rightTextHorizontal =\n    cmsUtils.payload(item, \"RightTextHorizontal\") || \"centre\"; // left, centre, right\n  const rightTextBgColor =\n    cmsUtils.payload(item, \"RightTextBgColor\") || \"transparent\"; // left, centre, right\n  const rightTextWidth = cmsUtils.payload(item, \"RightTextWidth\") || \"middle\"; //short, middle, wild\n  const rightYoutube = cmsUtils.payload(item, \"RightYoutube\") || \"\";\n  const rightPosterFrameUrl =\n    cmsUtils.payload(item, \"RightPosterFrameUrl\") || \"\";\n\n  const linkUrl = cmsUtils.payload(item, \"LinkUrl\") || \"\";\n\n  //const mobileReverse = cmsUtils.payload(item, 'MobileReverse', 'no');\n  //const subItems = (mobileReverse === \"yes\" && utils.css.screenWidth() <= 550) ? item.items.reverse() || [] : item.items || [];\n  //const columnWidths = cmsUtils.payload(item, 'ColumnWidths').split(\",\");\n  //const mobileColumnWidths = cmsUtils.payload(item, 'MobileColumnWidths').split(\",\");\n  //const countItem = { countD: 0, countM: 0, col: \"\" };\n\n  let content = cmsUtils.payload(item, \"Content\") || \"Please add text\";\n  let content2 = cmsUtils.payload(item, \"Content2\") || \"Please add text\";\n\n  let bgUrl = null;\n  if (imageUrl) bgUrl = utils.site.resourcePath(imageUrl);\n  else if (backgroundTile)\n    bgUrl = utils.site.resourcePath(\n      `/dist/transparent-textures/textures/${backgroundTile}`\n    );\n\n  let idFirstUse = 1;\n  if (leftPanel !== \"text\") {\n    idFirstUse = 2;\n  }\n\n  return (\n    <section\n      className={cssClass}\n      style={{\n        backgroundColor: `${bgColor}`,\n        backgroundImage: bgUrl && utils.css.bgUrlStyle(bgUrl),\n      }}\n      id={item.anchorName}\n    >\n      <div className='contentPanel__bg'></div>\n      <div className='container' css={style.container}>\n        <div className='row'>\n          <div\n            className={`col-12 \n            ${\n              leftPanel === \"text\" && rightPanel === \"text\"\n                ? \"col-md-6\"\n                : leftPanel === \"banner\" || leftPanel === \"youtube\"\n                ? \"col-md-7\"\n                : \"col-md-5\"\n            }\n            col__item ${\n              (leftPanel === \"text\" && rightPanel === \"banner\") ||\n              (leftPanel === \"text\" && rightPanel === \"youtube\")\n                ? \"change__flex__order\"\n                : \"no__change__flex__order\"\n            }`}\n          >\n            <GetItem\n              itemName={leftPanel}\n              content={content}\n              cmsOption={cmsOption}\n              itemId={item.itemId}\n              bannerItems={leftPanelBanner}\n              index='01'\n              checkOtherPanel={rightPanel}\n              textVertical={leftTextVertical}\n              textHorizontal={leftTextHorizontal}\n              textBgColor={leftTextBgColor}\n              textWidth={leftTextWidth}\n              idFirstUse={idFirstUse === 1 ? true : false}\n              linkUrl={linkUrl}\n              youtubeCode={leftYoutube}\n              posterFrameUrl={leftPosterFrameUrl}\n            />\n          </div>\n          <div\n            className={`col-12 \n            ${\n              leftPanel === \"text\" && rightPanel === \"text\"\n                ? \"col-md-6\"\n                : rightPanel === \"banner\" || rightPanel === \"youtube\"\n                ? \"col-md-7\"\n                : \"col-md-5\"\n            }\n            col__item ${\n              (rightPanel === \"text\" && leftPanel === \"banner\") ||\n              (rightPanel === \"text\" && leftPanel === \"youtube\")\n                ? \"change__flex__order__two\"\n                : \"no__change__flex__order\"\n            }`}\n          >\n            <GetItem\n              itemName={rightPanel}\n              content={content2}\n              cmsOption={cmsOption}\n              itemId={item.itemId}\n              bannerItems={rightPanelBanner}\n              index='02'\n              checkOtherPanel={leftPanel}\n              textVertical={rightTextVertical}\n              textHorizontal={rightTextHorizontal}\n              textBgColor={rightTextBgColor}\n              textWidth={rightTextWidth}\n              idFirstUse={idFirstUse === 2 ? true : false}\n              linkUrl={linkUrl}\n              youtubeCode={rightYoutube}\n              posterFrameUrl={rightPosterFrameUrl}\n            />\n          </div>\n        </div>\n      </div>\n    </section>\n  );\n}\n\nfunction GetItem({\n  itemName,\n  index,\n  content,\n  cmsOption,\n  itemId,\n  bannerItems,\n  checkOtherPanel,\n  textVertical,\n  textHorizontal,\n  idFirstUse,\n  textBgColor,\n  textWidth,\n  linkUrl,\n  youtubeCode,\n  posterFrameUrl,\n}) {\n  const { history } = useRouter();\n  const settings = {\n    dots: false,\n    infinite: true,\n    speed: 1500,\n    autoplaySpeed: 3000,\n    fade: true,\n    autoplay: false,\n    slidesToShow: 1,\n    slidesToScroll: 1,\n  };\n  // eslint-disable-next-line\n  const canPlayVideo = () => {\n    return false;\n  };\n  const video = {\n    heightSet: \"standard\",\n    videoLinkOrId: youtubeCode,\n    posterFrameUrl: posterFrameUrl,\n    playerId: \"ytBanner-\" + itemId.substr(0, 8) + \"-\" + index,\n  };\n\n  const [toggler, setToggler] = useState(false);\n  const [popupIndex, setPopupIndex] = useState(0);\n  function openVideo(index) {\n    setPopupIndex(index);\n    setToggler(!toggler);\n  }\n  const playerVars = {\n    enablejsapi: 1,\n    autoplay: 1,\n    controls: 1,\n    loop: 1,\n    showinfo: 0,\n    rel: 0,\n    modestbranding: 1,\n    allowfullscreen: true,\n    wmode: \"transparent\",\n  };\n  const { videoLinkOrId, playerId } = video;\n  const videoId = yt.getYoutubeCode(videoLinkOrId);\n  const popupImages = [\n    <iframe\n      className='youtubePlayer__iframe'\n      id={playerId}\n      width='1600px'\n      height='900px'\n      title='Youtube video'\n      src={`https://www.youtube.com/embed/${videoId}?autoplay=1&mute=1&${utils.url.toQueryString(\n        playerVars\n      )}`}\n      allow='fullscreen'\n      frameBorder='0'\n    ></iframe>,\n  ];\n\n  const _imgs = (bannerItems === \"\" ? \"logo.png\" : bannerItems).split(\"|\");\n  //https://jaba.com.au/sites/newjaba/media/banners/ocean1_269430438.jpg\n\n  function handleClick(e) {\n    let target = \"\";\n    if (e.target.closest(\"a\")) {\n      target = e.target.closest(\"a\").getAttribute(\"target\");\n    }\n    const processed =\n      target === \"_blank\"\n        ? handleElementLink(e.target, null)\n        : handleElementLink(e.target);\n    //const link = utils.url.getLinkFromElement(e.target);\n    //console.log('clicked', e, e.target, processed);\n\n    if (processed.handled) {\n      e.preventDefault();\n      e.stopPropagation();\n    } else if (processed.linkInfo && processed.linkInfo.type === \"internal\") {\n      e.preventDefault();\n      e.stopPropagation();\n      history.push(processed.linkInfo.url);\n    } else {\n      if (e.target.closest(\"a\")) {\n        let href = e.target.closest(\"a\").getAttribute(\"href\") + \"\";\n        if (href.indexOf(\"#\") !== -1) {\n          let _href = href.split(\"#\");\n          console.log(\"_href\", _href);\n          let el = document.querySelector(\n            'section[data-cms-item-anchor=\"' + _href[1] + '\"]'\n          );\n          if (el) {\n            let anchorStatus = el.getAttribute(\"data-anchor-status\");\n            if (anchorStatus === \"collapse\") {\n              el.setAttribute(\"data-anchor-status\", \"expand\");\n              el.classList.add(\"expand\");\n            } else {\n              el.setAttribute(\"data-anchor-status\", \"collapse\");\n              el.classList.remove(\"expand\");\n            }\n          }\n          e.preventDefault();\n          e.stopPropagation();\n        }\n      }\n    }\n  }\n\n  if (itemName === \"text\") {\n    return (\n      <div css={style.html__wrapper}>\n        <div\n          css={style.html__container}\n          className={`check_other_panel_${checkOtherPanel} ${textVertical} ${textHorizontal}`}\n          style={{ backgroundColor: textBgColor }}\n        >\n          <div\n            data-cms-html='true'\n            css={style.html__item}\n            data-cms-item-id={\n              cmsOption.isCmsEdit &&\n              (idFirstUse === true ? itemId : itemId + \"_\" + index)\n            }\n            data-cms-item-id2={cmsOption.isCmsEdit && itemId}\n            className={`cms_item htmlPanel html new__multicolumn__panel__html item__${index} ${\n              \"width__\" + textWidth\n            }`}\n            onClick={(e) => handleClick(e)}\n          >\n            {renderHtml(content, cmsOption)}\n          </div>\n        </div>\n      </div>\n    );\n  } else if (itemName === \"youtube\") {\n    return (\n      <>\n        <FsLightbox\n          toggler={toggler}\n          sources={popupImages}\n          sourceIndex={popupIndex}\n        />\n        <div\n          className='youtubePanel yp-multiColumnPanel2'\n          style={{ position: \"relative\", overflow: \"hidden\" }}\n        >\n          {/* <YoutubeBannerMobilePopup video={video} canPlayVideo={canPlayVideo} /> */}\n          {/* <YoutubeBannerNew video={video} canPlayVideo={canPlayVideo} /> */}\n          <VideoPanelNew\n            openVideo={openVideo}\n            videoId={videoId}\n            posterFrameUrl={posterFrameUrl}\n          />\n        </div>\n      </>\n    );\n  } else if (itemName === \"banner\") {\n    return (\n      <div className='cms_item bannerPanel bannerWrapperSize--standard'>\n        <Slider {...settings}>\n          {_imgs.map((item, index) => {\n            return <ImgItem key={index} item={item} linkUrl={linkUrl} />;\n          })}\n        </Slider>\n      </div>\n    );\n  }\n\n  return <div>No Item</div>;\n}\n\nfunction ImgItem({ item, linkUrl }) {\n  if (linkUrl && linkUrl !== \"\") {\n    return (\n      <SiteLink to={linkUrl}>\n        <div\n          className='cms_item banner-item bannerSize'\n          style={{ backgroundImage: utils.css.bgUrlStyle(item) }}\n        ></div>\n      </SiteLink>\n    );\n  }\n\n  return (\n    <div\n      className='cms_item banner-item bannerSize'\n      style={{ backgroundImage: utils.css.bgUrlStyle(item) }}\n    ></div>\n  );\n}\n\n//\"https://jaba.com.au/sites/newjaba/media/banners/ocean1_269430438.jpg\"\n","import utils from \"utils\";\n\nexport function loadApi(onApiReady) {\n  if (typeof window !== `undefined` && !window.YT) {\n    // If not, load the script asynchronously\n    const tag = document.createElement(\"script\");\n    tag.src = \"https://www.youtube.com/iframe_api\";\n    tag.id = \"youtubeIframeApJaba\";\n\n    // onYouTubeIframeAPIReady will load the video after the script is loaded\n    window.onYouTubeIframeAPIReady = () => onApiReady(true);\n\n    const firstScriptTag = document.getElementsByTagName(\"script\")[0];\n    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n  } else {\n    // If script is already there, load the video directly\n    onApiReady(false);\n  }\n}\n\n// export function player(playerId, videoId, playerVars = {}, events = {}) {\n//   //let player = null;\n//   const defaultPlayerVars = {\n//     'autoplay': 1,\n//     'controls': 0,\n//     'loop': 1,\n//     'showinfo': 0,\n//     'rel': 0,\n//     'modestbranding': 1,\n//     'origin': window.location.origin,\n//     'allowfullscreen': true,\n//     'wmode': 'transparent'\n//   }\n//   const defaultEvents = {\n//     'onStateChange': (e) => { },\n//     'onReady': (e) => { console.log('onReady'); player.mute() },\n//     'onError': (e) => { console.log(e) }\n//   }\n\n//   const player = new window.YT.Player(playerId, {\n//     videoId: videoId,\n//     playerVars: Object.assign({}, defaultPlayerVars, playerVars),\n//     events: Object.assign({}, defaultEvents, events),\n//   });\n//   return player;\n// }\n\nexport function thumbnailMax(videoId) {\n  return `https://img.youtube.com/vi/${videoId}/maxresdefault.jpg`;\n}\n\n// onPlayerStateChange(event){\n//   switch (event.data){\n//     case window['YT'].PlayerState.PLAYING:\n//       //console.log('Playing');\n//       //this.player.mute();\n//       break;\n//     case window['YT'].PlayerState.PAUSED:\n//       //console.log('Pafdsu');\n//       break;\n//     case window['YT'].PlayerState.ENDED:\n//       //console.log('ended ');\n//       //this.player.playVideo();\n//       this.player.stopVideo();\n//       break;\n//   }\n// }\n\n// toggleBannerYoutueInCMS(toggleItem:string){\n//   if(toggleItem == 'youtube'){\n//     //location.reload();\n//     this.toggleBannerOrYoutube = toggleItem;\n//     this.player.playVideo();\n//     this.init();\n//   }\n//   else{\n//     this.toggleBannerOrYoutube = toggleItem;\n//     this.player.stopVideo();\n//   }\n// }\n\nexport function getYoutubeCode(src) {\n  // if (src.indexOf('http') >= 0) {\n  //   if (src.indexOf('v=') >= 0) {\n  //     return src.split('v=')[1];\n  //   }\n  // }\n  // return src;\n  return utils.url.getYoutubeId(src);\n}\n","import React from 'react';\nimport { MultiColumnPanel } from './view/multiColumnPanel2';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'MultiColumnPanel2', \n  itemElt: (item, cmsOption) => <MultiColumnPanel item={item} cmsOption={cmsOption} />\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport Slider from \"react-slick\";\nimport { settings as defaultSettings} from './config';\n\n/**\n * Tile List\n * @param {Array<JSX.Element>} tiles React elements, required\n * @param {Object} style Style object, required\n * @param {string} cssClass\n * @param {string} useSlider Use SlickSlider, default: false\n * @param {Object} settings Tile Settings, required\n * @param {...Object} attrs Other attributes in the list level\n */\nexport function TileList({tiles, style, overridingStyle, cssClass, useSlider = false, settings = defaultSettings, ...attrs}) {\n  const s = style || {};\n  const ss = overridingStyle || {};\n  const slickSettings = settings.slickSettings;\n\n  useSlider = useSlider && tiles.length > 1\n  slickSettings.infinite = tiles.length > 2\n\n  if (useSlider) {\n    return (\n      <div className={cssClass} css={[s.holder, ss.holder]} {...attrs}>\n        <div css={[s.tiles, ss.tiles, useSlider && s.tilesSlider, useSlider && ss.tilesSlider]}>\n          <Slider {...slickSettings} >\n            {tiles}\n          </Slider>\n        </div>\n      </div>\n    );\n  } else {\n    return (\n      <div className={cssClass} css={[s.holder, ss.holder]} {...attrs}>\n        <div css={[s.tiles, ss.tiles]}>\n          {tiles}\n        </div>\n      </div>\n    );\n  }\n\n}","import { variables, mq } from '../../cssInJs';\nimport { settings as defaultSettings} from './config';\n/**\n * Tile List Style. This is only for list wrapper, not tile itself\n * @param {Object} settings Tile Settings, required\n */\nexport function getTileListStyle(settings = defaultSettings) {\n  const marginLR = settings.marginLR;\n  const marginTB = settings.marginTB;\n  return {\n    holder: mq({\n      //maxWidth: 1000,\n      margin: 'auto',\n      marginTop: [30, null, 40],\n      marginBottom: [30, null, 40],\n      '.slick-prev, .slick-next': {\n        top: [100],\n        transform: 'translate(0, 0)',\n      },\n      '.slick-prev': {\n        left: [10, null, -20]\n      },\n      '.slick-next': {\n        right: [10, null, -20]\n      },\n      '.slick-prev:before, .slick-next:before': {\n        color: variables.fontColor\n      }\n    }),\n    tiles: mq({\n      display: 'flex',\n      justifyContent: 'flex-start',\n      alignItems: 'stretch',\n      flexWrap: 'wrap',\n      marginLeft: marginLR.map(x => x === null? null : -x / 2),\n      marginRight: marginLR.map(x => x === null? null : -x / 2),\n      marginTop: marginTB.map(x => x === null? null : x / 2),\n      marginBottom: marginTB.map(x => x === null? null : x / 2),\n    }),\n    tilesSlider: mq({\n      display: 'block',\n      marginLeft: [15, null, 15],\n      marginRight: [15, null, 15],\n    })\n  }\n}\n\n","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport utils from 'utils';\nimport { SiteLink } from 'components';\nimport { getTileStyle } from './pageTileStyle';\n\nexport function PageTile({ page, useSlider, disableLink }) {\n  const tileLink = page.pageUrl;\n  const imageUrl = utils.site.resourcePath(page.imageUrl);\n  const title = page.pageTitle;\n  const desc = page.tileDesc || page.description;\n  const s = getTileStyle();\n  return (\n    <SiteLink to={tileLink} css={[s.tile, useSlider && s.tileSlider]} >\n      <div className=\"tileBg\" css={s.tileBg} style={{ backgroundImage: utils.css.bgUrlStyle(imageUrl) }}></div>\n      <div className=\"tileContent\" css={s.tileContent}>\n        <div css={s.title}>{title}</div>\n        <div css={s.desc}>{desc}</div>\n      </div>\n    </SiteLink>\n  )\n}\n","import { variables, mq } from 'cssInJs';\nimport { settings as defaultSettings } from 'site/tileList/config';\n\nimport { rgba } from 'polished';\n\nexport function getTileStyle(settings = defaultSettings) {\n  const numOfTilesPerBreakpoints = settings.numOfTilesPerBreakpoints\n  const marginLR = settings.marginLR\n  const marginTB = settings.marginTB\n\n  return {\n    tile: mq({\n      paddingLeft: marginLR.map(x => x === null ? null : x / 2),\n      paddingRight: marginLR.map(x => x === null ? null : x / 2),\n      paddingTop: marginTB.map(x => x === null ? null : x / 2),\n      paddingBottom: marginTB.map(x => x === null ? null : x / 2),\n      maxWidth: numOfTilesPerBreakpoints.map(x => x === null ? null : 100 / x + '%'),\n      flexBasis: numOfTilesPerBreakpoints.map(x => x === null ? null : 100 / x + '%'),\n      flexGrow: 0,\n      flexShrink: 0,\n      textAlign: 'left',\n      display: 'flex',\n      flexDirection: 'column',\n      color: 'inherit',\n      ':hover': {\n        textDecoration: 'none',\n        color: 'inherit',\n        '.tileBg': {\n          transform: 'scale(1.02)',\n          transition: 'all .2s ease-in-out'\n        },\n        '.tileContent': {\n          backgroundColor: rgba(variables.primaryColor, 0.3),\n        }\n      }\n    }),\n    tileSlider: mq({\n      maxWidth: '100% !important'\n    }),\n    tileBg: mq({\n      backgroundColor: 'white',\n      backgroundPosition: 'center',\n      backgroundRepeat: 'no-repeat',\n      backgroundSize: 'cover',\n      height: 0,\n      paddingBottom: '56.25%',\n    }),\n    tileContent: mq({\n      display: 'flex',\n      flexDirection: 'column',\n      flexGrow: 1,\n      lineHeight: 1.3,\n      //boxShadow: '4px 4px 14px 4px rgba(190,190,190,0.5)',\n      backgroundColor: '#fff',\n      marginTop: [10],\n      padding: [20],\n      transition: 'all .2s ease-in-out'\n    }),\n    title: mq({\n      //fontFamily: variables.familyHeader,\n      fontSize: '1.3rem',\n      textTransform: 'uppercase',\n      lineHeight: 1.3,\n      fontWeight: 900,\n      textAlign: 'center',\n    }),\n    desc: mq({\n      marginTop: 5,\n      fontSize: '0.9rem',\n      display: '-webkit-box',\n      WebkitLineClamp: '9',\n      WebkitBoxOrient: 'vertical',\n      overflow: 'hidden',\n    }),\n  }\n}\n\nexport function getTileListOverridingStyle() {\n  return {\n    tiles: mq({\n      alignItems: 'flex-start',\n    })\n  }\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport cmsUtils from '../../cmsUtils';\nimport { TileList } from 'site/tileList/tileList'\nimport { getTileListStyle } from 'site/tileList/tileListStyle';\n\nimport { PageTile } from './pageTile/pageTile'\n\nexport function PageTiles(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n  //console.log(cmsOption)\n  //console.log('item', item);\n  const useSlider = cmsUtils.payload(item, 'UseSlider') === 'slider';\n  const pages = getPages(cmsUtils.payload(item, 'PageObjects'))\n\n  const tiles = pages.map((page, index) => <PageTile key={index} page={page} useSlider={useSlider} disableLink={cmsOption.isCmsEdit} />)\n  \n  return (\n    <TileList tiles={tiles} style={getTileListStyle()} useSlider={useSlider} />\n  );\n}\n\nfunction getPages(pagesSerialized) {\n  if (pagesSerialized) {\n    return JSON.parse(pagesSerialized);\n  }\n  return [];\n}","import React from 'react';\nimport { PageTiles } from './view/pageTiles';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'PageTiles__', \n  itemElt: (item, cmsOption) => <PageTiles item={item} cmsOption={cmsOption} />\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport cmsUtils from '../../cmsUtils';\nimport { Item } from '../../../../cms/items/item';\nimport utils from '../../../../utils';\n\nexport function Panel(props) {\n  const item = props.item;\n  const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, subItems);\n  //console.log(cmsUtils.hasItemInPageDataByItemTypeCode(cmsOption.pageData, 'DestinationOperators'))\n\n  const bgColor = cmsUtils.payload(item, 'BgColor');\n  const waveColor = cmsUtils.payload(item, 'BgColor');\n  const wave = cmsUtils.payload(item, 'Wave') || 'none';\n  //const textColorTheme = cmsUtils.payload(item, 'TextColorTheme');\n  const imageUrl = cmsUtils.payload(item, 'ImageUrl');\n  const backgroundTile = cmsUtils.payload(item, 'BackgroundTile');\n  const bgTheme = cmsUtils.payload(item, 'TextColorTheme') || 'white';\n  //console.log(bgTheme)\n\n  let bgUrl = null;\n  if (imageUrl)\n    bgUrl = utils.site.resourcePath(imageUrl);\n  else if (backgroundTile)\n    bgUrl = utils.site.resourcePath(`/dist/transparent-textures/textures/${backgroundTile}`);\n\n  const cssClass = utils.classNames('cms_item', 'contentPanel', 'contentPanel--' + bgTheme, item.cssClass || item.anchorName || '');\n\n  const subItemsElts = subItems.map((subItem, index) =>\n    <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  );\n\n  return (\n    <section className={cssClass} style={{\n      backgroundColor: `${bgColor}`,\n      backgroundImage: bgUrl && utils.css.bgUrlStyle(bgUrl)\n    }} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      <div className=\"contentPanel__bg\"></div>\n      \n      {\n        (wave === 'top' || wave === 'both') &&\n        <div className=\"wave-animation-top\" style={{color:waveColor}}>\n          <svg width=\"1440px\" height=\"25px\" viewBox=\"0 0 1440 25\" preserveAspectRatio=\"none\"><g data-svg-origin=\"0 0\" ><path fill=\"currentColor\" d=\"M 0 12.5 q 360 -25 720 0 t 720 0 t 720 0 t 720 0 t 720 0 t 720 0 V 25 H 0 V 0\"></path></g></svg>\n        </div>\n      }\n\n      <div className=\"container\">{subItemsElts}</div>\n\n      {\n        (wave === 'bottom' || wave === 'both') &&\n        <div className=\"wave-animation-bottom\" style={{color:waveColor}}>\n          <svg width=\"1440px\" height=\"25px\" viewBox=\"0 0 1440 25\" preserveAspectRatio=\"none\"><g data-svg-origin=\"0 0\" ><path fill=\"currentColor\" d=\"M 0 12.5 q 360 -25 720 0 t 720 0 t 720 0 t 720 0 t 720 0 t 720 0 V 0 H 0 V 12.5\"></path></g></svg>\n        </div>\n      }\n\n    </section>\n  );\n}\n","import React from 'react';\nimport { Panel } from './view/panel';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'Panel', \n  itemElt: (item, cmsOption) => <Panel item={item} cmsOption={cmsOption} />\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport utils from '../../utils';\nimport { SiteLink } from '../../components';\n\nimport { TileList } from '../tileList/tileList'\nimport { getTileListStyle } from '../tileList/tileListStyle';\nimport { settings } from './config';\n\nimport { getImageTileStyle } from './galleryStyle';\n\nexport function GalleryTiles({ images, openPopupImage, useSlider = false }) {\n  if (images.length === 0) return null;\n  const tiles = images.map((img, index) => <ImageTile key={index} image={img} useSlider={useSlider} openPopupImage={openPopupImage} />)\n  return <TileList tiles={tiles} style={getTileListStyle(settings)} useSlider={useSlider} />\n}\n\nfunction ImageTile({ image, useSlider, disableLink, openPopupImage }) {\n  const s = getImageTileStyle(settings);\n  //const imageUrl = utils.site.resourcePath(image.imageUrl);\n  const thumbnailUrl = image.thumbnailUrl || image.imageUrl;\n  const tileLink = image.imageUrl;\n\n  return <SiteLink css={[s.tile, useSlider && s.tileSlider]} to={disableLink ? '' : tileLink} onClick={(e) => openPopupImage(e, image)}>\n    <div css={s.tileBg} className=\"tileBg\" style={{ backgroundImage: utils.css.bgUrlStyle(thumbnailUrl) }}></div>\n  </SiteLink>\n}\n","import { mq } from '../../cssInJs';\nimport { settings as defaultSettings} from '../tileList/config';\n\nexport function getImageTileStyle(settings = defaultSettings) {\n  const numOfTilesPerBreakpoints = settings.numOfTilesPerBreakpoints\n  const marginLR = settings.marginLR\n  const marginTB = settings.marginTB\n\n  return {\n    tile: mq({\n      paddingLeft: marginLR.map(x => x === null? null : x / 2),\n      paddingRight: marginLR.map(x => x === null? null : x / 2),\n      paddingTop: marginTB.map(x => x === null? null : x / 2),\n      paddingBottom: marginTB.map(x => x === null? null : x / 2),\n      maxWidth: numOfTilesPerBreakpoints.map(x => x === null? null : 100 / x + '%'),\n      flexBasis: numOfTilesPerBreakpoints.map(x => x === null? null : 100 / x + '%'),\n      flexGrow: 0,\n      flexShrink: 0,\n      textAlign: 'left',\n      display: 'flex',\n      flexDirection: 'column',\n      color: 'inherit',\n      ':hover': {\n        textDecoration: 'none',\n        color: 'inherit',\n        '.tileBg': {\n          transform: 'scale(1.02)',\n          transition: 'all .2s ease-in-out'\n        }\n      }\n    }),\n    tileSlider: mq({\n      maxWidth: '100% !important'\n    }),\n    tileBg: mq({\n      backgroundColor: 'white',\n      backgroundPosition: 'center',\n      backgroundRepeat: 'no-repeat',\n      backgroundSize: 'cover',\n      height: 0,\n      paddingBottom: '100%',//'56.25%',\n    }),\n  }\n}\n\n","import React from 'react';\nimport { createPortal } from \"react-dom\";\n\nexport function Portal({children}){\n  const [el] = React.useState(document.createElement('div'));\n  React.useEffect(() => {\n      let mount = document.getElementById(\"portal-root\");\n      mount.appendChild(el);\n    return () => mount.removeChild(el);\n  }, [el]);\n  return createPortal(children, el);\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport React from 'react';\nimport utils from 'utils';\nimport { GalleryTiles } from './galleryTiles';\n\nimport { Portal } from \"site/portal/portal\";\nimport FsLightbox from 'fslightbox-react';\n\nconst r = utils.site.resourcePath\nconst set = utils.media.getImageSetPath\n\nexport function Gallery({ images, useSlider = false }) {\n\n  const [toggler, setToggler] = React.useState(false);\n  const [popupIndex, setPopupIndex] = React.useState(0);\n\n  const filtered = utils.array.distinct(images, (x, y) => x.imageUrl === y.imageUrl)\n  if (filtered.length === 0) return null;\n\n  const popupImages = filtered.map(x => r(x.imageUrl));\n  const galleryImages = filtered.map(x => ({ imageUrl: r(x.imageUrl), thumbnailUrl: r(set(x.imageUrl, 'thumb')), caption: x.caption }));\n  // console.log(popupImages)\n\n  function openPopupImage(e, image) {\n    e.stopPropagation(); e.preventDefault();\n    const imageUrl = r(image.imageUrl);\n    const inx = utils.array.findIndex(popupImages, x => x === imageUrl);\n    setPopupIndex(inx >= 0 ? inx : 0)\n    setToggler(!toggler)\n  }\n\n  return <React.Fragment>\n    <Portal>\n      <FsLightbox\n        toggler={toggler}\n        sources={popupImages}\n        sourceIndex={popupIndex}\n      />\n    </Portal>\n    <GalleryTiles images={galleryImages} openPopupImage={openPopupImage} useSlider={useSlider} />\n  </React.Fragment>\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport cmsUtils from '../../cmsUtils';\nimport utils from 'utils'\nimport { Gallery } from '@site/gallery/gallery'\n\nexport function PhotoGallery(props) {\n  const item = props.item;\n  //const cmsOption = props.cmsOption || {};\n  //console.log(cmsOption)\n  //console.log('item', item);\n\n  const cssClass = utils.classNames('cms_item', 'photoGallery', item.cssClass || item.anchorName || '');\n  const images = cmsUtils.payload(item, 'ImageUrl') ? cmsUtils.payload(item, 'ImageUrl').split(\"|\") : [];\n  const galleryImages = images.map(x => ({imageUrl: x, thumbnailUrl: x, caption: null}));\n  \n  return (\n    <Gallery cssClass={cssClass} images={galleryImages} useSlider={false} />\n  );\n}\n","import React from 'react';\nimport { PhotoGallery } from './view/photoGallery';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'PhotoGallery', \n  itemElt: (item, cmsOption) => <PhotoGallery item={item} cmsOption={cmsOption} />\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport { FacebookShareButton, FacebookIcon } from \"react-share\";\n// import { LinkedinShareButton, LinkedinIcon } from \"react-share\";\n// import { TwitterShareButton, TwitterIcon } from \"react-share\";\nimport { WhatsappShareButton, WhatsappIcon } from \"react-share\";\nimport { EmailShareButton, EmailIcon } from \"react-share\";\n\nimport { getShareButtonStyle } from './shareButtonStyle';\n\nexport function ShareButtons({ shareUrl, pageTitle = null, topLabel = 'SHARE THIS PAGE:' }) {\n  const s = getShareButtonStyle();\n  const title = pageTitle || window.document.title;\n  console.log(title)\n  return <div css={s.shareButtons}>\n    {topLabel && <div css={s.shareButtonTitle}>{topLabel}</div>}\n    <span title=\"Sharing with Facebook\">\n      <FacebookShareButton css={s.shareButton} url={shareUrl}>\n        <FacebookIcon size={50} round={true} />\n      </FacebookShareButton>\n    </span>\n    {/* <span title=\"Sharing with LinkedIn\">\n      <LinkedinShareButton css={s.shareButton} url={shareUrl} title={title}>\n        <LinkedinIcon size={50} round={true} />\n      </LinkedinShareButton>\n    </span> */}\n    {/* <span title=\"Sharing with Twitter\">\n      <TwitterShareButton css={s.shareButton} url={shareUrl} title={title}>\n        <TwitterIcon size={50} round={true} />\n      </TwitterShareButton>\n    </span> */}\n    <span title=\"Sharing with Whatsapp\">\n      <WhatsappShareButton css={s.shareButton} url={shareUrl} title={title}>\n        <WhatsappIcon size={50} round={true} />\n      </WhatsappShareButton>\n    </span>\n    <span title=\"Sharing with Email\">\n      <EmailShareButton css={s.shareButton} url={shareUrl} subject={title}>\n        <EmailIcon size={50} round={true} />\n      </EmailShareButton>\n    </span>\n  </div>\n}\n","//import { mq } from '../../cssInJs';\n\nexport function getShareButtonStyle() {\n  return {\n    shareButtons: {\n      marginTop: '1.5rem',\n    },\n    shareButtonTitle: {\n      fontSize: '0.8rem',\n      marginLeft: '0.5rem',\n      marginBottom: '0.3rem'\n    },\n    shareButton: {\n      margin: 5\n    },\n  }\n} \n","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\n// import cmsUtils from '../../cmsUtils';\nimport utils from 'utils'\nimport { ShareButtons } from 'site/shareButtons/shareButtons'\n\nexport function SharingIcons(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n  //console.log(cmsOption)\n  //console.log('item', item);\n\n  const cssClass = utils.classNames('cms_item', item.cssClass || item.anchorName || '');\n  const shareUrl = utils.site.fullUrl(window.location.pathname + window.location.search)\n\n  return <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n    <ShareButtons shareUrl={shareUrl} />\n  </div>\n}\n","import React from 'react';\nimport { SharingIcons } from './view/sharingIcons';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'SharingIcons', \n  itemElt: (item, cmsOption) => <SharingIcons item={item} cmsOption={cmsOption} />\n}","export default {\n    sketchfab__item : {\n        '.sketchfab-embed-wrapper' : {\n            paddingTop: '56.25%',\n            position: 'relative',\n            overflow : 'hidden',\n            'iframe' : {\n                width: '100%',\n                height: '100%',\n                position: 'absolute',\n                top: '0px',\n                left: '0px'\n            }\n        }\n    }   \n}","/** @jsx jsx */\nimport { jsx } from \"@emotion/core\";\nimport style from \"./sketchfabItemStyle\";\nimport utils from \"utils\";\nimport cmsUtils from \"../../cmsUtils\";\n\nexport function SketchfabItem(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n  const cssClass = utils.classNames(\n    \"cms_item\",\n    \"sketchfab__item\",\n    item.cssClass || item.anchorName || \"\"\n  );\n  const code = cmsUtils.payload(item, \"Code\") || \"\";\n\n  if (!code || code === \"\") {\n    return (\n      <div\n        className={cssClass}\n        data-cms-item-id={cmsOption.isCmsEdit && item.itemId}\n        id={item.anchorName}\n      >\n        <pre\n          style={{\n            fontSize: \"12px\",\n            margin: \"5px\",\n            padding: \"10px\",\n            background: \"#eee\",\n            border: \"1px solid #ccc\",\n          }}\n        >\n          <b> Please add code </b>\n          {code}\n        </pre>\n      </div>\n    );\n  }\n\n  return (\n    <div\n      className={cssClass}\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId}\n      id={item.anchorName}\n      dangerouslySetInnerHTML={{ __html: code }}\n      css = {style.sketchfab__item}\n    >\n    </div>\n  );\n}","import React, { useState, useRef } from \"react\";\nimport utils from \"../../../utils\";\nimport { debounce } from \"../../../lib/utils-core/debounce\";\nimport * as yt from \"../../../lib/youtube/iframeApi\";\nimport { FiVolumeX, FiVolume2 } from \"react-icons/fi\";\n\nexport function YoutubeNew(props) {\n  const youtubeBannerRef = React.useRef(null);\n  const [playerStatus, setPlayerStatus] = useState(\"loading\");\n  const [playerSize, setPlayerSize] = useState(null);\n  // eslint-disable-next-line\n  const [ytPlayer, setYtPlayer] = useState(null);\n  const [muted, setMuted] = useState(true);\n  // eslint-disable-next-line\n  const countPlayedRef = useRef(0);\n  const { heightSet, videoLinkOrId, playerId } = props.video;\n  const videoId = yt.getYoutubeCode(videoLinkOrId);\n  const posterImageUrl =\n    props.posterImageUrl && props.posterImageUrl !== \"\"\n      ? props.posterImageUrl\n      : yt.thumbnailMax(videoId);\n  const mobileImageUrl = props.mobileImageUrl;\n  const canPlayVideo = () =>\n    typeof window !== `undefined` && typeof props.canPlayVideo === `undefined`\n      ? window.innerWidth >= 0\n      : !!(typeof props.canPlayVideo === \"function\"\n          ? props.canPlayVideo()\n          : props.canPlayVideo);\n\n  const playerVars = {\n    enablejsapi: 1,\n    //'autoplay': 1,\n    controls: 0,\n    loop: 1,\n    showinfo: 0,\n    rel: 0,\n    modestbranding: 1,\n    //'origin': typeof window !== `undefined` && window.location.origin,\n    allowfullscreen: true,\n    wmode: \"transparent\",\n  };\n\n  React.useEffect(() => {\n    const resized = debounce(() => {\n      loadVideo();\n    });\n    loadVideo();\n    if (typeof window !== `undefined`)\n      window.addEventListener(\"resize\", resized);\n    return () => {\n      if (typeof window !== `undefined`)\n        window.removeEventListener(\"resize\", resized);\n    };\n    // eslint-disable-next-line\n  }, []);\n\n  function loadVideo() {\n    if (youtubeBannerRef.current)\n      setPlayerSize(getSize(youtubeBannerRef.current, props.sizeCalculator));\n    if (canPlayVideo()) {\n      const existingScript = document.getElementById(\"youtubeIframeApJaba\");\n\n      if (existingScript) {\n        if (window.YT) {\n          setTimeout(init, 100);\n        } else {\n          let checkInterTime = 0;\n          const checkYoutubeIframeApJabaScript = setInterval(() => {\n            console.log(\"checkYoutubeIframeApJabaScript\", checkInterTime);\n            if (window.YT) {\n              setTimeout(init, 100);\n              clearInterval(checkYoutubeIframeApJabaScript);\n            }\n\n            if (checkInterTime >= 10) {\n              clearInterval(checkYoutubeIframeApJabaScript);\n            }\n            checkInterTime++;\n          }, 100);\n        }\n      } else {\n        yt.loadApi((loadJs) => {\n          loadJs ? init() : setTimeout(init, 100);\n        });\n      }\n\n      // yt.loadApi((loadJs) => {\n      //   loadJs ? init() : setTimeout(init, 100);\n      // });\n    }\n  }\n\n  function init() {\n    let player = null;\n    if (typeof window !== `undefined`) {\n      player = new window.YT.Player(playerId, {\n        events: {\n          onStateChange: (e) => {\n            switch (e.data) {\n              case window.YT.PlayerState.ENDED:\n                // const countPlayed = countPlayedRef.current;\n                // if (countPlayed < 3 - 1) {\n                //   console.log(\"ended\", countPlayed + 1);\n                //   countPlayedRef.current = countPlayed + 1;\n                //   if (player && player.playVideo) {\n                //     player.playVideo();\n                //   } else {\n                //     setPlayerStatus(\"finished\");\n                //   }\n                // } else {\n                //   setPlayerStatus(\"finished\");\n                // }\n\n                if (player && player.playVideo) {\n                  player.playVideo();\n                }\n\n                break;\n              default:\n            }\n          },\n          onReady: (e) => {\n            if (player && player.mute && player.playVideo) {\n              player.mute();\n              player.playVideo();\n            }\n            setTimeout(() => setPlayerStatus(\"loaded\"), 1000);\n          },\n          onError: (e) => {\n            console.log(e);\n          },\n        },\n      });\n      setYtPlayer(player);\n    }\n  }\n\n  function soundToggle(e) {\n    e.preventDefault();\n    e.stopPropagation();\n    if (ytPlayer) {\n      if (muted) {\n        setMuted(false);\n        setTimeout(() => {\n          if (\n            ytPlayer &&\n            ytPlayer.pauseVideo &&\n            ytPlayer.unMute &&\n            ytPlayer.playVideo\n          ) {\n            ytPlayer.pauseVideo();\n            ytPlayer.unMute();\n            ytPlayer.playVideo();\n          }\n        }, 100);\n      } else {\n        setMuted(true);\n        setTimeout(() => {\n          if (\n            ytPlayer &&\n            ytPlayer.pauseVideo &&\n            ytPlayer.unMute &&\n            ytPlayer.playVideo\n          ) {\n            ytPlayer.pauseVideo();\n            ytPlayer.mute();\n            ytPlayer.playVideo();\n          }\n        }, 100);\n      }\n    }\n    //https://developers.google.com/web/updates/2017/09/autoplay-policy-changes\n  }\n\n  function getSize(container, sizeCalculator) {\n    const containerSize = container\n      ? { w: container.offsetWidth, h: container.offsetHeight }\n      : { w: window.innerWidth, h: window.innerHeight };\n    if (sizeCalculator) {\n      const size = sizeCalculator(containerSize, canPlayVideo());\n      if (size) return size;\n    }\n\n    const overSize = 1;\n    const rate = 9 / 16;\n    const w = containerSize.w * overSize;\n    const h = containerSize.h * overSize;\n    const size = { width: w, height: w * rate, left: 0, top: 0 };\n    if (size.height < h) {\n      // stretch horizontally\n      size.height = h;\n      size.width = h / rate;\n    }\n    //console.log(size)\n    size.left = -(size.width - containerSize.w) / 2;\n    size.top = -(size.height - containerSize.h) / 2;\n    return size;\n  }\n  const canPlay = canPlayVideo();\n  const imageUrl = !canPlay && mobileImageUrl ? mobileImageUrl : posterImageUrl;\n  return (\n    <React.Fragment>\n      <div\n        className={utils.classNames(\n          \"youtubePlayer\",\n          \"youtubePlayerNew\",\n          `youtubePlayer--${canPlay ? \"canPlay\" : \"cannotPlay\"}`,\n          `youtubePlayer--${playerStatus}`,\n          `youtubePlayer--${heightSet}`\n        )}\n        ref={youtubeBannerRef}\n      >\n        <div className='bg_dark_linear'></div>\n        <div className='youtubePlayer__mask'></div>\n        <div\n          className='youtubePlayer__poster'\n          style={{ backgroundImage: utils.css.bgUrlStyle(imageUrl) }}\n        ></div>\n        {playerSize && (\n          <iframe\n            className='youtubePlayer__iframe'\n            id={playerId}\n            width='640'\n            height='390'\n            title='Youtube video'\n            style={{\n              width: `${playerSize.width}px`,\n              height: `${playerSize.height}px`,\n              top: `${playerSize.top}px`,\n              left: `${playerSize.left}px`,\n            }}\n            src={`https://www.youtube.com/embed/${videoId}?autoplay=1&mute=1&${utils.url.toQueryString(\n              playerVars\n            )}`}\n            allow='autoplay; fullscreen'\n            frameBorder='0'\n          ></iframe>\n        )}\n        {canPlay && playerStatus === \"loaded\" && (\n          <div\n            className='youtubePlayer__soundIcon'\n            title={muted ? \"Sound On\" : \"Sound Off\"}\n            onClick={soundToggle}\n          >\n            {muted ? <FiVolume2 /> : <FiVolumeX />}\n          </div>\n        )}\n      </div>\n    </React.Fragment>\n  );\n}\n","import React from \"react\";\nimport cmsUtils from \"../../cmsUtils\";\nimport utils from \"../../../../utils\";\nimport { YoutubeNew } from \"cms/items/youtubeNew/view\";\n\nexport function VideoPanel(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  const heightSet = cmsUtils.payload(item, \"HeightSet\") || \"standard\";\n  const videoCode = cmsUtils.payload(item, \"YoutubeCode\");\n  const posterFrameUrl = cmsUtils.payload(item, \"PosterFrameUrl\", null);\n  const playerId = \"ytBanner-\" + item.itemId.substr(0, 8);\n\n  const video = {\n    heightSet: heightSet,\n    videoLinkOrId: videoCode,\n    playerId: playerId,\n  };\n\n  const canPlayVideo = () => utils.css.screenWidth() >= 0;\n\n  const cssClass = utils.classNames(\n    \"cms_item\",\n    \"youtubePanel\",\n    item.cssClass || item.anchorName || \"\"\n  );\n\n  return (\n    <div\n      className={cssClass}\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId}\n      id={item.anchorName}\n      style={{ position: \"relative\", overflow: \"hidden\" }}\n    >\n      <YoutubeNew\n        video={video}\n        canPlayVideo={canPlayVideo}\n        posterImageUrl={utils.site.resourcePath(posterFrameUrl)}\n      />\n    </div>\n  );\n}\n","function payload(item, key, defaultVal = '') {\n  const found = item.payloads.find(x => x.key === key);\n  return found ? found.value : defaultVal;\n}\n\nexport default { payload };","import React, { useLayoutEffect, useRef } from 'react';\nimport ReactDOM from 'react-dom';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\n\nimport { useRouter } from '../../../components';\n\nimport { handleElementLink } from '../../../components';\nimport env from '../../../env';\n\n//import { Document, Page } from 'react-pdf'\n//import { Document, Page } from 'react-pdf/dist/entry.webpack';\n\nexport function Html(props) {\n  const ver = env.ver;\n  const item = props.item;\n  //const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n  const { history } = useRouter();\n  //const [ pdfViewPath, setPdfViewPath ] = React.useState(null)\n  //console.log('item', item, cmsOption);\n\n  const year = (new Date()).getFullYear();\n  let content = cmsOption.isCmsEdit? \n    cmsUtils.payload(item, 'Content'): \n    cmsUtils.payload(item, 'Content')\n      .replace(/__year__/g, year)\n      .replace(\"__version__\", \"<a href = '/app' class = 'app_version'> PWA \"+ ver +\"</a>\");\n\n\n  const cssClass = utils.classNames('cms_item', 'htmlPanel', cmsOption.isCmsEdit && 'html', item.cssClass || item.anchorName || '');\n\n  //let itemElt = (<div dangerouslySetInnerHTML={{ __html: content }}></div>);\n\n  function handleClick(e) {\n    \n    let target = \"\";\n    if(e.target.closest('a')){\n      target = e.target.closest('a').getAttribute('target');\n    }\n    const processed = (target === \"_blank\" ? handleElementLink(e.target, null) : handleElementLink(e.target));\n    //const link = utils.url.getLinkFromElement(e.target);\n    //console.log('clicked', e, e.target, processed);\n    \n    if (processed.handled) {\n      e.preventDefault();\n      e.stopPropagation();\n    } else if (processed.linkInfo && processed.linkInfo.type === 'internal') {\n      e.preventDefault();\n      e.stopPropagation();\n      history.push(processed.linkInfo.url)\n    } else {\n      //e.preventDefault();\n      //e.stopPropagation();\n      // setPdfViewPath(utils.site.resourcePath(link))\n\n      if(e.target.closest('a')){\n        let href = e.target.closest('a').getAttribute('href') + \"\";\n          if(href.indexOf('#') !== -1){\n          let _href = href.split('#');\n          console.log(\"_href\", _href);\n          let el = document.querySelector('section[data-cms-item-anchor=\"' + _href[1] + '\"]');\n          let anchorStatus = el.getAttribute('data-anchor-status');\n          if(anchorStatus === \"collapse\"){\n            el.setAttribute('data-anchor-status', 'expand');\n            el.classList.add(\"expand\");\n          }\n          else{\n            el.setAttribute('data-anchor-status', 'collapse');\n            el.classList.remove(\"expand\");\n          }\n          e.preventDefault();\n          e.stopPropagation(); \n        }\n      }\n\n    }\n  }\n  //console.log(pdfViewPath)\n  const pdfView = \n    // pdfViewPath ? \n    // <Document file={pdfViewPath}><Page pageIndex={1}/></Document> : \n    null;\n\n  const htmlBlock = useRef(null);\n  // function iframeSizer() {\n  //   //console.log('iframesizer')\n  //   let iframesContainer = htmlBlock.current.querySelectorAll('iframe.youtube, .ytvideo iframe');\n  //   //console.log('iframesizer', iframesContainer)\n  //   if (iframesContainer && iframesContainer.length) {\n  //     iframesContainer.forEach(element => {\n  //       let height = (element.parentElement.offsetWidth * 9) / 16\n  //       //console.log(height, element.parentElement.offsetWidth)\n  //       element.style.height = height + 'px';\n  //     });\n  //   }\n  // }\n\n\n  useLayoutEffect(() => {\n    //console.log(cmsOption.isCmsEdit)\n    if (!cmsOption.isCmsEdit || cmsOption.cmsViewMode === 'viewonly') {\n      replaceEmbedCodes(htmlBlock.current, cmsOption);\n    }\n      \n    const buttons = htmlBlock.current.querySelectorAll('.button');\n    for (let i = 0; buttons && i < buttons.length; i++) {\n      restructureButton(buttons[i])\n    }\n\n    // iframeSizer();\n    // window.addEventListener('resize', iframeSizer)\n    // return (): void => {\n    //   window.removeEventListener('resize', iframeSizer)\n    // }\n\n  }, [cmsOption])\n\n  return (\n    <>\n    <div ref={htmlBlock} className={cssClass} data-cms-html=\"true\"\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n      dangerouslySetInnerHTML={{ __html: content }} onClick={(e) => handleClick(e)}></div>\n    {pdfView}\n    </>\n  )\n}\n\n\nfunction restructureButton(el) {\n  if (!el.querySelector('span')) {\n    const span = document.createElement('span');\n    span.innerHTML = el.innerHTML;\n    el.innerHTML = '';\n    el.appendChild(span);\n  }\n}\n\n\nfunction replaceEmbedCodes(block, cmsOption) {\n  const embedDataList = cmsOption?.pageData?.embedDataList;\n  const embedCodes = block.querySelectorAll('[data-embed-jaba]')\n  embedCodes.forEach(embed => {\n    const id = embed.getAttribute(\"data-embed-jaba\");\n    const found = utils.array.find(embedDataList, x => x.id === id);\n    if (found){\n      //console.log(found)\n      ReactDOM.render(<div className={`codeType_${found.codeType}`} dangerouslySetInnerHTML={{ __html: found.code }}></div>, embed);\n    }\n  })\n  //console.log(embedCodes, embedDataList)\n}\n\n","import React from \"react\";\nimport cmsUtils from \"../../cmsUtils\";\nimport utils from \"../../../../utils\";\nimport { YoutubeNew } from \"cms/items/youtubeNew/view\";\nimport { Html } from \"cms/items/html/view\";\n\nexport function VideoPanelWithText(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  const heightSet = cmsUtils.payload(item, \"HeightSet\") || \"standard\";\n  const videoCode = cmsUtils.payload(item, \"YoutubeCode\");\n  const posterFrameUrl = cmsUtils.payload(item, \"PosterFrameUrl\", null);\n  const playerId = \"ytBanner-\" + item.itemId.substr(0, 8);\n\n  const video = {\n    heightSet: heightSet,\n    videoLinkOrId: videoCode,\n    playerId: playerId,\n  };\n\n  const canPlayVideo = () => utils.css.screenWidth() >= 0;\n\n  const cssClass = utils.classNames(\n    \"cms_item\",\n    \"videoPanelWithText\",\n    item.cssClass || item.anchorName || \"\"\n  );\n\n  return (\n    <div\n      className={cssClass}\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId}\n      id={item.anchorName}\n      style={{ position: \"relative\", overflow: \"hidden\" }}\n    >\n      <div className='container'>\n        <div className='video_panel_container'>\n          <YoutubeNew\n            video={video}\n            canPlayVideo={canPlayVideo}\n            posterImageUrl={utils.site.resourcePath(posterFrameUrl)}\n          />\n          <Html item={item} cmsOption={cmsOption} />\n        </div>\n      </div>\n    </div>\n  );\n}\n","import React from \"react\";\nimport { VideoPanelWithText } from \"./view/VideoPanelWithText\";\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === \"VideoPanelWithText\",\n  itemElt: (item, cmsOption) => (\n    <VideoPanelWithText item={item} cmsOption={cmsOption} />\n  ),\n};\n","\nimport { renderRule as code_instagram } from './code-instagram/render';\nimport { renderRule as code_subscribe } from './code-subscribe/render';\nimport { renderRule as html } from './html/render';\nimport { renderRule as imagePanel } from './imagePanel/render';\nimport { renderRule as multiColumnPanel2 } from './multiColumnPanel2/render';\nimport { renderRule as pageTiles } from './pageTiles/render';\nimport { renderRule as panel } from './panel/render';\nimport { renderRule as photoGallery } from './photoGallery/render';\nimport { renderRule as sharingIcons } from './sharingIcons/render';\nimport { renderRule as sketchfabItem } from './sketchfabItem/render';\nimport { renderRule as videoPanel } from './videoPanel/render';\nimport { renderRule as videoPanelWithText } from './videoPanelWithText/render';\nexport const items = [\n  code_instagram,\n  code_subscribe,\n  html,\n  imagePanel,\n  multiColumnPanel2,\n  pageTiles,\n  panel,\n  photoGallery,\n  sharingIcons,\n  sketchfabItem,\n  videoPanel,\n  videoPanelWithText,\n]","import React from 'react';\nimport {SketchfabItem } from './view/sketchfabItem';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'SketchfabItem', \n  itemElt: (item, cmsOption) => <SketchfabItem item={item} cmsOption={cmsOption} />\n}","import React from 'react';\nimport { VideoPanel } from './view/videoPanel';\n\nexport const renderRule = {\n  match: (item, cmsOption) => item.itemTypeCode === 'VideoPanel', \n  itemElt: (item, cmsOption) => <VideoPanel item={item} cmsOption={cmsOption} />\n}","import React from 'react';\nimport { Item } from '../../items/item';\nimport cmsUtils from '../../utils/cmsUtils';\nimport  utils from '../../../utils';\nimport Slider from \"react-slick\";\n\nexport function BannerPanel(props) {\n  const item = props.item;\n  const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, subItems);\n\n  const heightSet = cmsUtils.payload(item, 'HeightSet') || 'standard';\n\n  const slides = subItems.map((subItem, index) =>\n    <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  );\n\n  var settings = {\n    dots: false,\n    infinite: true,\n    speed: 1500,\n    autoplaySpeed: 3000,\n    fade: true,\n    autoplay: true,\n    slidesToShow: 1,\n    slidesToScroll: 1\n  };\n\n  const cssClass = utils.classNames('cms_item', 'bannerPanel', `bannerWrapperSize--${heightSet}`, item.cssClass || item.anchorName || '');\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      <Slider {...settings} >\n        {slides}\n      </Slider>\n    </div>\n  );\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { SiteLink } from '../../../components';\n\nexport function BannerItem(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item);\n\n  const bgUrl = utils.site.resourcePath(cmsUtils.payload(item, 'ImageUrl'));\n\n  const captionTitle = cmsUtils.payload(item, 'CaptionTitle2') || cmsUtils.payload(item, 'CaptionTitle');\n  const captionButton = cmsUtils.payload(item, 'CaptionButton') && cmsUtils.payload(item, 'CaptionButton') !== \"\" ? cmsUtils.payload(item, 'CaptionButton') : \"READ MORE\";\n  \n  const linkUrl = cmsUtils.payload(item, 'LinkUrl2') || cmsUtils.payload(item, 'LinkUrl');\n\n  const titlePanel = captionTitle ? (\n    linkUrl ? (<div>\n      <div className=\"banner-item__title\" dangerouslySetInnerHTML={{ __html: captionTitle }}></div>\n      <SiteLink to={linkUrl} className=\"banner-item__link\"> { captionButton } </SiteLink>\n    </div>\n    ) : (<div className=\"banner-item__title\" dangerouslySetInnerHTML={{ __html: captionTitle }}></div>)\n  ) : null;\n\n  const linkOverlay = linkUrl && !captionTitle ? (\n    <SiteLink className=\"bannerItem__overlay\" to={linkUrl}></SiteLink>\n  ) : null;\n\n  const cssClass = utils.classNames('cms_item', 'banner-item', 'bannerSize', item.cssClass || item.anchorName || '', titlePanel && 'bannerHasTitlePanel');\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n      style={{ backgroundImage: utils.css.bgUrlStyle(bgUrl) }}>\n      {titlePanel && <div className=\"banner_item__text\">{titlePanel}</div>}\n      {linkOverlay && linkOverlay}\n    </div>\n  );\n\n\n}\n","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport { Item } from '../../items/item';\nimport  utils from '../../../utils';\n\nexport function Panel(props) {\n  const item = props.item;\n  const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, subItems);\n  \n  const bgColor = cmsUtils.payload(item, 'BgColor');\n  //const textColorTheme = cmsUtils.payload(item, 'TextColorTheme');\n  const imageUrl = cmsUtils.payload(item, 'ImageUrl');\n  const backgroundTile = cmsUtils.payload(item, 'BackgroundTile');\n  const bgTheme = cmsUtils.payload(item, 'TextColorTheme') || 'white';\n  //console.log(bgTheme)\n\n\n  let bgUrl = null;\n  if (imageUrl)\n    bgUrl = utils.site.resourcePath(imageUrl);\n  else if (backgroundTile)\n    bgUrl = utils.site.resourcePath(`/dist/transparent-textures/textures/${backgroundTile}`);\n\n  const cssClass = utils.classNames('cms_item', 'contentPanel', 'contentPanel--' + bgTheme, item.cssClass || item.anchorName || '');\n\n  const subItemsElts = subItems.map((subItem, index) =>\n    <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  );\n\n  return (\n    <section className={cssClass} style={{\n      backgroundColor: `${bgColor}`,\n      backgroundImage: bgUrl && utils.css.bgUrlStyle(bgUrl)\n      }} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      <div className=\"contentPanel__bg\"></div>\n      <div className=\"container\">\n        {subItemsElts}\n      </div>\n    </section>\n  );\n}\n","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\n\nexport function ImagePanel(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n  //console.log(cmsOption)\n  //console.log('item', item);\n  const heightSet = cmsUtils.payload(item, 'HeightSet') || 'standard';\n  \n  const cssClass = utils.classNames('cms_item', 'imagePanel', 'parallax', `bannerSize--${heightSet}`, item.cssClass || item.anchorName || '');\n  \n  const bgUrl = cmsOption.pageOptions && cmsOption.pageOptions.imagePath ?\n    utils.site.resourcePath(cmsOption.pageOptions.imagePath):\n    utils.site.resourcePath(cmsUtils.payload(item, 'ImageUrl'));\n\n  const htmlBlock = React.useRef(null);\n  const cssClass2 = utils.classNames('cms_item', 'htmlPanel', cmsOption.isCmsEdit && 'html', item.cssClass || item.anchorName || '');\n  const content = cmsUtils.payload(item, 'Content');\n\n  return (\n    <div className={cssClass} data-pxh={heightSet}\n      style={{ backgroundImage: utils.css.bgUrlStyle(bgUrl) }}>\n      <div ref={htmlBlock} className={cssClass2} data-cms-html=\"true\" data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n        dangerouslySetInnerHTML={{ __html: content }}>\n      </div>\n    </div>\n  );\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { SiteLink } from '../../../components';\n\nimport Slider from \"react-slick\";\n\nexport function PageTiles(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item);\n  const useSlider = cmsUtils.payload(item, 'UseSlider') === 'slider';\n  const pages = getPages(cmsUtils.payload(item, 'PageObjects'))\n  //console.log(pages);\n  const pageTileElts = pages.map((page, index) =>\n    <Tile page={page} key={index} disableLink={cmsOption.isCmsEdit}></Tile>\n  );\n\n  var settings = {\n    dots: false,\n    infinite: true,\n    speed: 500,\n    autoplaySpeed: 3000,\n    fade: false,\n    autoplay: true,\n    slidesToShow: 3,\n    slidesToScroll: 1,\n    responsive: [\n      {\n        breakpoint: 992,\n        settings: {\n          slidesToShow: 2,\n          slidesToScroll: 1\n        }\n      },\n      {\n        breakpoint: 576,\n        settings: {\n          slidesToShow: 1,\n          slidesToScroll: 1\n        }\n      }\n      // You can unslick at a given breakpoint now by adding:\n      // settings: \"unslick\"\n      // instead of a settings object\n    ]\n  };\n\n  const cssClass = utils.classNames('cms_item', 'pageTiles tiles', useSlider && 'useSlider', item.cssClass || item.anchorName || '');\n\n  if (useSlider){\n    return (\n      <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n        <Slider {...settings} >\n          {pageTileElts}\n        </Slider>\n      </div>\n    );\n  } else {\n    return (\n      <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n        {pageTileElts}\n      </div>\n    );   \n  }\n}\n\nfunction getPages(pagesSerialized) {\n  if (pagesSerialized) {\n    return JSON.parse(pagesSerialized);\n  }\n  return [];\n}\n\nfunction Tile(props) {\n  const page = props.page;\n  const imageUrl = utils.site.resourcePath(page.imageUrl);\n  const disableLink = props.disableLink;\n  return (\n    <div className=\"pageTile tile\">\n      <SiteLink className=\"pageTile__content tile__content\" to={disableLink ? '' : page.pageUrl}>\n        <div className=\"tile__bg\" style={{ backgroundImage: utils.css.bgUrlStyle(imageUrl) }}></div>\n        <div className=\"pageTile_details tile__details\">\n          <div className=\"pageTile__title\">\n            {page.pageTitle}\n          </div>\n          <div className=\"pageTile_desc\">\n            {page.tileDesc || page.description}\n          </div>\n        </div>\n      </SiteLink>\n    </div>\n  )\n}","//import { css, keyframes  } from '@emotion/core'\n//import { variables, mq } from 'cssInJs'\n\nimport { css } from \"@emotion/core\";\nimport { mq, variables } from \"../../../cssInJs\";\n\nexport default {\n  pageTiles: css({\n    display: \"flex\",\n    justifyContent: \"flex-start\",\n    flexWrap: \"wrap\",\n    margin: \"2rem 0\",\n    overflow: \"hidden\",\n  }),\n  pageTile__tile: css(\n    mq({\n      flex: \"0 0 100%\",\n      maxWidth: \"100%\",\n      padding: \"10px\",\n      zIndex: 1,\n      \"&:nth-of-type(even)\": {\n        \".pageTile__bsyc__bg\": mq({\n          order: [\"0\", null, \"2\"],\n        }),\n        \".pageTile__bsyc__content__details\": mq({\n          order: \"1\",\n        }),\n      },\n    })\n  ),\n\n  tile__content: css({\n    //     display: 'flex',\n    //     flexDirection: 'row',\n    //     justifyContent: 'space-between',\n    //     width: '100%',\n    //     height: '100%',\n    //     cursor: 'pointer',\n    //     position: 'relative',\n    //     flexWrap: 'wrap',\n    \"&:hover\": {\n      textDecoration: \"none\",\n      \"& .pageTile__bsyc__content__details\": {\n        //color: 'white',\n        backgroundColor: variables.blueColor,\n        // '&.default' : css({\n        //      backgroundColor: 'rgba(0,113,188,1)'\n        // }),\n        // '&.red' : css({\n        //      backgroundColor: 'rgba(211,61,2,1)'\n        // }),\n        // '&.green' : css({\n        //      backgroundColor: 'rgba(0, 146, 69,1)'\n        // })\n        \"& .pageTile__bsyc__title\": {\n          color: \"white\",\n        },\n        \"& .pageTile__bsyc__desc\": {\n          color: \"white\",\n        },\n      },\n      \"& .pageTile__bsyc__bg2\": {\n        //transform: scale(1.05)\n        transform: \"scale(1.05)\",\n      },\n    },\n  }),\n\n  tile__flip__wrapper: css({\n    zIndex: \"-1\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    justifyContent: \"space-between\",\n    width: \"100%\",\n    height: \"100%\",\n    cursor: \"pointer\",\n    position: \"relative\",\n    flexWrap: \"wrap\",\n  }),\n\n  //     tile__bg : css(mq({\n  //          height: '0',\n  //          //paddingTop: '30%',\n  //          paddingTop: ['50%','35%','30%'],\n  //          backgroundPosition: '50%',\n  //          backgroundRepeat: 'no-repeat',\n  //          backgroundSize: 'cover',\n  //          flex: '1 1 300px'\n  //     })),\n\n  tile__bg: css(\n    mq({\n      height: \"0\",\n      paddingTop: [\"50%\", \"35%\", \"30%\"],\n      //height: ['50%','35%','30%'],\n      flex: \"1 1 300px\",\n      overflow: \"hidden\",\n      position: \"relative\",\n      boxShadow: \"3px 5px 10px rgba(0,0,0,0.3)\",\n    })\n  ),\n\n  tile__bg2: css(\n    mq({\n      height: \"100%\",\n      backgroundPosition: \"50%\",\n      backgroundRepeat: \"no-repeat\",\n      backgroundSize: \"cover\",\n      //overflow:'hidden',\n      transition: \"all .2s\",\n      position: \"absolute\",\n      top: \"0px\",\n      width: \"100%\",\n    })\n  ),\n\n  tile__details: css({\n    overflow: \"hidden\",\n    flexGrow: \"1\",\n    textAlign: \"center\",\n    width: \"100%\",\n    bottom: \"0\",\n    backgroundColor: \"white\",\n    //     '&.default' : css({\n    //           backgroundColor: 'rgba(0, 113, 188,.5)'\n    //     }),\n    //     '&.red' : css({\n    //           backgroundColor: 'rgba(211, 61, 2,.5)'\n    //      }),\n    //      '&.green' : css({\n    //           backgroundColor: 'rgba(0, 146, 69,.5)'\n    //      }),\n    //backgroundColor : '#77cf22',\n    flex: \"1 1 300px\",\n    transition: \"all .2s ease-in-out\",\n    color: \"#ebebeb\",\n    position: \"relative\",\n    boxShadow: \"3px 5px 10px rgba(0,0,0,0.3)\",\n    \"& .pageTile__bsyc__container\": mq({\n      //position: 'absolute',\n      position: [\"static,\", null, \"absolute\"],\n      top: \"50%\",\n      left: \"50%\",\n      transform: [\"none\", null, \"translate(-50%, -50%)\"],\n      width: [\"100%\", null, \"90%\"],\n      padding: [\"1rem\", null, \"0px\"],\n      \"& .pageTile__bsyc__title\": {\n        //fontFamily: 'proxima-soft, sans-serif',\n        fontSize: \"2rem\",\n        //textTransform: 'uppercase',\n        //fontWeight: '700',\n        lineHeight: \"1\",\n        margin: \"0\",\n        paddingTop: \".5rem\",\n        paddingBottom: \".5rem\",\n        color: variables.blueColor,\n        //fontWeight: 700\n      },\n      \"& .pageTile__bsyc__desc\": {\n        lineHeight: \"1.3\",\n        fontSize: \".9rem\",\n        //color: '#3d3d3d',\n        minHeight: \"70px\",\n        color: \"black\",\n      },\n    }),\n  }),\n};\n","//import React from 'react';\nimport cmsUtils from '../../../cms/utils/cmsUtils';\nimport utils from '../../../utils';\nimport { SiteLink } from '../../../components';\n\n/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport style from './style';\n\nexport function PageTilesBsyc(props) {\n  const item = props.item;\n  //const detailHoverBgColor = props.detailHoverBgColor ? props.detailHoverBgColor : \"black\";\n  const cmsOption = props.cmsOption || {};\n  const pages = getPages(cmsUtils.payload(item, 'PageObjects'))\n  const pageTileElts = pages.map((page, index) =>\n    <Tile page={page} key={index} disableLink={cmsOption.isCmsEdit} idx = {index}></Tile>\n  );\n\n  //const cssClass = utils.classNames('cms_item', 'pageTiles tiles', item.cssClass || item.anchorName || '');\n  const cssClass = utils.classNames('cms_item', 'pageTiles__bsyc', item.cssClass || item.anchorName || '');\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n     css = {style.pageTiles}>\n      {pageTileElts}\n    </div>\n  );\n}\n\nfunction getPages(pagesSerialized) {\n  if (pagesSerialized) {\n    return JSON.parse(pagesSerialized);\n  }\n  return [];\n}\n\nfunction Tile(props) {\n  const page = props.page;\n  const imageUrl = utils.site.resourcePath(page.imageUrl);\n  const disableLink = props.disableLink;\n  const colorTheme = page.colorTheme;\n  const index = props.idx;\n  return (\n    \n    <div css = {style.pageTile__tile} className=\"pageTile__bsyc\">\n      <SiteLink className=\"pageTile__bsyc__content\" css = {style.tile__content} to={disableLink ? '' : page.pageUrl}>\n      <div css={style.tile__flip__wrapper}>\n\n        <div className=\"pageTile__bsyc__bg\" data-aos={index % 2 === 0 ? 'fade-up-right' : 'fade-up-left'} css = {style.tile__bg}>\n          <div className=\"pageTile__bsyc__bg2\" css = {style.tile__bg2} style={{ backgroundImage: utils.css.bgUrlStyle(imageUrl) }}></div>\n        </div>\n        \n        <div css = {style.tile__details} className={`pageTile__bsyc__content__details ${colorTheme}`} data-aos={index % 2 === 0 ? 'fade-up-left' : 'fade-up-right'}>  \n          <div className=\"pageTile__bsyc__container\">\n            \n            {\n              (page.pageTitle && page.pageTitle !== '') &&\n              <div className=\"pageTile__bsyc__title\">\n                {page.pageTitle}\n              </div>\n            }\n\n            <div className=\"pageTile__bsyc__desc\">\n              {page.tileDesc || page.description}\n            </div>\n          </div>\n        </div>\n        </div>\n      </SiteLink>\n    </div>\n  )\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport  utils from '../../../utils';\nimport { SiteLink } from '../../../components';\n\nexport function SingleBanner(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item);\n  const heightSet = cmsUtils.payload(item, 'HeightSet') || 'standard';\n  const alignV = cmsUtils.payload(item, 'AlignV') || '50%';\n\n  const cssClass = utils.classNames('cms_item', 'single-banner', 'banner-item', `bannerSize--${heightSet}`, item.cssClass || item.anchorName || '');\n  const bgUrl = utils.site.resourcePath(cmsUtils.payload(item, 'ImageUrl'));\n\n  const captionTitle = cmsUtils.payload(item, 'CaptionTitle2') || cmsUtils.payload(item, 'CaptionTitle');\n  const linkUrl = cmsUtils.payload(item, 'LinkUrl2') || cmsUtils.payload(item, 'LinkUrl');\n\n  const titlePanel = captionTitle ? (\n    linkUrl ? (<SiteLink to={linkUrl} className=\"banner-item__link\">\n      <div className=\"banner-item__title\" dangerouslySetInnerHTML={{ __html: captionTitle }}></div>\n    </SiteLink>) : (<div className=\"banner-item__title\" dangerouslySetInnerHTML={{ __html: captionTitle }}></div>)\n  ) : null;\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n      style={{ backgroundImage: utils.css.bgUrlStyle(bgUrl), backgroundPositionY:alignV }}>\n      {titlePanel && <div className=\"banner_item__text\">{titlePanel}</div>}\n    </div>\n  );\n\n\n}\n","import React from \"react\";\nimport env from \"../../../env\";\nimport { usePost } from \"../../../components\";\nimport { useForm } from \"../../../form\";\nimport { Button, ErrorMessage } from \"../../../components\";\nimport { getContactModel } from \"./contactFormModel\";\nimport { gtm } from \"../../../lib/tracking\";\n\nexport function Contact(props) {\n  const emailReceiver = props.emailReceiver;\n  const fileAttachment = props.fileAttachment || \"false\";\n  const mailchimpApiKey = props.mailchimpApiKey;\n  const mailchimpAudienceKey = props.mailchimpAudienceKey;\n\n  const model = getContactModel({});\n  const form = useForm(model, { usePlaceholder: true });\n  const [sendingStatus, setSendingStatus] = React.useState(null);\n  const [mailChimpError, setMailChimpError] = React.useState();\n  const post = usePost();\n\n  const mailChimpErrorMemo = React.useMemo(() => {\n    return mailChimpError;\n  }, [mailChimpError]);\n\n  function onSubmit(e) {\n    setMailChimpError(null);\n    form.validateForm(e, () => {\n      const value = {\n        ...form.getValue(),\n        emailReceiver: emailReceiver,\n        mailchimpApiKey: mailchimpApiKey,\n        mailchimpAudienceKey: mailchimpAudienceKey,\n      };\n      var files = form.getFiles();\n      var formData = new FormData();\n      formData.append(\"jsonData\", JSON.stringify(value));\n      files.forEach((file) => {\n        (file.files || []).forEach((uploadFile) => {\n          formData.append(file.name, uploadFile);\n        });\n      });\n      //post.send(env.apiBase + \"/api/contact/send\", value);\n      post.sendFormData(env.apiBase + \"/api/contact/send\", formData);\n      setSendingStatus(\"pending\");\n    });\n\n    console.log(\"submitting\");\n  }\n\n  // if (status === 'done') {\n  //   //navigate(`/task/view/${taskId}`)\n  //   window.location.reload();\n  // }\n\n  if (post.done() && sendingStatus === \"pending\") {\n    var value = form.getValue();\n    gtm.sendEvent(\"contactFormSubmitted\", { contactEmail: value.email });\n    form.reset(model);\n    setSendingStatus(null);\n\n    if (\n      post.response.results &&\n      post.response.results.MailChimpError &&\n      post.response.results.MailChimpError !== \"\"\n    ) {\n      setMailChimpError(\n        \"Mail Chimp Error : \" + post.response.results.MailChimpError\n      );\n    }\n  }\n\n  const render = (name) => form.renderControl(name, null);\n\n  return (\n    <form className='contactForm'>\n      <div className='form-row'>\n        <div className='col-md-12 mb-2'>{render(\"name\")}</div>\n      </div>\n      <div className='form-row'>\n        <div className='col-md-12 mb-2'>{render(\"phone\")}</div>\n      </div>\n      <div className='form-row'>\n        <div className='col-md-12 mb-2'>{render(\"email\")}</div>\n      </div>\n      <div className='form-row'>\n        <div className='col-md-12 mb-2'>{render(\"enquiry\")}</div>\n      </div>\n\n      {fileAttachment === \"true\" && (\n        <div className='form-row'>\n          <div className='col-md-12 mb-2'> {render(\"attachments\")} </div>\n        </div>\n      )}\n\n      <div className='form-row'>\n        <div className='col-md-12 mb-2'>\n          <div className='actions'>\n            <Button onClick={onSubmit} status={post.status}>\n              Send Message\n            </Button>\n            <ErrorMessage\n              errors={form.errors}\n              summaryMessage='Please review the errors.'\n            />\n            <ErrorMessage errors={post.errors} />\n            <ErrorMessage errors={mailChimpErrorMemo} />\n            {post.done() && (\n              <span\n                style={{\n                  marginLeft: \"1.5rem\",\n                  color: \"green\",\n                  fontWeight: \"bold\",\n                }}\n              >\n                Successfully sent!\n              </span>\n            )}\n          </div>\n        </div>\n      </div>\n    </form>\n  );\n}\n","import { fb, validators } from '../../../lib/form';\n\nexport function getContactModel(data) {\n  const model = fb.group({\n    name: [data.name || '', [validators.Required()], { label: 'Name', type: 'text' }],\n    phone: [data.phone || '', [validators.Required()], { label: 'Phone', type: 'text' }],\n    email: [data.email || '', [validators.Required(), validators.Email()], { label: 'Email', type: 'email' }],\n    enquiry: [data.enquiry || '', [validators.Required()], { label: 'Your Message', type: 'textarea' }],\n    attachments: [data.attachments || '', [], { label: 'Attachments', type: 'file' }]\n  }); \n  return model;\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport  utils from '../../../utils';\nimport { Contact } from './contactForm';\n\nexport function ContactForm(props) {\n  const item = props.item;\n  console.log('item', item);\n  //const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, cmsOption);\n\n  const emailReceiver = cmsUtils.payload(item, 'EmailReceiver');\n  const fileAttachment = cmsUtils.payload(item, 'FileAttachment') || \"false\";\n\n  const mailchimpApiKey = cmsUtils.payload(item, 'MailchimpApiKey');\n  const mailchimpAudienceKey = cmsUtils.payload(item, 'MailchimpAudienceKey');\n\n  const cssClass = utils.classNames('cms_item', 'htmlPanel', cmsOption.isCmsEdit && 'html', item.cssClass || item.anchorName || '');\n\n  //let itemElt = (<div dangerouslySetInnerHTML={{ __html: content }}></div>);\n\n  return (\n    <div className={cssClass} data-cms-html=\"true\"\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n\n      <div className=\"container contact-wrapper\" id=\"contactForm\">\n        <Contact emailReceiver={emailReceiver} fileAttachment = {fileAttachment} mailchimpApiKey = {mailchimpApiKey} mailchimpAudienceKey = {mailchimpAudienceKey} />\n      </div>\n\n    </div>\n  )\n}","import React, { useState, useRef } from 'react';\r\nimport utils from '../../utils';\r\nimport { debounce } from '../utils-core/debounce';\r\nimport * as yt from './iframeApi';\r\nimport { FiVolumeX, FiVolume2 } from 'react-icons/fi';\r\nimport { FaRegPlayCircle } from 'react-icons/fa';\r\nimport ModalVideo from 'react-modal-video'\r\n\r\n\r\nexport function YoutubeBannerMobilePopup(props) {\r\n  const youtubeBannerRef = React.useRef(null);\r\n\r\n  const [playerStatus, setPlayerStatus] = useState('loading');\r\n  const [playerSize, setPlayerSize] = useState(null);\r\n  const [ytPlayer, setYtPlayer] = useState(null);\r\n  const [muted, setMuted] = useState(true);\r\n  const countPlayedRef = useRef(0);\r\n  const [popupOpened, setPopupOpened] = useState(false);\r\n  const { heightSet, videoLinkOrId, playerId } = props.video;\r\n  const videoId = yt.getYoutubeCode(videoLinkOrId);\r\n  //const posterImageUrl = yt.thumbnailMax(videoId);\r\n  const posterImageUrl = (props.posterImageUrl && props.posterImageUrl !== '') ? props.posterImageUrl : yt.thumbnailMax(videoId);\r\n  const mobileImageUrl = props.mobileImageUrl;\r\n  //let countPlayed = 0;\r\n  const canPlayVideo = () => (typeof window !== `undefined` && typeof props.canPlayVideo === `undefined`)? window.innerWidth >= 1200 : !!(typeof props.canPlayVideo === 'function'? props.canPlayVideo() : props.canPlayVideo);\r\n\r\n  const playerVars = {\r\n    'enablejsapi': 1,\r\n    //'autoplay': 1,\r\n    'controls': 0,\r\n    'loop': 1,\r\n    'showinfo': 0,\r\n    'rel': 0,\r\n    'modestbranding': 1,\r\n    //'origin': typeof window !== `undefined` && window.location.origin,\r\n    'allowfullscreen': true,\r\n    'wmode': 'transparent'\r\n  }\r\n\r\n  //console.log('videoId: ' + videoId)\r\n  //const canPlayVideo = () => window.innerWidth >= 1200\r\n  React.useEffect(() => {\r\n    const resized = debounce(() => {\r\n      loadVideo();\r\n    });\r\n    loadVideo();\r\n    if (typeof window !== `undefined`)\r\n      window.addEventListener('resize', resized)\r\n    return () => {\r\n      if (typeof window !== `undefined`)\r\n        window.removeEventListener('resize', resized)\r\n    }\r\n    // eslint-disable-next-line\r\n  }, [])\r\n\r\n  \r\n  function loadVideo() {\r\n    if (youtubeBannerRef.current)\r\n      setPlayerSize(getSize(youtubeBannerRef.current));\r\n    if (canPlayVideo()) {\r\n      \r\n      const existingScript = document.getElementById('youtubeIframeApJaba');\r\n\r\n      if(existingScript){\r\n        if(window.YT){\r\n          setTimeout(init, 100);\r\n        }\r\n        else{\r\n          let checkInterTime = 0;\r\n          const checkYoutubeIframeApJabaScript = setInterval(() => {\r\n            console.log(\"checkYoutubeIframeApJabaScript\", checkInterTime);\r\n            if(window.YT){\r\n              setTimeout(init, 100);\r\n              clearInterval(checkYoutubeIframeApJabaScript);\r\n            }\r\n\r\n            if(checkInterTime >= 10){\r\n              clearInterval(checkYoutubeIframeApJabaScript);\r\n            }\r\n            checkInterTime ++;\r\n          }, 100);\r\n        }\r\n      }\r\n      else{\r\n        yt.loadApi((loadJs) => {\r\n          loadJs ? init() : setTimeout(init, 100)\r\n        })\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  function init() {\r\n    let player = null;\r\n    if (typeof window !== `undefined`) {\r\n      player = new window.YT.Player(playerId, {\r\n        events: {\r\n          'onStateChange': (e) => {\r\n            switch (e.data) {\r\n              // case window.YT.PlayerState.PLAYING:\r\n              //   break;\r\n              // case window.YT.PlayerState.PAUSED:\r\n              //   break;\r\n              case window.YT.PlayerState.ENDED:\r\n                console.log(\"window.YT.PlayerState.ENDED----\", playerId);\r\n                const countPlayed = countPlayedRef.current;\r\n                if (countPlayed < 3 - 1) {\r\n                  //console.log('ended', countPlayed + 1);\r\n                  countPlayedRef.current = countPlayed + 1;\r\n                  if (player && player.playVideo)\r\n                    player.playVideo();\r\n                } else {\r\n                  console.log(\"window.YT.PlayerState.ENDED----finished\");\r\n                  setPlayerStatus('finished');\r\n                }\r\n                break;\r\n              default:\r\n            }\r\n          },\r\n          'onReady': (e) => {\r\n            //console.log('onReady');\r\n            if (player && player.mute && player.playVideo) {\r\n              player.mute();\r\n              player.playVideo();\r\n            }\r\n            setTimeout(() => setPlayerStatus('loaded'), 1000)\r\n          },\r\n          'onError': (e) => { console.log(e) }\r\n        }\r\n      });\r\n\r\n      setYtPlayer(player);\r\n    }\r\n  }\r\n\r\n  function soundToggle(e) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    if (ytPlayer){\r\n      if (muted) {\r\n        setMuted(false);\r\n        setTimeout(() => {\r\n          if (ytPlayer && ytPlayer.pauseVideo && ytPlayer.unMute && ytPlayer.playVideo) {\r\n            ytPlayer.pauseVideo();\r\n            ytPlayer.unMute();\r\n            ytPlayer.playVideo();\r\n          }\r\n        }, 100)\r\n      } else {\r\n        setMuted(true);\r\n        setTimeout(() => {\r\n          if (ytPlayer && ytPlayer.pauseVideo && ytPlayer.unMute && ytPlayer.playVideo) {\r\n            ytPlayer.pauseVideo();\r\n            ytPlayer.mute();\r\n            ytPlayer.playVideo();\r\n          }\r\n        }, 100)\r\n      }\r\n    }\r\n\r\n    //https://developers.google.com/web/updates/2017/09/autoplay-policy-changes\r\n  }\r\n\r\n  function playVideo() {\r\n    setPopupOpened(true)\r\n  }\r\n\r\n  const canPlay = canPlayVideo();\r\n  const imageUrl = !canPlay && mobileImageUrl ? mobileImageUrl : posterImageUrl;\r\n  return (\r\n    <React.Fragment>\r\n    <div className={utils.classNames('youtubePlayer', `youtubePlayer--${canPlay ? 'canPlay' : 'cannotPlay'}`, `youtubePlayer--${playerStatus}`, `youtubePlayer--${heightSet}`)} ref={youtubeBannerRef}>\r\n      <div className=\"youtubePlayer__mask\"></div>\r\n      <div className=\"youtubePlayer__poster\" id={playerId + \"poster\"} style={{ backgroundImage: utils.css.bgUrlStyle(imageUrl) }}></div>\r\n      {canPlay && playerSize && <iframe className=\"youtubePlayer__iframe\" id={playerId} width=\"640\" height=\"390\" title=\"Youtube video\"\r\n        style={{ width: `${playerSize.width}px`, height: `${playerSize.height}px`, top: `${playerSize.top}px`, left: `${playerSize.left}px` }}\r\n        src={`https://www.youtube.com/embed/${videoId}?${utils.url.toQueryString(playerVars)}`}\r\n        allow=\"autoplay; fullscreen\"\r\n        frameBorder=\"0\"></iframe>}\r\n      {canPlay && playerStatus === 'loaded' && <div className=\"youtubePlayer__soundIcon\" title={muted? 'Sound On': 'Sound Off'} onClick={soundToggle}>\r\n        {/* {muted? <FiVolume2 /> : <FiVolumeX/>} */}\r\n        {muted? <FiVolumeX /> : <FiVolume2 />}\r\n      </div>}\r\n\r\n      {!canPlay && !mobileImageUrl && <div className=\"youtubePlayer__playIcon\" title=\"Play\" onClick={playVideo}>\r\n      <FaRegPlayCircle />\r\n      </div>}\r\n    </div>\r\n    <ModalVideo channel='youtube' isOpen={popupOpened} videoId={videoId} onClose={() => setPopupOpened(false)} />\r\n    </React.Fragment>\r\n  );\r\n}\r\n\r\nfunction getSize(container) {\r\n  const containerSize = container ? { w: container.offsetWidth, h: container.offsetHeight } : { w: window.innerWidth, h: window.innerHeight }\r\n  const overSize = 1;\r\n  const rate = 9 / 16;\r\n  const w = containerSize.w * overSize;\r\n  const h = containerSize.h * overSize;\r\n  const size = { width: w, height: w * rate, left: 0, top: 0 };\r\n  if (size.height < h) {\r\n    // stretch horizontally\r\n    size.height = h;\r\n    size.width = h / rate;\r\n  }\r\n\r\n  //console.log(size)\r\n  size.left = -(size.width - containerSize.w) / 2;\r\n  size.top = -(size.height - containerSize.h) / 2;\r\n  return size;\r\n}\r\n","import React from 'react';\n// import { Item } from '../../items/item';\n// import { SiteLink } from 'shared/link/siteLink';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { YoutubeBannerMobilePopup } from '../../../lib/youtube/youtubeBanner--mobilePopup';\n//import env from '../../../env';\n//import Slider from 'modules/slider/slider';\n//import {BannerPanel} from '../bannerPanel/view';\n\nexport function VideoPanel(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item);\n\n  const heightSet = cmsUtils.payload(item, 'HeightSet') || 'standard';\n  const videoCode = cmsUtils.payload(item, 'YoutubeCode');\n  const playerId = 'ytBanner-' + (item.itemId).substr(0, 8);\n\n  const video = {\n    heightSet: heightSet,\n    videoLinkOrId: videoCode,\n    playerId: playerId\n  }\n\n  //const enableYoutube = env.isProd;\n  const canPlayVideo = () => utils.css.screenWidth() >= 0\n\n  const cssClass = utils.classNames('cms_item', 'youtubePanel', item.cssClass || item.anchorName || '');\n\n  //console.log(window.innerWidth, canPlayVideo())\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      {/* {canPlayVideo() ? <YoutubeBanner video={video} /> : <BannerPanel item={item}></BannerPanel>} */}\n      <YoutubeBannerMobilePopup video={video} canPlayVideo={canPlayVideo} />\n    </div>\n  );\n}\n\n// function MobileSlider(props) {\n//   const item = props.item;\n//   const subItems = item.items || [];\n  \n//   const slides = subItems.map((subItem, index) =>\n//     <SlideItem item={subItem} key={subItem.itemId}></SlideItem>\n//   );\n\n//   useLayoutEffect(() => {\n//     setTimeout(() => {\n//       console.log(window.innerWidth);\n//     const slider = new Slider('.contSlider');\n//     slider.init();\n//     }, 100)\n//   }, [])\n\n//   return (\n//     <div className=\"contSlider bannerSize\">\n//       {slides}\n//     </div>\n//   );\n// }\n\n// function SlideItem(props){\n//   const item = props.item;\n//   const bgUrl = utils.site.resourcePath(cmsUtils.payload(item, 'ImageUrl'));\n\n//   return (\n//     <div className=\"contSlide bannerSize\">\n//       <img className=\"contSlide__img\" src={bgUrl} alt=\"Banner\" />\n//     </div>\n//   );\n\n// }","import React from 'react';\nimport env from '../../env';\nimport { SiteLink} from '../../components';\nimport { usePost } from '../../components';\nimport { ErrorPopup, Loading } from '../../components';\nimport { useRouter } from '../../components';\n\nexport function SearchResult(props) {\n  const { query } = useRouter();\n  const post = usePost();\n  const keyword = query.q;\n  //console.log(keyword);\n\n  React.useEffect(() => {\n    post.send(env.apiBase + '/api/search/search', { keyword: keyword });\n    // eslint-disable-next-line\n  }, [keyword]);\n\n  if (post.loading()) {\n    return <Loading />\n  } else if (post.hasErrors()) {\n    return <ErrorPopup title=\"Loading Error\" errors={post.errors} />\n  }\n\n  console.log(post)\n  const data = post.response;\n\n  const pages = data.pages;\n\n  if (pages.length === 0) return (\n    <div className=\"alert alert-danger\" role=\"alert\">\n      No result found.\n    </div>\n  )\n  return (\n    <>\n      {pages.length > 0 && <div>\n      <h3 style={{marginTop: '2rem'}}>Pages</h3>\n      <PageList pages={pages} />\n      </div>}\n    </>\n  );\n}\n\nfunction PageList({pages}) {\n  return (\n    <div className=\"pageList row\">\n      {pages.map((page, index) =>\n        <div className=\"pageListItem col-md-6 col-lg-4\" key={index}>\n          <div className=\"pageListItem__inner\">\n            <SiteLink className=\"pageListItem__title\" to={page.pageUrl}>{page.pageTitle}</SiteLink>\n            <div className=\"pageListItem__highlight\" dangerouslySetInnerHTML={{ __html: page.searchHighlight }}></div>\n          </div>\n        </div>\n      )}\n    </div>\n  );\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core';\nimport cmsUtils from '../../cms/utils/cmsUtils';\nimport { useEffect } from 'react';\n//import style from './style';\n\nexport function TextWithJavScript(props){\n    \n    const item = props.item;\n    const cssClass = props.cssClass;\n    const code = cmsUtils.payload(item, 'Code') || '';\n\n    const javaScriptCode = code.substring(code.indexOf(\"<script\"), (code.indexOf(\"</script>\") + 9)).trim();\n    const nonjavaScriptCode = code.replace(javaScriptCode, '').trim();\n    console.log('nonjavaScriptCode', nonjavaScriptCode);\n\n    useEffect(() => {\n        \n        const javaScriptTopCode = javaScriptCode.substring(javaScriptCode.indexOf(\"<script\"), (javaScriptCode.indexOf(\">\") + 1)).trim();\n        const javaScriptInsideCode = javaScriptCode.substring((javaScriptCode.indexOf(\">\") + 1), (javaScriptCode.indexOf(\"</script>\"))).trim();\n\n        const script = document.createElement('script');\n        script.type = `text/javascript`;\n        \n        if(javaScriptInsideCode !== ''){\n            script.text = javaScriptInsideCode;\n        }\n\n        if(javaScriptTopCode.includes(\"src=\")){\n            let _src = javaScriptTopCode.indexOf('src=\"') === -1 ? '' : javaScriptTopCode.substring(javaScriptTopCode.indexOf('src=\"')).trim();\n            let src = _src.substring((_src.indexOf('src=\"') + 5), _src.indexOf('\"',5));\n            script.src = src;\n        }\n\n        if(javaScriptTopCode.includes(\"async\")){\n            script.async = true;\n        }\n\n        if(javaScriptTopCode.includes(\"defer\")){\n            script.defer = true;\n        }\n\n        if(javaScriptTopCode.includes(\"onload=\")){\n            \n            let _functionName = javaScriptTopCode.substring(javaScriptTopCode.indexOf('onload=') + 8);\n            let functionName = _functionName.substring(0, _functionName.indexOf('\"')-1).replace('()','');\n            script.onload = function(){\n                window[functionName]();\n            };\n        }\n\n        document.body.appendChild(script);\n    }, [javaScriptCode]);\n\n    return(\n        <div className={cssClass} id={item.anchorName}\n            dangerouslySetInnerHTML={{ __html: nonjavaScriptCode }}>\n        </div>\n    )\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { SearchResult } from '../../../site/searchResult/searchResult';\nimport { InstagramFeed } from '../../../components';\nimport { AppVersion } from '../../../components';\nimport { TextWithJavScript } from '../../../components/TextWithJavaScript/view';\n\nexport function Code(props) {\n  const item = props.item;\n  //const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, cmsOption);\n\n  const code = cmsUtils.payload(item, 'Code');\n  const codeType = cmsUtils.payload(item, 'CodeType');\n  let controls = null;\n  if (codeType === 'Json') {\n    const codeJson = JSON.parse(code);\n    if (codeJson.control === 'search-results') {\n      controls = <SearchResult />\n    } else if(codeJson.control === 'app'){\n      controls = <AppVersion />\n    } else if (codeJson.control === 'instagram') {\n      controls = <InstagramFeed />\n    }\n  }\n\n  const cssClass = utils.classNames('cms_item', item.cssClass || item.anchorName || '');\n\n  //let itemElt = (<div dangerouslySetInnerHTML={{ __html: content }}></div>);\n\n  if (cmsOption.isCmsEdit)\n    return (\n      <div className={cssClass}\n        data-cms-item-id={item.itemId} \n        id={item.anchorName}>\n        <pre style={{ fontSize: '12px', margin: '5px', padding: '10px', background: '#eee', border: '1px solid #ccc' }}>\n          <b>Code Type: {codeType}</b>\n          {code}</pre>\n        </div>\n    )\n  else if (codeType === 'Text')\n    return (\n      <div className={cssClass} id={item.anchorName}\n        dangerouslySetInnerHTML={{ __html: code }}></div>\n    )\n  else if(codeType === 'TestWithJs'){\n      return(\n        <TextWithJavScript item = {item} cssClass = {cssClass}/>\n      )\n  }\n  else\n    return (\n      <div className={cssClass} id={item.anchorName}>{controls}</div>\n    )\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { SiteLink } from '../../../components';\n\nexport function BlogPosts(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item);\n\n  const posts = getPages(cmsUtils.payload(item, 'BlogPosts'));\n  const numOfTileLines = parseInt(cmsUtils.payload(item, 'NumOfTileLines', '2'));\n  //console.log(numOfPost, parseInt(numOfPost));\n  //console.log(posts);\n  const bp = utils.ui.getCurrentBreakpoint();\n  const tilesPerLine = {xs:1, sm:1, md:2, lg:2, xl:3, xxl:4}\n  const numOfPost = numOfTileLines * (tilesPerLine[bp] || 3);\n  const step = numOfPost;\n  console.log(bp, numOfTileLines, tilesPerLine, numOfPost)\n\n  const [tilesToShow, setTilesToShow] = React.useState(numOfPost);\n\n  const displayingPosts = posts.length > tilesToShow ? posts.slice(0, tilesToShow) : posts;\n  const showMore = posts.length > displayingPosts.length;\n\n  const pageTileElts = displayingPosts.map((page, index) =>\n    <Tile page={page} key={index} disableLink={cmsOption.isCmsEdit}></Tile>\n  );\n\n  const cssClass = utils.classNames('cms_item', 'blogTiles tiles', item.cssClass || item.anchorName || '');\n\n  return (\n    <>\n      <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n        {pageTileElts}\n      </div>\n      {showMore && (<div className=\"blogTiles__loadMore\">\n        <span className=\"thinBtn\" onClick={(e) => { setTilesToShow(tilesToShow + step) }}>LOAD MORE</span></div>)}\n    </>\n  );\n}\n\nfunction getPages(pagesSerialized) {\n  if (pagesSerialized) {\n    return JSON.parse(pagesSerialized);\n  }\n  return [];\n}\n\nfunction Tile(props) {\n  const page = props.page;\n  const imageUrl = utils.site.resourcePath(page.imageUrl);\n  const disableLink = props.disableLink;\n  return (\n    <div className=\"blogTile\">\n      <SiteLink className=\"blogTile__link\" to={disableLink ? '' : page.pageUrl}>\n        <div className=\"blogTile__bg\" style={{ backgroundImage: utils.css.bgUrlStyle(imageUrl) }}></div>\n        <div className=\"blogTile__content\">\n          <div className=\"blogTile__contentInner\">\n            <div className=\"blogTile__title\">\n              {page.pageTitle}\n            </div>\n            <div className=\"blogTile__desc\">\n              {page.tileDesc || page.description}\n            </div>\n            <div className=\"blogTile__readMore thinBtn\">READ MORE</div>\n          </div>\n        </div>\n      </SiteLink>\n    </div>\n  )\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\n\nexport function BlogPostTitle(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item);\n\n  const title = cmsUtils.payload(item, 'PageTitle');\n  const postDate = cmsUtils.payload(item, 'PostDate');\n\n  const cssClass = utils.classNames('blogView__titleContainer', 'cms_item', item.cssClass || item.anchorName || '');\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      <div className=\"blogView__date\">\n        {postDate}\n      </div>\n      <h1 className=\"blogView__title\">\n        {title}\n      </h1>\n    </div>\n  );\n}\n","import React from 'react';\n//import cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { Item } from '../../items/item';\n\nexport function VideoHolder(props) {\n  const item = props.item;\n  const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, subItems);\n\n  const subItemsElts = subItems.map((subItem, index) =>\n    <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  );\n\n  const cssClass = utils.classNames('cms_item', 'videoHolder', item.cssClass || item.anchorName || '');\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      {subItemsElts}\n    </div>\n  );\n}","import React from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { YoutubeEmbedPopup } from '../../../components';\n\nexport function VideoItem(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  console.log('item', item);\n\n  const youtubeCode = cmsUtils.payload(item, 'YoutubeCode');\n  const posterFrameUrl = cmsUtils.payload(item, 'PosterFrameUrl');\n  const captionTitleYoutube = cmsUtils.payload(item, 'CaptionTitleYoutube');\n  const shortDesc = cmsUtils.payload(item, 'ShortDesc');\n\n  const cssClass = utils.classNames('cms_item', 'videoItem', item.cssClass || item.anchorName || '');\n\n  return (\n    <div className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n      <div className=\"row video\">\n        <div className=\"col-md-5\">\n          <YoutubeEmbedPopup url={youtubeCode} title={captionTitleYoutube} posterUrl={posterFrameUrl} />\n        </div>\n        <div className=\"col-md-7\">\n          <h4>{captionTitleYoutube}</h4>\n          <div dangerouslySetInnerHTML={{ __html: shortDesc }}></div>\n        </div>\n      </div>\n    </div>\n  );\n}","import React from \"react\";\nimport cmsUtils from \"../../utils/cmsUtils\";\nimport { Item } from \"../../items/item\";\nimport utils from \"../../../utils\";\n\nexport function MultiColumnPanel(props) {\n  const item = props.item;\n  const mobileReverse = cmsUtils.payload(item, \"MobileReverse\", \"no\");\n  //const subItems = item.items || [];\n  const subItems =\n    mobileReverse === \"yes\" && utils.css.screenWidth() <= 550\n      ? item.items.reverse() || []\n      : item.items || [];\n  const cmsOption = props.cmsOption || {};\n  const columnWidths = cmsUtils.payload(item, \"ColumnWidths\").split(\",\");\n  const mobileColumnWidths = cmsUtils\n    .payload(item, \"MobileColumnWidths\")\n    .split(\",\");\n  const countItem = { countD: 0, countM: 0, col: \"\" };\n\n  const bgColor = cmsUtils.payload(item, \"BgColor\");\n  //const textColorTheme = cmsUtils.payload(item, 'TextColorTheme');\n  const imageUrl = cmsUtils.payload(item, \"ImageUrl\");\n  const backgroundTile = cmsUtils.payload(item, \"BackgroundTile\");\n  const bgTheme = cmsUtils.payload(item, \"TextColorTheme\") || \"white\";\n  const panelWidth = cmsUtils.payload(item, \"PanelWidth\");\n\n  let bgUrl = null;\n  if (imageUrl) bgUrl = utils.site.resourcePath(imageUrl);\n  else if (backgroundTile)\n    bgUrl = utils.site.resourcePath(\n      `/dist/transparent-textures/textures/${backgroundTile}`\n    );\n\n  const cssClass =\n    panelWidth === \"full\"\n      ? utils.classNames(\n          \"cms_item\",\n          \"contentPanel\",\n          \"multiColumnPanel\",\n          \"multiColumnPanelFull\",\n          \"contentPanel--\" + bgTheme,\n          item.cssClass || item.anchorName || \"\"\n        )\n      : utils.classNames(\n          \"cms_item\",\n          \"contentPanel\",\n          \"multiColumnPanel\",\n          \"contentPanel--\" + bgTheme,\n          item.cssClass || item.anchorName || \"\"\n        );\n\n  function setupClass(index) {\n    countItem.col = \"\";\n    if (columnWidths.length === countItem.countD) {\n      countItem.countD = 0;\n    }\n\n    if (mobileColumnWidths.length === countItem.countM) {\n      countItem.countM = 0;\n    }\n\n    countItem.col =\n      \"col-sm\" +\n      (columnWidths[countItem.countD] === \"13\"\n        ? \"\"\n        : \"-\" + columnWidths[countItem.countD]) +\n      \" col-\" +\n      mobileColumnWidths[countItem.countM];\n    countItem.countD++;\n    countItem.countM++;\n  }\n\n  const subItemsElts = subItems.map((subItem, index) => {\n    setupClass();\n    return (\n      <div className={countItem.col} key={subItem.itemId}>\n        <Item item={subItem} cmsOption={cmsOption}></Item>\n      </div>\n    );\n  });\n  return (\n    <section\n      className={cssClass}\n      style={{\n        backgroundColor: `${bgColor}`,\n        backgroundImage: bgUrl && utils.css.bgUrlStyle(bgUrl),\n      }}\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId}\n      id={item.anchorName}\n    >\n      <div className='container'>\n        <div className='row'>{subItemsElts}</div>\n      </div>\n    </section>\n  );\n}\n","/** @jsx jsx */\nimport { jsx } from '@emotion/core';\nimport { FaChevronDown } from \"react-icons/fa\";\nimport React, { useLayoutEffect, useRef } from 'react';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { useRouter } from '../../../components';\nimport { handleElementLink } from '../../../components';\nimport env from '../../../env';\n\nexport function ExpandableHtml(props) {\n  const cmsOption = props.cmsOption || {};\n  const [open, setOpen] = React.useState(cmsOption.isCmsEdit);\n  const ver = env.ver;\n  const item = props.item;\n  //const subItems = item.items || [];\n  const { history } = useRouter();\n  //console.log('item', item, cmsOption);\n  //console.log(open)\n  let content = cmsOption.isCmsEdit? \n    cmsUtils.payload(item, 'Content'): \n    cmsUtils.payload(item, 'Content').replace(\"__version__\", \"<a href = '/app' class = 'app_version'> PWA \"+ ver +\"</a>\");\n\n  const buttonTitle = cmsUtils.payload(item, 'ButtonTitle');\n\n\n  const cssClass = utils.classNames('cms_item', 'htmlPanel exHtml', cmsOption.isCmsEdit && 'html', item.cssClass || item.anchorName || '');\n\n  //let itemElt = (<div dangerouslySetInnerHTML={{ __html: content }}></div>);\n\n  function handleClick(e) { \n    \n    let target = \"\";\n    if(e.target.closest('a')){\n      target = e.target.closest('a').getAttribute('target');\n    }\n    const processed = (target === \"_blank\" ? handleElementLink(e.target, null) : handleElementLink(e.target));\n    //const link = utils.url.getLinkFromElement(e.target);\n    //console.log('clicked', e, e.target, processed);\n    \n    if (processed.handled) {\n      e.preventDefault();\n      e.stopPropagation();\n    } else if (processed.linkInfo && processed.linkInfo.type === 'internal') {\n      e.preventDefault();\n      e.stopPropagation();\n      history.push(processed.linkInfo.url)\n    } else {\n      // e.preventDefault();\n      // e.stopPropagation();\n      // setPdfViewPath(utils.site.resourcePath(link))\n    }\n  }\n\n  const htmlBlock = useRef(null);\n  // function iframeSizer() {\n  //   //console.log('iframesizer')\n  //   let iframesContainer = htmlBlock.current.querySelectorAll('iframe.youtube, .ytvideo iframe');\n  //   //console.log('iframesizer', iframesContainer)\n  //   if (iframesContainer && iframesContainer.length) {\n  //     iframesContainer.forEach(element => {\n  //       let height = (element.parentElement.offsetWidth * 9) / 16\n  //       //console.log(height, element.parentElement.offsetWidth)\n  //       element.style.height = height + 'px';\n  //     });\n  //   }\n  // }\n\n  useLayoutEffect(() => {\n    const buttons = htmlBlock.current.querySelectorAll('.button');\n    for (let i = 0; buttons && i < buttons.length; i++) {\n      restructureButton(buttons[i])\n    }\n\n    // const youtubes = htmlBlock.current.querySelectorAll('iframe[src*=\"youtube\"]');\n    // console.log(youtubes)\n\n    // iframeSizer();\n    // window.addEventListener('resize', iframeSizer)\n    // return (): void => {\n    //   window.removeEventListener('resize', iframeSizer)\n    // }\n\n  }, [])\n\n\n  const style = {\n    icon: {\n      marginLeft: '0.5rem',\n      width: 'auto !important',\n      fontSize: '80%',\n      transition: 'all 0.5s'\n    },\n    iconOpen: {\n      transform: 'translateY(-0.1rem) rotate(-180deg)'\n    },\n    iconClosed: {\n      transform: 'translateY(-0.1rem) rotate(0)'\n    },\n    panelCollapsed: {\n      maxHeight: 0,\n      transition: 'all 0.6s',\n      opacity: 0,\n      overflow: 'hidden'\n    },\n    panelOpen: {\n      opacity: 1,\n      maxHeight: '2000px',\n      transition: 'all 1s'\n    }\n  }\n\n  const toggleExPanel = (e) => {\n    e.preventDefault()\n    e.stopPropagation()\n    setOpen(!open)\n  }\n\n\n  if (cmsOption.isCmsEdit)\n  return (\n    <div ref={htmlBlock} className={cssClass}\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName} onClick={(e) => handleClick(e)}>\n        <div css={{textAlign: 'center'}}>\n          <a className=\"button\" href=\"/\" onClick={(e) => {e.preventDefault(); e.stopPropagation();}}><strong>{buttonTitle}</strong> <span css={[style.icon, open? style.iconOpen : style.iconClosed]}><FaChevronDown /></span> </a>\n          <div css={{color: 'chocolate'}}>To edit the button title, please double click or open item editor</div>\n        </div>\n        \n        <div data-cms-html=\"true\"\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId} css={[{margin: '1rem 0'}, open? style.panelOpen: style.panelCollapsed ]}\n      dangerouslySetInnerHTML={{ __html: content }}></div>\n      </div>\n  )\n\n  return (\n    <div ref={htmlBlock} className={cssClass} data-cms-html=\"true\"\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName} onClick={(e) => handleClick(e)}>\n        <div css={{textAlign: 'center'}}>\n          <a className=\"button\" href=\"/\" onClick={toggleExPanel}><strong>{buttonTitle}</strong> <span css={[style.icon, open? style.iconOpen : style.iconClosed]}><FaChevronDown /></span> </a>\n        </div>\n        \n        <div css={[{margin: '1rem 0'}, open? style.panelOpen: style.panelCollapsed ]}\n      dangerouslySetInnerHTML={{ __html: content }}></div>\n      </div>\n  )\n}\n\n\nfunction restructureButton(el) {\n  if (!el.querySelector('span')) {\n    const span = document.createElement('span');\n    span.innerHTML = el.innerHTML;\n    el.innerHTML = '';\n    el.appendChild(span);\n  }\n}","// //import { css, keyframes  } from '@emotion/core'\n// //import { variables, mq } from 'cssInJs'\n\nimport { css } from '@emotion/core'\nimport { mq } from '../../cssInJs'\n\nexport default {\n    photoGallery : css({\n        maxWidth : '960px',\n        margin: 'auto'\n    }),\n    thumbnails : css({\n        display:'flex',\n        flexWrap:'wrap',\n        marginLeft:'-5px',\n        marginRight:'-5px'\n    }),\n    thumbnail : css(mq({\n        //flexBasis: ['50%','25%','33.33%'],\n        flexBasis: ['50%','25%','16.66%'],\n        //padding: ['5px']\n        padding:'5px',\n        cursor: 'pointer'\n    })),\n    bg : {\n        paddingBottom: '100%',\n        backgroundSize: 'cover',\n        backgroundPosition: 'center',\n        backgroundRepeat: 'no-repeat',\n    }\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport style from './style';\nimport { useState, useEffect } from 'react';\n\nimport utils from '../../utils';\nimport cmsUtils from '../../cms/utils/cmsUtils';\nimport FsLightbox from 'fslightbox-react';\nimport { createPortal } from \"react-dom\";\n\nfunction Portal({children}){\n    const [el] = useState(document.createElement('div'));\n    useEffect(() => {\n        let mount = document.getElementById(\"portal-root\");\n        mount.appendChild(el);\n      return () => mount.removeChild(el);\n    }, [el]);\n    return createPortal(children, el);\n}\n\nexport function PhotoGallery(props){\n    const item = props.item;\n    const cmsOption = props.cmsOption || {};\n    const cssClass = utils.classNames('cms_item', 'photoGallery', item.cssClass || item.anchorName || '');\n    const _images = cmsUtils.payload(item, 'ImageUrl') ? cmsUtils.payload(item, 'ImageUrl').split(\"|\") : [];\n    const _thumbImages = [];\n\n    // _images.forEach(el => {\n    //     let a = el.split(\"/\");\n    //     console.log('e',e);\n    // });\n\n    //let a = _images[0].split(\"/\");\n    \n    if(_images.length > 0){\n        _images.forEach(el => {\n            let _texts = el.split('/');\n            let _text = el.replace(_texts[_texts.length-1], \"@thumb/\" + _texts[_texts.length-1]);\n            _thumbImages.push(_text);\n        });\n        //console.log('222', _images2);\n    }\n\n    //const _images = ['https://jaba.com.au/sites/jaba/media/images/multicolour-services-min.jpg'];\n    const [toggler, setToggler] = useState(false);\n    const [popupIndex, setPopupIndex] = useState(0);\n    \n    return(\n        <div css={style.photoGallery} className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n            {/* <FsLightbox\n                toggler={ toggler }\n                sources={_images}\n            /> */}\n            <Portal>\n                <div style={{display:'none'}}>\n                    PhotoGallery\n                </div>\n                <FsLightbox\n                    toggler={ toggler }\n                    sources={_images}\n                    sourceIndex={popupIndex}\n                />  \n            </Portal>\n\n            <div css={style.thumbnails}>\n                {\n                    _thumbImages.map((item, index) =>\n                     <div css={style.thumbnail} className=\"thumbnail\" key={index} onClick={(e)=> {\n                        e.preventDefault();\n                        e.stopPropagation();\n                        setToggler(!toggler);\n                        setPopupIndex(index);\n                     }}>\n                         <div css={style.bg} style={{ backgroundImage: utils.css.bgUrlStyle(item) }}></div>\n                     </div>\n                    )\n                    \n                }\n            </div>\n        </div>\n    );   \n}","import { css } from '@emotion/core'\n//import { mq } from 'cssInJs'\n\nexport default{\n    testimonialPanel : css({\n        marginTop: '20px',\n        marginBottom: '20px',\n        backgroundColor: 'transparent',\n        '& .slick-prev:before, .slick-next:before' : {\n            color : 'black'\n        },\n        '& .slick-next' : {\n            right : '-2%'\n        },\n        '& .slick-prev' : {\n            left : '-2%'\n        }\n    })\n}","import { css } from \"@emotion/core\";\nimport { mq } from \"../../../cssInJs\";\n\nexport default {\n  testimonialItem: css(\n    mq({\n      maxWidth: \"300px\",\n      backgroundColor: \"#fff\",\n      textAlign: \"left\",\n      color: \"#000\",\n      padding: \"1.5rem\",\n      //height: '100%',\n      display: \"flex\",\n      flexDirection: \"column\",\n      // justifyContent: \"space-between\",\n      margin: \"auto\",\n      height: [\"400px\", \"430px\"],\n      borderBottom: \"6px solid #0158D7\",\n    })\n  ),\n\n  testimonialItem_title: css(\n    mq({\n      marginBottom: \"1rem\",\n      fontSize: [\"1.2rem\", \"1.1rem\"],\n      lineHeight: \"1.3\",\n    })\n  ),\n  testimonialItem_star: css(\n    mq({\n      marginBottom: \".8rem\",\n    })\n  ),\n\n  testimonialItem_desc: css(\n    mq({\n      // flex: \"1 1 auto\",\n      fontSize: [\"1rem\", \".85rem\"],\n      lineHeight: \"1.3\",\n      marginBottom: \"1rem\",\n      //flexGrow: '1',\n      //flexShrink: '1'\n    })\n  ),\n\n  testimonialItem_bottom: css(\n    mq({\n      fontSize: [\"1rem\", \"0.8rem\"],\n    })\n  ),\n};\n","import utils from \"../../../utils\";\nimport cmsUtils from \"../../../cms/utils/cmsUtils\";\nimport { IoIosStar } from \"react-icons/io\";\n\n/** @jsx jsx */\nimport { jsx } from \"@emotion/core\";\nimport style from \"./style\";\n\nexport function TestimonialItem(props) {\n  const item = props.item;\n  //const cmsOption = props.cmsOption || {};\n  const cssClass = utils.classNames(\n    \"cms_item\",\n    \"testimonialItem\",\n    item.cssClass || item.anchorName || \"\"\n  );\n\n  const startRatingColor = \"#fbbb07\";\n\n  const title = cmsUtils.payload(item, \"Title\");\n  const desc = cmsUtils.payload(item, \"Desc\");\n  const bottom = cmsUtils.payload(item, \"BottomText\");\n  const ratingValue = parseInt(cmsUtils.payload(item, \"RatingStar\"));\n\n  var rating = [];\n\n  for (var i = 0; i < ratingValue; i++) {\n    rating.push(<IoIosStar key={i} style={{ color: startRatingColor }} />);\n  }\n\n  return (\n    // data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}\n    <div css={style.testimonialItem} className={cssClass}>\n      <div css={style.testimonialItem_star} className='rating'>\n        {rating}\n      </div>\n      <h4 css={style.testimonialItem_title} className='title'>\n        {title}\n      </h4>\n      {/* style={{ flexBasis: props.desH + \"px\" }} */}\n      <div css={style.testimonialItem_desc} className='desc'>\n        {desc}\n      </div>\n      <h5 css={style.testimonialItem_bottom} className='bottom'>\n        {bottom}\n      </h5>\n    </div>\n  );\n}\n","//import { Item } from 'cms/items/item';\nimport Slider from \"react-slick\";\nimport utils from '../../../utils';\n//import cmsUtils from 'cms/utils/cmsUtils';\n\n/** @jsx jsx */\nimport { jsx } from '@emotion/core';\nimport style from './style';\n//import { useState, useEffect } from 'react';\n\nimport { TestimonialItem } from '../testimonialItem/view';\n\nexport function TestimonialPanel(props){\n    const item = props.item;\n    //const defaultDesH = 220;\n    const startRatingColor = props.startRatingColor;\n    const subItems = item.items || [];\n    //console.log(subItems.length);\n    const cmsOption = props.cmsOption || {};\n    const cssClass = utils.classNames('cms_item', 'testimonialPanel', item.cssClass || item.anchorName || '');\n    \n    //const [desH, setDesH] = useState(defaultDesH);\n\n    //var maxDesTextLength = 0;\n    const testimonialItems = subItems.map((subItem, index) => {\n            // let subItemDes = cmsUtils.payload(subItem, \"Desc\");\n            // if(maxDesTextLength < subItemDes.length){\n            //     maxDesTextLength = subItemDes.length\n            // }\n            //return <TestimonialItem item={subItem} key={subItem.itemId} cmsOption={cmsOption} desH = {desH} startRatingColor = {startRatingColor} ></TestimonialItem>\n            return <TestimonialItem item={subItem} key={subItem.itemId} cmsOption={cmsOption} startRatingColor = {startRatingColor} ></TestimonialItem>\n        }\n    );\n    \n    // useEffect(() => {\n    //     if(defaultDesH < maxDesTextLength){\n    //         setDesH(maxDesTextLength);\n    //     }\n    // }, [maxDesTextLength]);\n\n    var settings = {\n        dots: false,\n        infinite: true,\n        speed: 1700,\n        autoplaySpeed: 3000,\n        ////fade: true,\n        autoplay: true,\n        slidesToShow: (subItems.length >= 3 ? 3 : subItems.length),\n        //slidesToShow: 3,\n        slidesToScroll: 1,\n        responsive : [\n            {breakpoint : 1024, settings : { slidesToShow: (subItems.length >= 2 ? 2 : subItems.length) }},\n            {breakpoint : 800, settings : { slidesToShow: 1 }}\n        ]\n    };\n\n    return(\n        <div css = {style.testimonialPanel} className={cssClass} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\n            <Slider {...settings}>\n                { testimonialItems }\n            </Slider>\n        </div>\n    );\n}","import { css } from '@emotion/core'\n//import { mq } from '../../cssInJs'\nexport default{\n    exTextItem : css({\n        overflow:'hidden',\n        maxHeight:'0',\n        transition: 'all 0.8s',\n        padding: '0px',\n        '&.expand' : {\n            maxHeight:'40000px',\n            padding: '1rem 0'\n        }\n    })\n}","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\n//import React from 'react';\nimport cmsUtils from '../../cms/utils/cmsUtils';\nimport utils from '../../utils';\nimport style from './style';\nimport { Item } from '../../cms/items/item';\n\nexport function ExpandablePanel(props){\n    const item = props.item;\n    const subItems = item.items || [];\n    const cmsOption = props.cmsOption || {};\n\n    const bgColor = cmsUtils.payload(item, 'BgColor');\n    const imageUrl = cmsUtils.payload(item, 'ImageUrl');\n    const backgroundTile = cmsUtils.payload(item, 'BackgroundTile');\n    \n    let bgUrl = null;\n\n    if (imageUrl){\n        bgUrl = utils.site.resourcePath(imageUrl);\n    }\n    else if (backgroundTile){\n        bgUrl = utils.site.resourcePath(`/dist/transparent-textures/textures/${backgroundTile}`);\n    }\n\n    const cssClass = utils.classNames('cms_item', 'contentPanel', 'expandablePanel', cmsOption.isCmsEdit && 'expandablePanel_item_cms', item.cssClass || item.anchorName || '');\n    const subItemsElts = subItems.map((subItem, index) =>\n        <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n    );\n    //id={item.anchorName}\n    return (\n            <section className={cssClass} style={{\n                backgroundColor: `${bgColor}`,\n                backgroundImage: bgUrl && utils.css.bgUrlStyle(bgUrl)\n                }} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} css={!cmsOption.isCmsEdit && style.exTextItem} data-anchor-status = \"collapse\" data-cms-item-anchor = {item.anchorName}>\n                <div className=\"contentPanel__bg\"></div>\n                <div className=\"container\">\n                  {subItemsElts}\n                </div>\n              </section> \n    )\n}","import React from \"react\";\nimport cmsUtils from \"../../utils/cmsUtils\";\nimport utils from \"../../../utils\";\nimport { YoutubeNew } from \"../youtubeNew/view\";\nimport { Html } from \"../html/view\";\n\nexport function VideoPanelWithText(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n  const heightSet = cmsUtils.payload(item, \"HeightSet\") || \"standard\";\n  const videoCode = cmsUtils.payload(item, \"YoutubeCode\");\n  const playerId = \"ytBanner-\" + item.itemId.substr(0, 8);\n  const posterFrameUrl = cmsUtils.payload(item, \"PosterFrameUrl\", null);\n\n  const video = {\n    heightSet: heightSet,\n    videoLinkOrId: videoCode,\n    playerId: playerId,\n  };\n  const canPlayVideo = () => utils.css.screenWidth() >= 0;\n  const cssClass = utils.classNames(\n    \"cms_item\",\n    \"videoPanelWithText\",\n    item.cssClass || item.anchorName || \"\"\n  );\n\n  return (\n    <section\n      className={cssClass}\n      data-cms-item-id={cmsOption.isCmsEdit && item.itemId}\n      id={item.anchorName}\n      style={{ position: \"relative\", overflow: \"hidden\" }}\n    >\n      <div className='container'>\n        <div className='video_panel_container'>\n          <YoutubeNew\n            video={video}\n            canPlayVideo={canPlayVideo}\n            posterImageUrl={utils.site.resourcePath(posterFrameUrl)}\n          />\n          <Html item={item} cmsOption={cmsOption} />\n        </div>\n      </div>\n    </section>\n  );\n}\n","import React from 'react';\r\nimport cmsUtils from '../../utils/cmsUtils';\r\nimport { Item } from '../../items/item';\r\nimport utils from '../../../utils';\r\nimport './style.scss';\r\nimport { useMediaQuery } from 'react-responsive';\r\n\r\nexport function MultiColumnPanelNew(props) {\r\n    const item = props.item;\r\n    const mobileReverse = cmsUtils.payload(item, 'MobileReverse', 'no');\r\n    //const subItems = item.items || [];\r\n    const subItems = (mobileReverse === \"yes\" && utils.css.screenWidth() <= 550) ? item.items.reverse() || [] : item.items || [];\r\n    const cmsOption = props.cmsOption || {};\r\n\r\n    const columnLaptop = cmsUtils.payload(item, 'ColumnNumber');\r\n    const columnMobile = cmsUtils.payload(item, 'ColumnNumberM');\r\n    const isMobile = useMediaQuery({ maxWidth: 767.99 });\r\n\r\n    const bgColor = cmsUtils.payload(item, 'BgColor');\r\n    //const textColorTheme = cmsUtils.payload(item, 'TextColorTheme');\r\n    const imageUrl = cmsUtils.payload(item, 'ImageUrl');\r\n    const backgroundTile = cmsUtils.payload(item, 'BackgroundTile');\r\n    const bgTheme = cmsUtils.payload(item, 'TextColorTheme') || 'white';\r\n\r\n    console.log(\"columnmunber\", columnLaptop);\r\n\r\n    let bgUrl = null;\r\n    if (imageUrl)\r\n        bgUrl = utils.site.resourcePath(imageUrl);\r\n    else if (backgroundTile)\r\n        bgUrl = utils.site.resourcePath(`/dist/transparent-textures/textures/${backgroundTile}`);\r\n\r\n\r\n    const cssClass = utils.classNames('cms_item', 'contentPanel', 'multiColumnPanel', 'multiColumnPanelNew', 'contentPanel--' + bgTheme, item.cssClass || item.anchorName || '');\r\n\r\n    const getColumnClass = () => {\r\n        if (columnLaptop === \"1\" || isMobile) {\r\n            return \"single-column\";\r\n        } else if (columnLaptop === \"2\") {\r\n            return \"double-column\";\r\n        }\r\n    };\r\n\r\n    const subItemsElts = subItems.map((subItem, index) => (\r\n        <div\r\n            className={`${getColumnClass()}`} \r\n            key={subItem.itemId}\r\n        >\r\n            <Item item={subItem} cmsOption={cmsOption} />\r\n        </div>\r\n    ));\r\n\r\n    console.log(\"isMobile:\", isMobile);\r\n\r\n    return (\r\n        <section className={cssClass} style={{\r\n            backgroundColor: `${bgColor}`,\r\n            backgroundImage: bgUrl && utils.css.bgUrlStyle(bgUrl)\r\n        }} data-cms-item-id={cmsOption.isCmsEdit && item.itemId} id={item.anchorName}>\r\n            <div className=\"container\">\r\n                {(columnLaptop === 1 || isMobile) ? (\r\n                    <div className='single-column-container'>\r\n                        {subItemsElts}\r\n                    </div>\r\n                ) : (\r\n                    <div className='double-column-container'>\r\n                        {subItemsElts}\r\n                    </div>\r\n                )}\r\n            </div>\r\n        </section>\r\n    );\r\n}","import React from \"react\";\nimport utils from \"../../utils\";\nimport { items } from \"../../site/_cmsItems/items-generated\";\nimport cmsUtils from \"../utils/cmsUtils\";\nimport { BannerPanel } from \"./bannerPanel/view\";\nimport { BannerItem } from \"./bannerItem/view\";\nimport { Panel } from \"./panel/view\";\nimport { Html } from \"./html/view\";\n// import { TestimonialPanel } from './testimonialPanel/view';\n// import { TestimonialItem } from './testimonialItem/view';\nimport { ImagePanel } from \"./imagePanel/view\";\nimport { PageTiles } from \"./pageTiles/view\";\nimport { PageTilesBsyc } from \"../../components/tiles/bsyc/view\";\nimport { SingleBanner } from \"./singleBanner/view\";\nimport { ContactForm } from \"./contactForm/view\";\nimport { VideoPanel } from \"./VideoPanel/view\";\nimport { Code } from \"./code/view\";\nimport { BlogPosts } from \"./blogPosts/view\";\nimport { BlogPostTitle } from \"./blogPostTitle/view\";\nimport { VideoHolder } from \"./videoHolder/view\";\nimport { VideoItem } from \"./videoItem/view\";\nimport { MultiColumnPanel } from \"./multiColumnPanel/view\";\nimport { ExpandableHtml } from \"./expandableHtml/view\";\nimport { PhotoGallery } from \"../../components/photoGallery/view\";\nimport { TestimonialPanel } from \"../../components/testimonial/index\";\nimport { ExpandablePanel } from \"../../components/expandablePanel/view\";\nimport { VideoPanelWithText } from \"./VideoPanelWithText/view\";\nimport { MultiColumnPanelNew } from \"./multiColumnPanelNew/view\";\n\n//import { PrintShare } from './printShare/view';\n\nexport function Item(props) {\n  const item = props.item;\n  const cmsOption = props.cmsOption || {};\n\n  //console.log('item', item, cmsOption);\n\n  let itemElt = null;\n\n  const found = utils.array.find(items, (x) => x.match(item, cmsOption));\n  //console.log(found)\n  if (found) {\n    return found.itemElt(item, cmsOption);\n  }\n\n  if (item.itemTypeCode === \"Panel\") {\n    itemElt = <Panel item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"Html\") {\n    itemElt = <Html item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"BannerPanel\") {\n    itemElt = <BannerPanel item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"BannerItem\") {\n    itemElt = <BannerItem item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"TestimonialPanel\") {\n    const setting = {\n      startRatingColor: \"#2b707d\",\n    };\n    itemElt = (\n      <TestimonialPanel item={item} cmsOption={cmsOption} {...setting} />\n    );\n  } else if (item.itemTypeCode === \"ImagePanel\") {\n    itemElt = <ImagePanel item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"PageTiles\") {\n    let _tileType = cmsUtils.payload(item, \"TileType\");\n    const tileType = _tileType && _tileType !== \"\" ? _tileType : \"1\";\n    if (tileType === \"2\") {\n      itemElt = <PageTiles item={item} cmsOption={cmsOption} />;\n    } else {\n      itemElt = <PageTilesBsyc item={item} cmsOption={cmsOption} />;\n    }\n  } else if (item.itemTypeCode === \"SingleBanner\") {\n    itemElt = <SingleBanner item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"ContactForm\") {\n    itemElt = <ContactForm item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"VideoPanel\") {\n    itemElt = <VideoPanel item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"Code\") {\n    itemElt = <Code item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"Blog-Posts\") {\n    itemElt = <BlogPosts item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"Blog-PostTitle\") {\n    itemElt = <BlogPostTitle item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"MultiColumnPanel\") {\n    itemElt = <MultiColumnPanel item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"ExpandableHtml\") {\n    itemElt = <ExpandableHtml item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"VideoHolder\") {\n    itemElt = <VideoHolder item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"VideoItem\") {\n    itemElt = <VideoItem item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"PhotoGallery\") {\n    itemElt = <PhotoGallery item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"ExpandablePanel\") {\n    itemElt = <ExpandablePanel item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"VideoPanelWithText\") {\n    itemElt = <VideoPanelWithText item={item} cmsOption={cmsOption} />;\n  } else if (item.itemTypeCode === \"MultiColumnPanelNew\") {\n    itemElt = <MultiColumnPanelNew item={item} cmsOption={cmsOption} />;\n  } else {\n    itemElt = <div>{item.itemTypeCode}</div>;\n  }\n\n  // const subItemsElts = subItems.map((subItem, index) =>\n  //   <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  // );\n  return itemElt;\n}\n","import React, { useState, useEffect } from 'react';\nimport { useRouter } from '../../../components';\nimport { useGet } from '../../../components';\nimport { Item } from '../../items/item';\nimport { NotFound } from '../../../components';\nimport env from '../../../env';\nimport { useStore } from '../../../store';\nimport { ErrorPopup, Loading } from '../../../components';\nimport { useInstagram } from '../../../components';\nimport { MetaTag } from '../../../components';\nimport cmsUtils from '../../utils/cmsUtils';\nimport utils from '../../../utils';\nimport { gtm } from '../../../lib/tracking';\n\nconst log = (...args) => {\n  //console.log(args);\n}\nconst areEqual = (prevProps, nextProps) => {\n  return (prevProps.pageData === nextProps.pageData)\n};\nconst PageMemo = React.memo(Page, areEqual)\n\nexport function ViewPage() {\n  const { dispatch } = useStore();\n  const [pageLoaded, setPageLoaded] = useState(false);\n  const [data, setData] = useState(null);\n  //const path = usePath();\n  //log('view page', path);\n  const { pathname, Redirect } = useRouter();\n  useInstagram();\n\n  const get = useGet();\n  log('0. viewpage ready');\n\n  useEffect(() => {\n    log('*. start loading')\n    setPageLoaded(false);\n    get.send(env.apiBase + \"/api/cms/GetPublishedPage?path=\" + pathname);\n    // eslint-disable-next-line\n  }, [pathname]);\n\n  useEffect(() => {\n    if (data){\n      dispatch({ type: 'SET_PAGE', payload: data.data })\n      dispatch({ type: 'SET_MENU', payload: data.menu })\n    }\n    // eslint-disable-next-line\n  }, [data]);\n\n  if (get.loading()) {\n    return <Loading />\n  } else if (get.hasErrors()) {\n    return <ErrorPopup title=\"Loading Error\" errors={get.errors} />\n  }\n\n  //log(router.pathname);\n  //log(get.loading());\n  log('1. viewpage component', pageLoaded, get.response);\n\n\n  const pageData = get.response.data;\n  //const menuData = get.response.menu;\n  const redirectTo = get.response.redirectTo;\n\n  const cmsOption = {};\n  log(pageLoaded, !pageLoaded && !!pageData)\n  if (!pageLoaded && pageData) {\n    //log(pageLoaded, pageData, menuData)\n    log('2. dispatching page & menu')\n    setPageLoaded(true);\n    setData(get.response);\n    document.title = pageData.pageTitle;\n    gtm.pageView(pathname, pageData.pageTitle);\n    return null;\n  } else if (redirectTo) {\n    if (redirectTo.indexOf('http') >= 0 && typeof window !== `undefined`) {\n      return window.location.href = redirectTo;\n    } else {\n      return <Redirect to={redirectTo} />\n    }\n  } else if (!pageLoaded && !pageData) {\n    setPageLoaded(true);\n    setData(get.response);\n    return (<NotFound />)\n  }\n\n  log('3. call rendering memo')\n  if (pageData)\n  return <PageMemo pageData={pageData} cmsOption={cmsOption} />;\n  else\n    return <NotFound />\n}\n\n\nfunction Page(props) {\n  const pageData = props.pageData;\n  const cmsOption = props.cmsOption;\n  cmsOption.pageData = pageData;\n  // document.title = pageData.pageTitle;\n  log('4. page rendering', pageData, cmsOption)\n  const sectionItems = pageData.sections.map((section, index) => {\n    return (\n      <Section item={section} key={section.sectionName + index} cmsOption={cmsOption}></Section>\n    )\n  }\n  );\n  return (\n    <>\n      <MetaTag data={getMetaTag(pageData)} />\n      <div className={`cmsPage cmsPage--${pageData.pageTypeCode}`}>\n        {sectionItems}\n      </div>\n    </>\n  );\n}\n\nfunction Section(props) {\n  log('5. section rendering')\n  const item = props.item;\n  //const sectionName = item.sectionName;\n  const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n  if (!subItems || subItems.length === 0)\n    return (<></>);\n\n  const subItemsElts = subItems.map((subItem, index) =>\n    <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  );\n  return (\n    <>\n      {subItemsElts}\n    </>\n  );\n}\n\nfunction getMetaTag(pageData) {\n  //const country = utils.site.isNZ? 'New Zealand' : 'Australia'\n  const country = \"Australia\";\n  const siteName = env.siteName;\n  const titleSuffix = env.titleSuffix;\n\n  return {\n    title: pageData.pageTitle + ' | ' + titleSuffix,\n    description: cmsUtils.payload(pageData, 'Description'),\n    keywords: cmsUtils.payload(pageData, 'Keyword'),\n    heroImageUrl: utils.site.fullUrl(cmsUtils.payload(pageData, 'ImageUrl')),\n    language: 'English',\n    country: country,\n    siteName: siteName,\n    url: utils.site.fullUrl(pageData.pageUrl),\n    //canonical: utils.site.resourcePath(pageData.pageUrl)\n  }\n}","import React from 'react';\r\nimport { loadJs } from '../../lib/net-loader';\r\n\r\nexport function useInstagram() {\r\n  const [embedStatus, setEmbedStatus] = React.useState(null);\r\n\r\n  React.useEffect(() => {\r\n    loadEmbedJs()\r\n  })\r\n\r\n  function loadEmbedJs() {\r\n    if (typeof window !== `undefined`) {\r\n      //console.log('instgrm effect', embedStatus, window.instgrm);\r\n      if (window.instgrm) {\r\n        window.instgrm.Embeds.process();\r\n      }\r\n      else if (!embedStatus && embedStatus !== 'loading') {\r\n        setEmbedStatus('loading');\r\n        loadJs(\"https://www.instagram.com/embed.js\").then(data => {\r\n          //console.log('instgrm loaded', data);\r\n          if (window.instgrm) {\r\n            window.instgrm.Embeds.process();\r\n            setEmbedStatus('loaded');\r\n          }\r\n        })\r\n      }\r\n    }\r\n  }\r\n\r\n  return { loadEmbedJs: loadEmbedJs }\r\n}","//import { CmsPageController } from './cms-page-controller'\n\nexport class CmsRadioSender {\n  controller;//: CmsPageController;\n  constructor(controller) {\n    this.controller = controller;\n  }\n\n  sendMessageToParent(action: string, data: any) {\n    var cloned = JSON.parse(JSON.stringify(data));\n    if (typeof window !== `undefined`) {\n      window.parent.postMessage({\n        action: action,\n        data: cloned\n      }, \"*\");\n    }\n  }\n\n  saveAllDirtyHtml(htmlChanges) {\n    // skip another unneccesary round trip\n    this.sendMessageToParent('return-all-dirty-html', {\n      returnTo: '_saveAllDirtyHtml',\n      htmlChanges: htmlChanges\n    });\n  }\n\n  selectControllerItem(data) {\n    this.sendMessageToParent(\"select-controller-item\", data);\n  }\n\n  returnAllDirtyHtml(returnTo, htmlChanges) {\n    this.sendMessageToParent('return-all-dirty-html', {\n      returnTo: returnTo,\n      htmlChanges: htmlChanges\n    });\n  }\n\n  returnHtml(id, html) {\n    this.sendMessageToParent('return-html', {\n      id: id,\n      html: html\n    });\n  }\n\n  markDirtyHtml(id) {\n    this.sendMessageToParent(\"mark-dirty-html-item\", { id: id });\n  }\n}\n","//declare var CKEDITOR: any;\n//import { CmsPageController } from './cms-page-controller'\n\nexport class CmsRadioReceiver {\n  controller;//: CmsPageController;\n  constructor(controller) {\n    this.controller = controller;\n    this.init();\n  }\n\n  init() {\n    if (typeof window !== `undefined`) {\n      var self = this;\n      window.addEventListener(\"message\", function (e) {\n\n        var action = e.data.action;\n        var data = e.data.data;\n\n        // console.log(e, \"cms-action-received: \" + action, data);\n\n        if (action === 'select-item') {\n          self.selectItem(data.itemId)\n        } else if (action === 'media-selected-ckeditor') {\n          self.mediaSelectedCKEditor(data)\n        } else if (action === 'get-all-dirty-html') {\n          var htmlChanges = self.controller.getAllDirtyHtml();\n          self.controller.sender.returnAllDirtyHtml(data.returnTo, htmlChanges);\n        } else if (action === 'get-html') {\n          var html = self.controller.getHtml(data.id, data.itemName);\n          self.controller.sender.returnHtml(data.id, html);\n        } else if (action === 'page-reload') {\n          window.location.reload();\n        }\n      }, false);\n    }\n  }\n\n  mediaSelectedCKEditor(data) {\n    const CKEDITOR = window['CKEDITOR'] || {};\n    CKEDITOR.tools.callFunction(data.funcNum, data.selectedPath);\n  }\n\n  selectItem(itemId) {\n    this.controller.selectItemFromController(itemId);\n  }\n}\n","import { CmsRadioSender } from \"./cms-radio-sender\";\n// //import * as $ from 'jquery';\n// declare var CKEDITOR: any;\n// import * as $ from 'jquery';\n\nexport class CmsHtmlEditor {\n  ckeditorConfig;\n  ckeditorStylesSet;\n  sender;\n  constructor(cmsEndpoint: string, sender: CmsRadioSender) {\n    this.ckeditorConfig = {\n      startupFocus: true,\n      filebrowserBrowseUrl:\n        cmsEndpoint + \"/cms41helper/browse/selectpageormedia\", //'/cms/browse',//'/cms/resource/selectfileckeditor',\n      filebrowserImageBrowseUrl:\n        cmsEndpoint + \"/cms41helper/browse/selectmedia\", //'/cms/browse?type=rc',//'/cms/resource/selectfileckeditor?type=Images',\n      extraPlugins:\n        \"sourcedialog,youtubejaba,lineutils,widget,embedjaba,image2\",\n      toolbar: [\n        {\n          name: \"basicstyles\",\n          groups: [\"basicstyles\", \"cleanup\"],\n          items: [\n            \"Bold\",\n            \"Italic\",\n            \"Underline\",\n            \"Strike\",\n            \"Subscript\",\n            \"Superscript\",\n            \"-\",\n            \"RemoveFormat\",\n          ],\n        },\n        {\n          name: \"paragraph\",\n          groups: [\"list\", \"align\"],\n          items: [\n            \"NumberedList\",\n            \"BulletedList\",\n            \"-\",\n            \"JustifyLeft\",\n            \"JustifyCenter\",\n            \"JustifyRight\",\n            \"JustifyBlock\",\n          ],\n        },\n        {\n          name: \"links\",\n          items: [\"Link\", \"Unlink\", \"Anchor\"],\n        },\n        {\n          name: \"insert\",\n          items: [\n            \"Image\",\n            \"Table\",\n            \"HorizontalRule\",\n            \"PageBreak\",\n            \"Iframe\",\n            \"Youtube\",\n            \"EmbedJaba\",\n          ],\n        },\n        \"/\",\n        {\n          name: \"document\",\n          groups: [\"mode\"],\n          items: [\"Sourcedialog\"],\n        },\n        {\n          name: \"clipboard\",\n          groups: [\"clipboard\", \"undo\"],\n          items: [\n            \"Cut\",\n            \"Copy\",\n            \"Paste\",\n            \"PasteText\",\n            \"PasteFromWord\",\n            \"-\",\n            \"Undo\",\n            \"Redo\",\n          ],\n        },\n        {\n          name: \"styles\",\n          items: [\"Styles\", \"Format\"],\n        },\n        {\n          name: \"colors\",\n          items: [\"TextColor\", \"BGColor\"],\n        },\n        {\n          name: \"tools\",\n          items: [\"Maximize\", \"ShowBlocks\"],\n        },\n      ],\n      extraAllowedContent: \"style;span;*[id,rel,data-*](*){*}\",\n    };\n\n    this.ckeditorStylesSet = [\n      /* Block Styles */\n\n      // These styles are already available in the \"Format\" combo (\"format\" plugin),\n      // so they are not needed here by default. You may enable them to avoid\n      // placing the \"Format\" combo in the toolbar, maintaining the same features.\n      /*\n      { name: 'Paragraph',\t\telement: 'p' },\n      { name: 'Heading 1',\t\telement: 'h1' },\n      { name: 'Heading 2',\t\telement: 'h2' },\n      { name: 'Heading 3',\t\telement: 'h3' },\n      { name: 'Heading 4',\t\telement: 'h4' },\n      { name: 'Heading 5',\t\telement: 'h5' },\n      { name: 'Heading 6',\t\telement: 'h6' },\n      { name: 'Preformatted Text',element: 'pre' },\n      { name: 'Address',\t\t\telement: 'address' },\n      */\n      { name: \"Title\", attributes: { \"class\": \"title\" } },\n      // { name: 'Heading 3', element: 'h1', attributes: { 'class': 'h3' } },\n      // { name: 'Super paragraph',\t\telement: 'p', attributes: { 'class': 'superparagraph' } },\n\n      //{ name: 'Italic Title',\t\telement: 'h2', styles: { 'font-style': 'italic' } },\n      //{ name: 'Subtitle',\t\t\telement: 'h3', styles: { 'color': '#aaa', 'font-style': 'italic' } },\n      //{\n      //\tname: 'Special Container',\n      //\telement: 'div',\n      //\tstyles: {\n      //\t\tpadding: '5px 10px',\n      //\t\tbackground: '#eee',\n      //\t\tborder: '1px solid #ccc'\n      //\t}\n      //},\n\n      /* Inline Styles */\n\n      // These are core styles available as toolbar buttons. You may opt enabling\n      // some of them in the Styles combo, removing them from the toolbar.\n      // (This requires the \"stylescombo\" plugin)\n      /*\n      { name: 'Strong',\t\t\telement: 'strong', overrides: 'b' },\n      { name: 'Emphasis',\t\t\telement: 'em'\t, overrides: 'i' },\n      { name: 'Underline',\t\telement: 'u' },\n      { name: 'Strikethrough',\telement: 'strike' },\n      { name: 'Subscript',\t\telement: 'sub' },\n      { name: 'Superscript',\t\telement: 'sup' },\n      */\n\n      //{ name: 'Marker',\t\t\telement: 'span', attributes: { 'class': 'marker' } },\n\n      //{ name: 'Big',\t\t\t\telement: 'big' },\n      //{ name: 'Small',\t\t\telement: 'small' },\n      //{ name: 'Typewriter',\t\telement: 'tt' },\n\n      //{ name: 'Computer Code',\telement: 'code' },\n      //{ name: 'Keyboard Phrase',\telement: 'kbd' },\n      //{ name: 'Sample Text',\t\telement: 'samp' },\n      //{ name: 'Variable',\t\t\telement: 'var' },\n\n      //{ name: 'Deleted Text',\t\telement: 'del' },\n      //{ name: 'Inserted Text',\telement: 'ins' },\n\n      //{ name: 'Cited Work',\t\telement: 'cite' },\n      //{ name: 'Inline Quotation',\telement: 'q' },\n\n      //{ name: 'Language: RTL',\telement: 'span', attributes: { 'dir': 'rtl' } },\n      //{ name: 'Language: LTR',\telement: 'span', attributes: { 'dir': 'ltr' } },\n\n      /* Object Styles */\n      { name: \"Button\", element: \"a\", attributes: { \"class\": \"button\" } },\n      {\n        name: \"Primary Button\",\n        element: \"a\",\n        attributes: { \"class\": \"p-button\" },\n      },\n      {\n        name: \"Secondary Button\",\n        element: \"a\",\n        attributes: { \"class\": \"s-button\" },\n      },\n      {\n        name: \"Third Button\",\n        element: \"a\",\n        attributes: { \"class\": \"t-button\" },\n      },\n      {\n        name: \"Fourth Button\",\n        element: \"a\",\n        attributes: { \"class\": \"fourth-btn\" },\n      },\n      { name: \"More link\", element: \"a\", attributes: { \"class\": \"more\" } },\n      //{\n      //\tname: 'Styled image (left)',\n      //\telement: 'img',\n      //\tattributes: { 'class': 'left' }\n      //},\n\n      //{\n      //\tname: 'Styled image (right)',\n      //\telement: 'img',\n      //\tattributes: { 'class': 'right' }\n      //},\n\n      //{\n      //\tname: 'Compact table',\n      //\telement: 'table',\n      //\tattributes: {\n      //\t\tcellpadding: '5',\n      //\t\tcellspacing: '0',\n      //\t\tborder: '1',\n      //\t\tbordercolor: '#ccc'\n      //\t},\n      //\tstyles: {\n      //\t\t'border-collapse': 'collapse'\n      //\t}\n      //},\n\n      //{ name: 'Borderless Table',\t\telement: 'table',\tstyles: { 'border-style': 'hidden', 'background-color': '#E6E6FA' } },\n      //{ name: 'Square Bulleted List',\telement: 'ul',\t\tstyles: { 'list-style-type': 'square' } }\n    ];\n\n    this.sender = sender;\n  }\n\n  show($editor) {\n    const CKEDITOR = window[\"CKEDITOR\"] || {};\n    //for ckeditor\n    // console.log('ckeditor show');\n    try {\n      // We need to turn off the automatic editor creation first.\n      CKEDITOR.disableAutoInline = true;\n    } catch (e) {}\n\n    var editor = CKEDITOR.inline(\"cmsCurrentEditor\", this.ckeditorConfig);\n    if (!CKEDITOR.stylesSet.get(\"default\"))\n      CKEDITOR.stylesSet.add(\"default\", this.ckeditorStylesSet);\n\n    var self = this;\n    editor.on(\"change\", function (evt) {\n      // getData() returns CKEditor's HTML content.\n      //$(\"#cmsCurrentEditor\").addClass(\"dirtyHtml\");\n      //const itemId = $(\"#cmsCurrentEditor\").data('cms-item-id');\n      const ed = document.querySelector(\"#cmsCurrentEditor\");\n      ed.classList.add(\"dirtyHtml\");\n      const itemId = ed.getAttribute(\"data-cms-item-id\");\n\n      //console.log(itemId);\n      self.sender.markDirtyHtml(itemId);\n      //console.log('Total bytes: ' + evt.editor.getData().length);\n    });\n    editor.on(\n      \"paste\",\n      function (evt) {\n        //console.log(evt.data.dataValue);\n        //evt.data.dataValue = evt.data.dataValue.replace(/&nbsp;/g, '');\n        //evt.data.dataValue = evt.data.dataValue.replace(/<p><\\/p>/g, '');\n        //editor.insertHtml(evt.data.dataValue); return false;\n        setTimeout(function () {\n          CKEDITOR.instances.cmsCurrentEditor.setData(\n            CKEDITOR.instances.cmsCurrentEditor.getData()\n          );\n        }, 100);\n      },\n      null,\n      null,\n      9\n    );\n  }\n\n  close($editor = null) {\n    const CKEDITOR = window[\"CKEDITOR\"] || {};\n    //console.log('ckeditor close');\n    if (typeof CKEDITOR.instances.cmsCurrentEditor != \"undefined\")\n      CKEDITOR.instances.cmsCurrentEditor.destroy();\n\n    //for (var instance in CKEDITOR.instances) {\n    //    CKEDITOR.instances[instance].destroy();\n    //}\n  }\n}\n","import { CmsRadioSender } from './cms-radio-sender'\nimport { CmsRadioReceiver } from './cms-radio-receiver'\nimport { CmsHtmlEditor } from './cms-html-editor'\nimport env from '../../env';\n\n// declare var CKEDITOR: any;\n// import * as $ from 'jquery';\n\n\nexport class CmsPageController {\n  settings;//: any;\n  sender;//: CmsRadioSender;\n  receiver;//: CmsRadioReceiver;\n  htmlEditor;//: CmsHtmlEditor;\n\n  constructor() {\n    this.settings = { root: \"body\", viewOnly: false };\n    this.sender = new CmsRadioSender(this);\n    this.receiver = new CmsRadioReceiver(this);\n    this.htmlEditor = new CmsHtmlEditor(env.cmsEndpoint, this.sender);\n  }\n  init(options) {\n    const $ = window['jQuery'];\n    this.settings = Object.assign({}, /*default*/{ root: \"body\", viewOnly: false }, options);\n    this.initGlobalVars();\n\n    var self = this;\n    $(\"[onclick]\").prop(\"onclick\", null);\n    $(\"[dblclick]\").prop(\"dblclick\", null);\n    $(self.settings.root).off(\"click dblclick\", \"*\");\n    $(self.settings.root).on(\"click dblclick\", \"*\", function (e) {\n      //$(\".cms_html_editor_img_selected\").removeClass(\"cms_html_editor_img_selected\");\n      //                console.log($(e.target).hasClass(\"allowClick\"));\n      //                console.log(e.target);\n\n      if (!$(e.target).hasClass(\"allowClick\")) {\n        e.stopPropagation();\n        e.preventDefault();\n      }\n\n      if ($(this).attr(\"contenteditable\") === \"true\" ||\n        $(\"#cms_html_editor_source_id\").is(\":visible\")) {\n        e.stopPropagation();\n        return;\n      }\n      if (!self.settings.viewOnly)\n        self.selectItem($(this), false, e.type === \"dblclick\");\n\n      //Add noreferrer noopener when new window\n      $(\"#cke_108_select\").change(function () {\n        let _value = $(this).val();\n        $(\"#cke_215_textInput\").val(\"\");\n        if (_value === \"_blank\") {\n          $(\"#cke_215_textInput\").val(\"noreferrer noopener\");\n        }\n      });\n\n    });\n\n    if (self.settings.viewOnly) return; // stop the editing logic for viewonly mode.\n\n    // ctrl + s for html block\n    $(self.settings.root).on('keydown', \"#cmsCurrentEditor\", function (e) {\n      if (e.ctrlKey && e.which === 83) {\n        //var itemId = $(this).data(\"cms-item-id\");\n        //if (!itemId)\n        //    itemId = $(this).closest(\"[data-cms-item-id]\").data(\"cms-item-id\");\n        //window.parent.cms.site.saveHtml(itemId);\n        //e.preventDefault();\n\n        self.sender.saveAllDirtyHtml(self.getAllDirtyHtml());\n        return false;\n      }\n    });\n  }\n\n  selectItemFromController(id) {\n    const $ = window['jQuery'];\n    var item = $(\".cms_item[data-cms-item-id='\" + id + \"']\");\n    this.scrollTo(item);\n    this.selectItem(item, true);\n  }\n\n  selectItem($item, fromController, doubleclicked = false) {\n    //console.log(\"select item - \" + fromController + \" - \" + doubleclicked);\n    //console.log($item);\n    var editor = $item.closest(\"[contenteditable]\");\n    if (editor.length > 0)\n      return;\n    var cke_top = $item.closest(\".cke_top\");\n    if (cke_top.length > 0)\n      return;\n\n    this.closeEditingItem();\n    //console.log($item);\n    if (typeof $item === \"undefined\") return;\n    if ($item.length === 0) return;\n    this.findItem($item, fromController, 0, doubleclicked);\n  }\n\n  closeEditingItem() {\n    const $ = window['jQuery'];\n    //console.log(\"close editing item\");\n    $(\"[contenteditable]\").removeAttr(\"contenteditable\");\n    $(\"#cms_hovermenu\").remove();\n    $(\".cms_editing_item\").removeClass(\"cms_editing_item\");\n\n  }\n\n  findItem($item, fromController, depth, doubleclicked) {\n    const $ = window['jQuery'];\n    if (depth > 100) return false;\n    // console.log($item, fromController, depth, doubleclicked)\n    if (typeof $item.attr(\"data-cms-html\") !== \"undefined\" && $item.attr(\"data-cms-html\") === \"true\") {\n      $item.attr(\"contenteditable\", \"true\");\n      this.showHtmlEditor($item);\n    }\n    if (typeof $item.attr(\"data-cms-item-id\") !== \"undefined\") {\n      //$item.attr(\"contenteditable\", \"true\");\n      $item.addClass(\"cms_editing_item\");\n      if($item.hasClass(\"multiColumnPanelv2\")){\n        //$(\".cms_item[data-cms-item-id='\" + itemid + \"']\")\n        $item.find(\"div.new__multicolumn__panel__html\").each(function(index){\n          $(this).addClass(\"cms_editing_item\");\n        });\n      }\n\n      if (!fromController) {\n        //window.parent.cms.site.selectControllerItem($item.attr(\"data-cms-item-id\"),\n        //    typeof doubleclicked != \"undefined\" && doubleclicked == true\n        //);\n        this.sender.selectControllerItem({\n          id: $item.attr(\"data-cms-item-id\"),\n          openEdit: typeof doubleclicked !== \"undefined\" && doubleclicked === true\n        });\n      }\n      //show_hovermenu($item);\n    } else {\n      var editableParent = $item.parents(\".cms_item[data-cms-item-id], [data-cms-html]\");\n      if (editableParent.length > 0)\n        this.findItem(editableParent.first(), fromController, depth + 1, doubleclicked);\n\n    }\n  }\n\n  sameContent(a, b) {\n    return a === b;\n  }\n\n  showHtmlEditor($item) {\n    const $ = window['jQuery'];\n    var editor = $item;\n    //console.log(editor);\n    //var $menu = $(\"#cms_html_editor_ctrl\");\n    ////$menu.css(\"top\", $item.offset().top - 40);\n    ////$menu.css(\"left\", $item.offset().left);\n    //$menu.show();\n    //initHtmlEditor($item);\n\n    if (editor.attr(\"id\") === \"cmsCurrentEditor\") return;\n\n    $(\"#cmsCurrentEditor\").attr(\"id\", \"\");\n    this.htmlEditor.close(editor);\n\n\n    if (editor.hasClass(\"new__multicolumn__panel__html\")){\n      //$item.attr(\"data-cms-item-id\")\n      var dataCmsItemId2 = editor.attr(\"data-cms-item-id2\");\n      $(\"div.cms_item[data-cms-item-id2='\" + dataCmsItemId2 + \"']\").attr(\"data-cms-item-id\", \"\");\n      editor.attr(\"data-cms-item-id\", dataCmsItemId2);\n    }\n\n    editor.attr(\"id\", \"cmsCurrentEditor\");\n    //editor.data(\"current-content\", editor.html());\n    \n    this.htmlEditor.show(editor);\n    //setHandlers($item);\n\n  }\n\n  initGlobalVars() {\n    const $ = window['jQuery'];\n    window[\"cmsPage\"] = $.extend({}, window[\"cmsPage\"] || {}, {\n      htmleditor: {\n        // cmsPage.htmleditor.getAnchors();\n        getAnchors: function (opt) {\n          //var options = $.extend({}, opt);\n          //console.log(options);\n          var anchors = [];\n\n          $(\"a[name]\").each(function (inx, obj) {\n            anchors.push({ id: $(obj).attr(\"id\"), name: $(obj).attr(\"name\") });\n          });\n\n          $(\"[data-cms-item-name],[data-cms-anchor]\").each(function (inx, obj) {\n            if (typeof $(obj).attr(\"data-cms-anchor\") !== \"undefined\" && $(obj).attr(\"data-cms-anchor\") !== \"\" && $(obj).parents(\".owl-item\").length === 0) {\n              anchors.push({ id: null, name: $(obj).attr(\"data-cms-anchor\") });\n            } else if ($(obj).attr(\"data-cms-item-name\") !== \"\" && $(obj).parents(\".owl-item\").length === 0) {\n              anchors.push({ id: null, name: $(obj).attr(\"data-cms-item-name\") });\n            }\n          });\n\n          return anchors;\n        }\n      }\n    });\n  }\n\n  scrollTo(target) {\n    const $ = window['jQuery'];\n    if (typeof target === \"undefined\") return;\n    if ($(target).length === 0) return;\n    var htmlbody = $('html,body');\n    var top = 0;\n    if ($(target).height() > $(window).height())\n      top = $(target).offset().top;\n    else {\n      top = $(target).offset().top - Math.floor(($(window).height() - $(target).height()) / 2);\n    }\n    //console.log(top);\n    //htmlbody.animate({ scrollTop: top }, 500, 'easeInOutQuint');\n    htmlbody.animate({ scrollTop: top }, 500);\n  }\n\n  getCurrentHtml() {\n    const CKEDITOR = window['CKEDITOR'] || {};\n    try {\n      return CKEDITOR.instances.cmsCurrentEditor.getData();\n    } catch (e) { return \"\"; }\n  }\n\n  getAllDirtyHtml() {\n    const $ = window['jQuery'];\n    var self = this;\n    var htmlChanges = [];\n    $(\".dirtyHtml\").each(function (inx, obj) {\n      var $section = $(obj);\n      var content = $section.is(\"#cmsCurrentEditor\") ? // if the html editor is active, it needs to get the html from the editor.\n        self.getCurrentHtml() : $section.html();\n      if ($section.is(\"[data-cms-section-id]\")) {\n        // section level?\n        let $item = $section.closest(\"[data-cms-item-id]\");\n        htmlChanges.push({ ItemId: $item.data(\"cms-item-id\"), SectionId: $section.data(\"cms-section-id\"), Content: content });\n      } else if ($section.is(\"[data-cms-item-id]\")) {\n        // section level?\n        let $item = $section;\n        if ($item.hasClass(\"new__multicolumn__panel__html\")) {          \n          htmlChanges.push({\n            ItemId: $item.data(\"cms-item-id\"),\n            SectionId: \"Content\",\n            SectionId2: \"Content2\",\n            Content: $(\".cms_item.item__01[data-cms-item-id2='\" + $item.data(\"cms-item-id2\") + \"']\").html(),\n            Content2: $(\".cms_item.item__02[data-cms-item-id2='\" + $item.data(\"cms-item-id2\") + \"']\").html()\n          });\n        }\n        else {\n          htmlChanges.push({ ItemId: $item.data(\"cms-item-id\"), SectionId: \"Content\", Content: content });\n        }\n      }\n    });\n    return htmlChanges;\n  }\n\n  getHtml(itemid: any ) {\n    const $ = window['jQuery'];\n    this.htmlEditor.close();\n    var self = this;\n\n    var item = $(\".cms_item[data-cms-item-id='\" + itemid + \"']\");\n    var formvals = { Content: this.cms_replace_item_html(item) };\n\n    if (item.hasClass(\"new__multicolumn__panel__html\")){\n      formvals = {\n        Content: this.cms_replace_item_html($(\".cms_item.itme__01[data-cms-item-id='\" + itemid + \"']\")),\n        Content2: this.cms_replace_item_html($(\".cms_item.itme__02[data-cms-item-id='\" + itemid + \"']\")),\n      };\n    }\n\n    //cms_msg_progressing(\"#save_message\", \"Saving...\");\n    if ($(\"[data-cms-section-id]\", item).length > 0) {\n      $(\"[data-cms-section-id]\", item).each(function (inx, section) {\n        var closestItemId = $(section).closest(\".cms_item\").data(\"cms-item-id\");\n        if (closestItemId === itemid) {\n          var id = $(section).attr(\"data-cms-section-id\");\n          formvals[id] = self.cms_replace_item_html($(section)); //.find(\">:first-child\")().html();\n        }\n      });\n    }\n    return formvals;\n  }\n\n  cms_replace_item_html(item) {\n    return item.html();\n    // var $tmp = $(\"<div></div>\").html(item.html());\n    // if ($tmp.find('.cms-skeleton').length > 0)\n    //   return $tmp.find('.cms-skeleton').html();\n    // else\n    //   return item.html();\n    //tmp.find(\".cms_ctrl_in_editor\").each(function (inx, obj) {\n    //    var ctrlid = $(obj).attr(\"data-cms-ctrl-id\");\n    //    $(obj).replaceWith(\"__cms__ctrl:\" + ctrlid + \"__\");\n    //});\n    //return tmp.html();\n  }\n\n}\n","import React, { useEffect } from 'react';\nimport { useRouter } from '../../../components';\nimport { useGet } from '../../../components';\nimport { Item } from '../../items/item';\nimport env from '../../../env';\nimport { loadJs } from '../../../lib/net-loader';\nimport { CmsPageController } from '../../services/cms-page-controller';\nimport { ErrorPopup, Loading } from '../../../components';\n\n// function useQuery() {\n//   return new URLSearchParams(useLocation().search);\n// }\n\nexport function EditPage(props) {\n  //const [page, setPage] = useState(null);\n\n  //const pageId = props.pageId;\n  const { query } = useRouter();\n  const { cmsViewMode = 'edit', id, publishVer, editVer } = query;\n  const pageId = id;\n\n  //console.log(pageId, cmsViewMode, env.apiBase, env)\n\n  const get = useGet();\n  useEffect(() => {\n    get.send(env.apiBase + '/api/cms/GetPage/' + pageId + '?cmsViewMode=' + cmsViewMode\n      + (publishVer ? '&publishVer=' + publishVer : '')\n      + (editVer ? '&editVer=' + editVer : '')\n    );\n    // eslint-disable-next-line\n  }, [pageId]);\n\n  if (get.loading()) {\n    return <Loading />\n  } else if (get.hasErrors()) {\n    return <ErrorPopup title=\"Loading Error\" errors={get.errors} />\n  }\n\n  //console.log(router.pathname);\n  //console.log(res);\n\n  const pageData = get.response.data;\n  const cmsOption = { isCmsEdit: true, cmsViewMode: cmsViewMode };\n  cmsOption.pageData = pageData;\n\n  const cmsPageController = new CmsPageController();\n  if (cmsViewMode !== 'viewonly') {\n    const ver = 1;\n    loadJs(\n      env.resourceBase + '/dist/jquery-3.4.1/jquery.min.js?v=' + ver\n    ).then(data => {\n      return loadJs(\n        env.resourceBase + '/dist/cms/ckeditor/ckeditor.js?v=' + ver\n      )\n    }).then(data => {\n      // console.log('script loaded ', data);\n      cmsPageController.init({});\n      document.querySelector('body').classList.add('cmsedit');\n    }).catch(error => console.log(error));\n  } else {\n    const ver = 1;\n    loadJs(\n      env.resourceBase + '/dist/jquery-3.4.1/jquery.min.js?v=' + ver\n    ).then(data => {\n      cmsOption.isCmsEdit = false;\n      cmsPageController.init({ viewOnly: true });\n    }).catch(error => console.log(error));\n  }\n\n  //setPage(res.response.data);\n  const sectionItems = pageData.sections.map((section, index) =>\n    <Section item={section} key={section.sectionName + index} cmsOption={cmsOption}></Section>\n  );\n  return (\n    <div className={`cmsPage cmsPage--${pageData.pageTypeCode}`}>\n      {sectionItems}\n    </div>\n  );\n}\n\n\nfunction Section(props) {\n  const item = props.item;\n  //const sectionName = item.sectionName;\n  const subItems = item.items || [];\n  const cmsOption = props.cmsOption || {};\n\n  if (!subItems || subItems.length === 0)\n    return (<></>);\n\n  const subItemsElts = subItems.map((subItem, index) =>\n    <Item item={subItem} key={subItem.itemId} cmsOption={cmsOption}></Item>\n  );\n  return (\n    <>\n      {subItemsElts}\n    </>\n  );\n}\n\n","import React from \"react\";\nimport { SiteLink } from \"../../components\";\n\nexport function GlobalNav(props) {\n  return (\n    <>\n      <div id=\"globalNav\">\n        <div className=\"globalNav_top\">\n          <div className=\"globalNav_top_content\">\n            <div className=\"globalNav_main\">\n              <a href=\"/products\">PRODUCTS & PRICING</a>\n              <div className=\"globalNav_sub\">\n                <div className=\"globalNav_sub_products\">\n                  <a href=\"/products/wall-mounted-whole-house-water-filtration-system\">\n                    <div>\n                      <img\n                        src=\"/assets/Wall_Mounted_Top_Nav.jpg\"\n                        width=\"100%\"\n                        alt = \"Wall_Mounted_Top_Nav\"\n                      />\n                    </div>\n                    Wall Mounted System\n                  </a>\n                  <a href=\"/products/above-ground-whole-house-water-filtration-system\">\n                    <div>\n                      <img\n                        src=\"/assets/Above_Ground_Top_Nav3.jpg\"\n                        width=\"100%\"\n                        alt = \"Above_Ground_Top_Nav\"\n                      />\n                    </div>\n                    Above Ground System\n                  </a>\n                  <a href=\"/products/below-ground-whole-house-water-filtration-system\">\n                    <div>\n                      <img\n                        src=\"/assets/Below_Ground_Top_Nav.jpg\"\n                        width=\"100%\"\n                        alt = \"Below_Ground_Top_Nav\"\n                      />\n                    </div>\n                    Below Ground System\n                  </a>\n                  <a href=\"/products/reverse-osmosis-under-sink-water-filtration-system\">\n                    <div>\n                      <img\n                        src=\"/assets/Reverse_Osmosis_Top_Nav_2.jpg\"\n                        width=\"100%\"\n                        alt = \"Reverse_Osmosis_Top_Nav\"\n                      />\n                    </div>\n                    Reverse Osmosis\n                  </a>\n                </div>\n              </div>\n            </div>\n\n            <div className=\"globalNav_main\">\n              <a href=\"/benefits\">BENEFITS</a>\n              <div className=\"globalNav_sub\">\n                <div className=\"globalNav_sub_benefits\"></div>\n              </div>\n            </div>\n\n            <div className=\"globalNav_main\">\n              <a href=\"/servicing\">ANNUAL SERVICING</a>\n              <div className=\"globalNav_sub\">\n                <div className=\"globalNav_sub_servicing\"></div>\n              </div>\n            </div>\n            <div className=\"globalNav_main\">\n              <a href=\"/reviews\">REVIEWS</a>\n              <div className=\"globalNav_sub\">\n                <div className=\"globalNav_sub_reviews\"></div>\n              </div>\n            </div>\n\n            <div className=\"globalNav_main\">\n              <a href=\"/faq\">COMMON QUESTIONS</a>\n              <div className=\"globalNav_sub\">\n                <div className=\"globalNav_sub_faq\"></div>\n              </div>\n            </div>\n\n            {/* <a className=\"button\" href=\"/contact\">\n              <span>CONTACT</span>\n            </a> */}\n            \n            <a href=\"https://calendly.com/info-40816\" target=\"_blank\" rel=\"noopener noreferrer\" className=\"button\">\n              <span>Book Online</span>\n            </a>\n            {/*<SiteLink to=\"#calendly\"\t className = 'button'>\n              <span>Book Online</span>\n            </SiteLink>*/}\n\n            <a href=\"tel:+61-08-8359-8821\" className=\"button\">\n              <span>08 8359 8821</span>\n            </a>\n          </div>\n        </div>\n      </div>\n    </>\n  );\n}\n","import React, {useState, useEffect} from 'react';\nimport { SiteLink } from '../../components';\nimport { useStore } from '../../store';\n\nimport { FaChevronDown } from 'react-icons/fa';\n//import { SearchBar } from './searchBar';\n\nexport function NavBar(props) {\n  const open = props.open;\n  //const currentLocation = props.currentLocation;\n  const { state } = useStore();\n\n  const menu = state.menu || { items: [] };\n  const currentLocation = state.history && state.history.length > 0? state.history[state.history.length - 1].path : '';\n  const depth = 1;\n  const menuItemElts = menu.items.map((item, index) =>\n    <MenuItem item={item} key={index} depth={depth} onCloseMenu={props.onCloseMenu} currentLocation={currentLocation}></MenuItem>\n  );\n  return (\n    <div className={`navBar ${open ? 'navBar--on' : ''}`} id=\"sliding-menu\">\n      {/* <SearchBar onCloseMenu={props.onCloseMenu}/> */}\n      <div className=\"navBar__scrollArea\" id=\"top-menu\">\n        <nav className=\"navBar_nav\">\n          <ul>\n            {menuItemElts}\n          </ul>\n        </nav>\n      </div>\n\n    </div>);\n\n}\n\nfunction MenuItem(props) {\n  const [subMenuOpened, setSubMenuOpened] = useState(false);\n  const item = props.item;\n  const subItems = item.items || [];\n  const currentLocation = props.currentLocation;\n\n  const subItemsElts = subItems.length > 0? subItems.map((subItem, index) =>\n    <SubMenuItem item={subItem} key={index} onCloseMenu={props.onCloseMenu} />\n  ) : null;\n\n\n  useEffect(() => {\n    //console.log('navbar', currentLocation);\n    setSubMenuOpened(false);\n  }, [currentLocation])\n\n  function closeMenu() {\n    props.onCloseMenu();\n  }\n\n  function toggleSubmenu(e) {\n    e.preventDefault();\n    e.stopPropagation();\n    setSubMenuOpened(!subMenuOpened);\n  }\n\n  return (\n    <li className={`navBar__item ${subMenuOpened ? 'navBar__item--open' : ''}`}>\n      <SiteLink className=\"navBar__link\" to={item.url} onClick={() => closeMenu()}>\n        <span>{item.title}</span>\n        {subItemsElts && <span className=\"navBar__icon\" onClick={(e) => toggleSubmenu(e)}><FaChevronDown /></span>}\n      </SiteLink>\n      {subItemsElts &&\n        <ul className={`navBar__subMenu`}>\n          {subItemsElts}\n        </ul>}\n    </li>\n  )\n}\n\nfunction SubMenuItem(props) {\n  const item = props.item;\n  function closeMenu() {\n    props.onCloseMenu();\n  }\n\n  return (\n    <li className=\"navBar__subItem\">\n      <SiteLink className=\"navBar__subLink\" to={item.url} onClick={() => closeMenu()}>\n        <span>{item.title}</span>\n      </SiteLink>\n    </li>\n  )\n}","import { css } from \"@emotion/core\";\nimport { mq } from \"../../cssInJs\";\nexport default {\n  button: css(\n    mq({\n      position: \"absolute\",\n      left: \"1rem\",\n      lineHeight: \"1.6rem\",\n      color: \"#666\",\n      fontSize: [\"12px\", null, \"15px\"],\n    })\n  ),\n};\n","/** @jsx jsx */\nimport { jsx } from '@emotion/core';\nimport { SiteLink } from '../../components';\nimport { FaAngleLeft } from 'react-icons/fa';\nimport { useHistoryStore } from '../../components';\nimport style from './backButtonStyle';\n\nexport function BackButton(props) {\n\n  const history = useHistoryStore();\n\n  function goBack(e) {\n    history.pop();\n  }\n\n  if (history.last()) {\n    return (<SiteLink css={style.button} title=\"Go Back\" to={history.last()} onClick={goBack} >\n      <FaAngleLeft />\n    </SiteLink>)\n  } else {\n    return null;\n  }\n}","import { css } from \"@emotion/core\";\nimport { mq } from \"../../cssInJs\";\n\nconst rs = [\n  // { w: 44, h: 44, barW: 28, barH: 3, space: 8 },\n  { w: 56, h: 56, barW: 44, barH: 3, space: 10 },\n  { w: 56, h: 56, barW: 44, barH: 3, space: 10 },\n];\n\nconst line = css(\n  mq({\n    width: [rs[0].barW, null, rs[1].barW],\n    height: [rs[0].barH, null, rs[1].barH],\n    borderRadius: \"4px\",\n    position: \"absolute\",\n    transitionProperty: \"transform\",\n    backgroundColor: \"#fff\",\n    display: \"block\",\n    transitionDuration: \"0.15s\",\n    transitionDelay: \"0.15s\",\n    transitionTimingFunction: \"cubic-bezier(0.55, 0.055, 0.675, 0.19)\",\n  })\n);\n\nexport default {\n  button: css(\n    mq({\n      cursor: \"pointer\",\n      zIndex: \"1000\",\n      position: \"fixed\",\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n      transition: \"all 0.3s ease-in-out\",\n      padding: \"0\",\n      // top: [0, 0, 0, \"60px\"],\n      width: [rs[0].w, null, rs[1].w],\n      //height: [rs[0].h, null, rs[1].h],\n      height: [null, null, rs[1].h],\n\n      right: [0, null, 20],\n      background: \"black\", //variables.primaryColor,\n      border: \"none\",\n      outline: \"none\",\n      font: \"inherit\",\n      color: \"inherit\",\n      textTransform: \"none\",\n      \"&:focus\": {\n        outline: \"none\",\n      },\n    })\n  ),\n\n  buttonScrolled: css(\n    mq({\n      // top: [0, 0, 0, \"60px\"],\n    })\n  ),\n\n  hamburger: css(\n    mq({\n      width: [rs[0].barW, null, rs[1].barW],\n      height: [\n        rs[0].barH + rs[0].space * 2,\n        null,\n        rs[1].barH + rs[1].space * 2,\n      ],\n      position: \"relative\",\n      display: \"block\",\n    })\n  ),\n\n  line1: css(\n    mq(line, {\n      top: 0,\n      transition:\n        \"top 0.3s 0.1s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0.1s 0.1s linear\",\n    })\n  ),\n  line2: css(\n    mq(line, {\n      transition:\n        \"top 0.12s 0.3s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.15s cubic-bezier(0.55, 0.055, 0.675, 0.19)\",\n      top: [rs[0].space, null, rs[1].space],\n    })\n  ),\n  line3: css(\n    mq(line, {\n      top: [rs[0].space * 2, null, rs[1].space * 2],\n    })\n  ),\n\n  lineActive1: css({\n    opacity: \"0\",\n    top: 18,\n    transition:\n      \"top 0.3s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0.2s linear\",\n  }),\n  lineActive2: css({\n    transform: \"rotate(-135deg)\",\n    transition:\n      \"top 0.12s 0.18s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.15s 0.42s cubic-bezier(0.215, 0.61, 0.355, 1)\",\n  }),\n  lineActive3: css(\n    mq({\n      transform: [\n        `translate3d(0, -${rs[0].space}px, 0) rotate(-45deg)`,\n        null,\n        `translate3d(0, -${rs[1].space}px, 0) rotate(-45deg)`,\n      ],\n      transitionDelay: \"0.32s\",\n      transitionTimingFunction: \"cubic-bezier(0.215, 0.61, 0.355, 1)\",\n    })\n  ),\n};\n","/** @jsx jsx */\nimport { jsx } from '@emotion/core'\nimport style from './hamburgerStyle';\n\nexport function Hamburger({ opened, toggleMenu, scrolled }) {\n\n  return <button css={[style.button, scrolled && style.buttonScrolled]} type=\"button\" aria-label=\"Menu\" onClick={toggleMenu}>\n    <span css={style.hamburger}>\n      <span css={[style.line1, opened && style.lineActive1]}></span>\n      <span css={[style.line2, opened && style.lineActive2]}></span>\n      <span css={[style.line3, opened && style.lineActive3]}></span>\n    </span>\n  </button>\n}","import { css } from \"@emotion/core\";\nimport { mq } from \"../../cssInJs\";\n\nexport default {\n  top: css(\n    mq({\n      //height: [44, null, 80],\n      height: [44, null, 56],\n      background: \"black\",\n      position: \"fixed\",\n      width: \"100%\",\n      zIndex: \"1100\",\n      display: \"flex\",\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      transition: \"all 0.3s\", \n      // top: [0, 0, 0, \"60px\"],\n    })\n  ),\n  topScrolled: css(\n    mq({\n      //height: [44, null, 56],\n      // background: \"white\",\n    })\n  ),\n  logo: css(mq({})),\n  logoImg: css(\n    mq({\n      display: \"block\",\n      position: \"absolute\",\n      left: 20,\n      top: 10,\n      height: [30, null, 40],\n      zIndex: 1000\n      // marginTop: [\"3rem\", null, \"3.5rem\"],\n      // transition: \"all .2s\",\n    })\n  ),\n  logoScrolled: css(\n    mq({\n      img: css(\n        mq({\n          // height: [38, null, 50],\n          // marginTop: \"0rem\",\n        })\n      ),\n    })\n  ),\n  phone: css(\n    mq({\n      position: \"absolute\",\n      right: [70, null, 80],\n      top: [10, null, 14],\n      zIndex: 1000,\n    })\n  ),\n  phoneIcon: css(\n    mq({\n      img: css(\n        mq({\n          width: [25, null, 30],\n          display: [\"block\", \"block\", \"block\", \"block\", \"none\", \"none\"],\n        })\n      ),\n    })\n  ),\n};\n","/** @jsx jsx */\nimport { jsx } from \"@emotion/core\";\n\nimport { useState, Fragment } from \"react\";\nimport { SiteLink } from \"../../components\";\nimport { useScrollPosition } from \"@n8tb1t/use-scroll-position\";\nimport { NavBar } from \"./navBar\";\nimport { BackButton } from \"../backButton/backButton\";\nimport { Hamburger } from \"../hamburger/hamburger\";\nimport style from \"./topHeaderStyle\";\nimport { GlobalNav } from \"layout/globalNav/globalNav\";\n\nexport function TopHeader(props) {\n  const [menuOpened, setMenuOpened] = useState(false);\n  // eslint-disable-next-line\n  const [scrolled, setScrolled] = useState(false);\n\n  useScrollPosition(\n    ({ prevPos, currPos }) => {\n      //console.log(currPos.x)\n      //console.log(currPos.y);\n      if (currPos.y > 90) {\n        setScrolled(true);\n      } else {\n        setScrolled(false);\n      }\n      //setScrolled(currPos.y > 90)\n    },\n    [],\n    null,\n    true\n  );\n\n  function toggleMenu(e) {\n    setMenuOpened(!menuOpened);\n  }\n\n  function onCloseMenu() {\n    setMenuOpened(false);\n  }\n\n  function backTop() {\n    window.scrollTo({ top: 0, behavior: \"smooth\" });\n  }\n\n  return (\n    <Fragment>\n      <header css={[style.top]} id='top'>\n        <BackButton />\n        <SiteLink to='/' onClick={backTop}>\n          <img css={style.logoImg} src={\"/assets/logos/logo.png\"} alt='logo' />\n        </SiteLink>\n        <GlobalNav />\n        <a href=\"tel:+61-08-8359-8821\" css={style.phone}>\n              <span css={style.phoneIcon}><img  src=\"/assets/icons/telephone-symbol-button-green.png\" alt=\"phone\"></img></span>\n        </a>\n        <Hamburger\n          opened={menuOpened}\n          toggleMenu={toggleMenu}\n          // scrolled={scrolled}\n        />\n        <NavBar open={menuOpened} onCloseMenu={onCloseMenu}></NavBar>\n      </header>\n    </Fragment>\n  );\n}\n","import Hammer from '@egjs/hammerjs'\nimport { gsap } from 'gsap';\n\nexport default class BottomDrawer {\n  constructor(el, options = {}) {\n    const defaults = {};\n    this.settings = Object.assign({}, defaults, options);\n    this.slider = el;\n\n    // location\n    this.currentTranslateY = 0;\n    this.size = null;\n    this.status = 'collapsed';\n    this.inititialised = false;\n    this.tsEventHandled = new Date();\n  }\n\n  init() {\n    this.size = this.getSize(this.slider);\n    //console.log(this.size)\n    const initialStatus = localStorage.getItem('bottomDrawerStatus') || 'expanded'\n    if (initialStatus === 'expanded')\n      this.open();\n    else\n      this.close();\n\n    this.showHidePaddingBar();\n\n    //\n    const hammer = new Hammer.Manager(this.slider);\n    hammer.add(new Hammer.Pan({ direction: Hammer.DIRECTION_VERTICAL, threshold: 0 }));\n\n    hammer.on('panstart pan panend', e => {\n      //console.log(e.type, e)\n      if (e.type === 'panend') {\n        this.switch(e.deltaY);\n      } else if (e.type === 'pan') {\n        this.moveDeltaTmp(e.deltaY)\n      }\n    });\n\n    this.initEvent();\n  }\n\n  initEvent() {\n    const bar = this.slider.querySelector('.bottomMenu__bar');\n    if (this.inititialised) {\n      bar.removeEventListener('click', (e) => this.handleClick(e, this))\n    }\n    bar.addEventListener('click', (e) => this.handleClick(e, this))\n    this.inititialised = true;\n  }\n\n  handleClick(e, self) {\n    e.preventDefault();\n    e.stopPropagation();\n    const dt = (new Date()) - this.tsEventHandled;\n    //console.log('handleClick', dt);\n\n    if (dt < 100) return;\n    self.switch();\n  }\n\n  moveDeltaTmp(delta){\n    const y = this.getBaseY() + delta;\n    //console.log(y,delta)\n\n    this.currentTranslateY = y < 0? 0 : (y > this.size.max ? this.size.max : y);\n    this.move(this.currentTranslateY);\n  }\n\n  switch(delta){\n    this.tsEventHandled = new Date();\n    if ((delta < 0 && this.status === 'expanded') || (delta > 0 && this.status === 'collapsed')) return;\n    const targetY = this.getTargetY();\n    //console.log('return', this.currentTranslateY, targetY)\n    \n    gsap.fromTo(this.slider, {y: this.currentTranslateY}, {duration: 0.3, y: targetY, ease: 'power1'});\n    this.status = this.status === 'collapsed'? 'expanded' : 'collapsed';\n    this.setStatus();\n    \n    this.currentTranslateY = targetY;\n\n    this.showHidePaddingBar();\n  }\n\n  getBaseY() {\n    return this.status === 'collapsed'? this.size.max : this.size.min;\n  }\n\n  getTargetY() {\n    return this.status === 'collapsed'? this.size.min : this.size.max;\n  }\n\n  getSize(el) {\n    const links = el.querySelector('.bottomMenu__links');\n    const bar = el.querySelector('.bottomMenu__bar');\n    return { min: 0, max: links.offsetHeight, barHeight: bar.offsetHeight };\n  }\n\n  move(dy) {\n    this.slider.style.transform = `translate3d(0, ${dy}px, 0)`;\n  }\n\n  setStatus() {\n    localStorage.setItem('bottomDrawerStatus', this.status)\n  }\n\n  close() {\n    this.status = 'collapsed';\n    this.setStatus();\n    this.currentTranslateY = this.size.max;\n    this.move(this.currentTranslateY);\n  }\n\n  open() {\n    this.status = 'expanded';\n    this.setStatus();\n    this.currentTranslateY = this.size.min;\n    this.move(this.currentTranslateY);\n  }\n\n  showHidePaddingBar(){  \n    if(this.status === 'collapsed'){\n      console.log('close');\n      document.querySelector(\".bottomMenuPadding\").style.display = \"block\";\n      //this.slider.style.bottom = \"10px\";\n      this.slider.classList.add(\"bottomMenuShowOrHide\");\n    }\n    else{\n      console.log('open');\n      document.querySelector(\".bottomMenuPadding\").style.display = \"none\";\n      this.slider.classList.remove(\"bottomMenuShowOrHide\");\n      //this.slider.style.bottom = \"0px\";\n    }\n  }\n\n}\n\n\n//.bottomMenu","import React, { useLayoutEffect, useRef } from \"react\";\nimport { useRouter } from \"../../components\";\nimport { SiteLink } from \"../../components\";\nimport BottomDrawer from \"../../components/bottomDrawer\";\n\nexport function BottomDock(props) {\n  const links = [\n    {\n      url: \"/products\",\n      title: \"PRODUCTS & PRICING\",\n      icon: \"navicon-white.png\",\n      iconHover: \"navicon-white.png\",\n    },\n    {\n      url: \"/benefits\",\n      title: \"BENEFITS\",\n      icon: \"navicon-white.png\",\n      iconHover: \"navicon-white.png\",\n    },\n    {\n      url: \"/servicing\",\n      title: \"ANNUAL SERVICING\",\n      icon: \"navicon-white.png\",\n      iconHover: \"navicon-white.png\",\n    },\n    {\n      url: \"/reviews\",\n      title: \"REVIEWS\",\n      icon: \"navicon-white.png\",\n      iconHover: \"navicon-white.png\",\n    },\n    {\n      url: \"/faq\",\n      title: \"COMMON QUESTIONS\",\n      icon: \"navicon-white.png\",\n      iconHover: \"navicon-white.png\",\n    }\n  ];\n\n  //const path = usePath();\n  const { pathname } = useRouter();\n\n  const isCurrent = (link) => {\n    return pathname && pathname.toLowerCase() === link.toLowerCase();\n  };\n\n  const linkElts = links.map((link, index) => (\n    <li\n      key={index}\n      className={`bottomMenu__li ${isCurrent(link.url) ? \"selected\" : \"\"}`}\n    >\n      <SiteLink\n        to={link.url}\n        className={`bottomMenu__link bottomMenu__link--${index}`}\n      >\n        <div className=\"icon\">\n          <img\n            className=\"normal\"\n            src={`/assets/navicons/${link.icon}`}\n            alt={link.title}\n          />\n          <img\n            className=\"selected\"\n            src={`/assets/navicons/${link.iconHover}`}\n            alt={link.title}\n          />\n        </div>\n        <div>{link.title}</div>\n      </SiteLink>\n    </li>\n  ));\n\n  const bottomMenu = useRef(null);\n  useLayoutEffect(() => {\n    console.log(\"useLayoutEffect\");\n    const slider = new BottomDrawer(bottomMenu.current);\n    setTimeout(() => slider.init(), 1000);\n  }, []);\n\n  return (\n    <>\n      <nav\n        className=\"bottomMenu bottomMenuShowOrHide\"\n        ref={bottomMenu}\n        style={{\n          transform: \"translate(0px, 90px)\",\n          touchAction: \"pan-x\",\n          userSelect: \"none\",\n        }}\n      >\n        <div className=\"bottomMenu__bar\">\n          <div className=\"bottomMenu__line1\"></div>\n          <div className=\"bottomMenu__line2\"></div>\n        </div>\n        <ul className=\"bottomMenu__links\">{linkElts}</ul>\n      </nav>\n      <div className=\"bottomMenuPadding\"></div>\n    </>\n  );\n}\n","import React from 'react';\nimport { useStore } from '../../store';\nimport FsLightbox from 'fslightbox-react';\n\nexport function CommonVideoPopup(props) {\n  const { state } = useStore();\n\n  const [toggler, setToggler] = React.useState(false);\n  const [sources, setSources] = React.useState([]);\n  const [popupIndex, setPopupIndex] = React.useState(0);\n\n  const popup = state.popup;\n  //console.log(popup, JSON.stringify((popup && popup.sources) || []), JSON.stringify(sources), (popup && popup.popupIndex), popupIndex)\n  if (JSON.stringify((popup && popup.sources) || []) !== JSON.stringify(sources) ||\n    ((popup && popup.popupIndex) || 0) !== popupIndex) {\n    setSources(popup.sources);\n    setPopupIndex(popup.popupIndex);\n    setTimeout(() => { setToggler(!toggler) }, 10)\n  } else {\n\n  }\n  //console.log(toggler, popupIndex, sources)\n  return (\n    <div className=\"\">\n      <FsLightbox\n\n        toggler={toggler}\n        sources={sources}\n        key={popupIndex}\n        onOpen={(e) => {\n        }}\n      />\n    </div>\n\n  );\n}","import React from 'react';\nimport { useRouter } from './components';\nimport { useHistoryStore } from './components';\nimport { useParallax } from './components';\nimport utils from './utils';\n\nexport function AppRouteChanged() {\n  const { path } = useRouter();\n  const parallax = useParallax();\n  const history = useHistoryStore();\n  \n  React.useLayoutEffect(() => {\n    console.log('route changed', path)\n    if (typeof window !== `undefined`) {\n      parallax.reset();\n      const hash = window.location.hash;\n      history.push({path: path})\n  \n      if (hash) { \n        setTimeout(() => {\n          const anchor = utils.ui.findElement(hash);\n          if (anchor)\n            utils.ui.scrollTo(anchor, 500);\n        }, 500)\n      } else {\n        window.scrollTo(0, 0);\n      }\n    }\n    // eslint-disable-next-line\n  }, [path]);\n\n  return null;\n}","import React, { useEffect } from \"react\";\nimport {\n  BrowserRouter as Router,\n  Switch,\n  Route,\n  Redirect,\n} from \"react-router-dom\";\nimport { useRouter } from \"./components\";\nimport { StoreProvider } from \"./store\";\nimport { ViewPage } from \"./cms/pages/viewPage/viewPage\";\nimport { EditPage } from \"./cms/pages/editPage/editPage\";\n// eslint-disable-next-line\nimport { GlobalNav } from \"./layout/globalNav/globalNav\";\nimport { TopHeader } from \"./layout/topHeader/topHeader\";\n// import { Footer } from './layout/footer/footer';\nimport { BottomDock } from \"./layout/bottomDock/bottomDock\";\n// import { BlogView } from './site/blog/blogView';\nimport { AppVersionPage } from \"./components\";\nimport { MediaQueryStatus } from \"./components\";\nimport { CommonVideoPopup } from \"./layout/popup/commonVideoPopup\";\nimport { HelmetProvider } from \"react-helmet-async\";\n//import { useScrollPosition } from '@n8tb1t/use-scroll-position';\nimport { AppRouteChanged } from \"./AppRouteChanged\";\nimport AOS from \"aos\";\n\n//For ECM\n// import { ProductView } from './site/ecm/product/productView';\n// import { OrderDetails } from './site/ecm/orderDetails/orderDetails';\n// import env from './env';\n// import { useStore } from './store';\n\nfunction AppLayout(props) {\n  const { pathname } = useRouter();\n\n  //For ECM\n  //const storeContext = useRef(useStore());\n\n  //const [scrolled, setScrolled] = useState(false)\n  //const path = usePath();\n  //const routeResult = useRoutes(routes);\n\n  // const parallax = useParallax();\n  // //console.log(path, routeResult);\n  // const routeChanged = (path) => {\n  //   //console.log(path);\n  //   parallax.reset();\n  // }\n\n  // useScrollPosition(({ prevPos, currPos }) => {\n  //   //console.log(currPos.x)\n  //   //console.log(currPos.y);\n  //   if (currPos.y > 90) {\n  //     document.querySelector('body').classList.add('scrolled')\n  //   } else {\n  //     document.querySelector('body').classList.remove('scrolled')\n  //   }\n  //   //setScrolled(currPos.y > 90)\n  // }, [], null, true)\n\n  //const pageChanged = useCallback(path => routeChanged(path), [])\n  //useLocationChange((path) => { routeChanged(path, history)})\n  //useLocationChange(path => routeChanged(path))\n\n  //const pathFiltered = (pathname || '').toLocaleLowerCase();\n  let specialClassName = \"\";\n  //  if (pathFiltered.indexOf('/digital-sensor') >= 0) specialClassName = 'digital-sensor-page';\n  //  else if (pathFiltered === '/brilliance') specialClassName = 'brilliance-page';\n\n  useEffect(() => {\n    AOS.init({\n      duration: 1200,\n      //delay:400,\n      //once:true\n    });\n\n    // For ECM\n    // fetch(env.apiBase + \"/api/cart/getcart/\" + env.getDevCartId())\n    //   .then(res => res.json())\n    //   .then(res => {\n    //       const data = res;\n    //       if(data){\n    //         storeContext.current.dispatch({type:'SET_STATE', payload : {cartInfo : data.cartInfo.totalQuantity === 0 ? 0 : (data.cartInfo.totalQuantity)-1}});\n    //       }\n    //   })\n    //   .catch(error =>{\n    //     storeContext.current.dispatch({type:'SET_STATE', payload : {cartInfo : 0}});\n    // });\n\n    console.log(\"TEST STG\");\n  }, []);\n\n  // useLayoutEffect(() => {\n\n  //   const interval = setInterval(() => {\n  //     console.log('This will run every second!');\n  //     const _iframe = document.querySelector(\"iframe[title='chat widget']\");\n  //     if(_iframe){\n  //       _iframe.style.top = \"calc((50% - 20px) + 0px)\";\n  //       _iframe.style.display = \"none\";\n  //       _iframe.classList.add(\"override\");\n  //       clearInterval(interval);\n  //     }\n\n  //   }, 1000);\n  //   return () => clearInterval(interval);\n\n  // }, []);\n\n  return (\n    <div\n      className={`body-content ${\n        pathname === \"/\" ? \"homepage\" : \"subpage\"\n      } ${specialClassName}`}\n    >\n      <AppRouteChanged />\n      {/*<GlobalNav></GlobalNav>*/}\n      <TopHeader></TopHeader>\n      <div className='main-content'>\n        <div className='app-content'>\n          <Switch>\n            <Route path='/ver' children={<AppVersionPage />} />\n            <Route path='/cms/page/render/:id' children={<EditPage />} />\n            {/* <Route path=\"/blog/:id\" children={<BlogView />} /> */}\n\n            <Route path='/admin'>\n              <Redirect to='/admin' />\n            </Route>\n\n            {/* For ECM <Route path=\"/order-thankyou\" children = {<OrderDetails />}/>\n            <Route path=\"/product/:slug\" children = {<ProductView />}/> */}\n\n            <Route path='/'>\n              <ViewPage />\n            </Route>\n          </Switch>\n        </div>\n        {/* <app-common-bottom-partial></app-common-bottom-partial> */}\n      </div>\n      {/* <Footer></Footer> */}\n      <BottomDock></BottomDock>\n      <MediaQueryStatus />\n      <CommonVideoPopup />\n    </div>\n  );\n}\n\nfunction App() {\n  return (\n    <StoreProvider>\n      <HelmetProvider>\n        <Router>\n          <AppLayout />\n        </Router>\n      </HelmetProvider>\n    </StoreProvider>\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\nlet serviceUpdateCheckerInterval = null;\n\nexport function register(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(process.env.PUBLIC_URL, window.location.href);\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, config) {\n  navigator.serviceWorker\n    .register(swUrl, {updateViaCache: 'none'})\n    .then(async registration => {\n      // https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerRegistration\n      console.log('Service Worker registration successful with scope: ', registration.scope);\n      if (registration && registration.waiting) {\n        registration.waiting.postMessage({ type: 'SKIP_WAITING' });\n      }\n      \n      // Regular checking service worker\n      if (serviceUpdateCheckerInterval) { try { clearInterval(serviceUpdateCheckerInterval) } catch (e) { } }\n      serviceUpdateCheckerInterval = setInterval(() => {\n        console.log('Checking SW updates...')\n        registration.update();\n      }, 1/*hour(s)*/ * 10/*minutes*/ * 60 * 1000);\n\n      window.updateSW = function() {\n        console.log('Checking SW updates... (force)')\n        return registration.update();\n      }\n      \n      // When the user asks to refresh the UI, we'll need to reload the window\n      var preventDevToolsReloadLoop = false;\n      \n      const oldSw = (await navigator.serviceWorker.getRegistration())?.active?.state;\n      console.log(oldSw, registration)\n      navigator.serviceWorker.addEventListener('controllerchange', async function (ev) {\n        const newSw = (await navigator.serviceWorker.getRegistration())?.active?.state;\n        console.log('Service Worker controller change', ev)\n        console.log(oldSw, newSw)\n        // Ensure refresh is only called once.\n        // This works around a bug in \"force update on reload\".\n        if (preventDevToolsReloadLoop) return;\n        \n\n        if(oldSw === 'activated' && newSw === 'activating') {\n          preventDevToolsReloadLoop = true;\n          console.log('Reloading...')\n          window.location.reload();\n        }\n\n        //window.location.reload();\n      });\n\n      // onNewServiceWorker(registration, function () {\n      //   console.log('onNewServiceWorker', registration)\n      //   alert('New Update Available');\n        \n      //   console.log('User okay to update', registration);\n      //   if (!registration.waiting) {\n      //     // Just to ensure registration.waiting is available before calling postMessage()\n      //     return;\n      //   }\n      //   registration.waiting.postMessage({ type: 'SKIP_WAITING' });\n\n      //   console.log('show refresh')\n      // });\n      \n      registration.onupdatefound = () => {\n        console.log('registration.onupdatefound', registration.installing)\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  navigator.serviceWorker.ready.then(function (registration) {\n    console.log('Service Worker ready');\n  });\n}\n\n\n// function onNewServiceWorker(registration, callback) {\n//   if (registration.waiting) {\n//     console.log('onNewServiceWorker-registration.waiting')\n//     // SW is waiting to activate. Can occur if multiple clients open and one of the clients is refreshed.\n//     return callback();\n//   }\n\n//   function listenInstalledStateChange() {\n//     console.log('listenInstalledStateChange', registration.installing)\n//     registration.installing.addEventListener('statechange', function (event) {\n//       console.log('listenInstalledStateChange - statechange', event)\n//       if (event.target.state === 'installed') {\n//         // A new service worker is available, inform the user\n//         callback();\n//       }\n//     });\n//   };\n\n//   if (registration.installing) {\n//     console.log('onNewServiceWorker-registration.installing')\n//     return listenInstalledStateChange();\n//   }\n\n//   // We are currently controlled so a new SW may be found...\n//   // Add a listener in case a new SW is found,\n//   registration.addEventListener('updatefound', listenInstalledStateChange);\n// }\n\n\nfunction checkValidServiceWorker(swUrl, 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            console.log('Reloading... No SW found')\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.then(registration => {\n      registration.unregister();\n    });\n  }\n}\n","import 'react-app-polyfill/ie11';\nimport 'react-app-polyfill/stable';\nimport './polyfill';\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport './_scss/index.scss';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\n\nReactDOM.render(<App />, document.getElementById('root'));\n//ReactDOM.hydrate(<App />, document.getElementById('root'));\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.register({\n  onUpdate: (registration) => {\n    console.log('updated', registration);\n    const update = true;//window.confirm('New Update Available. Do you want to update? (Refresh page)');\n    if (update){\n      if (!registration.waiting) {\n        // Just to ensure registration.waiting is available before calling postMessage()\n        return;\n      }\n      registration.waiting.postMessage({ type: 'SKIP_WAITING' });\n \n    }\n  }\n});\n","const settings = {\n  //                         xs,    sm,    md,    lg,    xl,    xxl          <-- only sample, check your breakpoints settings.\n  //                         <      576    768    992    1200   1600\n  breakpointNames:          ['xs', 'sm',  'md',  'lg',  'xl',  'xxl'],\n  numOfTilesPerBreakpoints: [1,     2,     2,     2,     3,     3],\n  marginLR:                 [14,    20,    20,    20,    20,    20],\n  marginTB:                 [14,    20,    20,    20,    20,    20],\n  slickSettings: {\n    dots: false,\n    infinite: true,\n    speed: 500,\n    autoplaySpeed: 3000,\n    //fade: false,\n    autoplay: true,\n    slidesToShow: 3,\n    slidesToScroll: 1,\n    responsive: [\n      {\n        breakpoint: 1200,\n        settings: {\n          slidesToShow: 2,\n          slidesToScroll: 1\n        }\n      },\n      {\n        breakpoint: 576,\n        settings: {\n          slidesToShow: 1,\n          slidesToScroll: 1\n        }\n      }\n      // You can unslick at a given breakpoint now by adding:\n      // settings: \"unslick\"\n      // instead of a settings object\n    ]\n  }\n}\n\nexports.settings = settings"],"sourceRoot":""}