{"version":3,"sources":["images/cardIcons/06-c.png","images/background.jpg","images/do.png","images/it.png","images/technology.png","images/doTechnology.png","images/about.png","images/cardIcons/05-c.png","images/cardIcons/02-c.png","images/cardIcons/08-c.png","images/cardIcons/09-c.png","images/cardIcons/03-c.png","images/cardIcons/04-c.png","images/cardIcons/01-c.png","images/cardIcons/10.png","images/cardIcons/11.png","images/cardIcons/autodep.png","images/cardIcons/gcloud.png","images/cardIcons/flutter.png","images/cardIcons/blockchain.png","images/Artboard.png","images/airplane.png","images/projects/mobile.png","images/projects/mobile2.png","images/projects/taifho.png","images/projects/foto-01.png","images/projects/foto-03.png","images/projects/foto-05.png","images/projects/micro-management.png","images/projects/TimeLinePirate.png","images/projects/foto-02.png","images/projects/foto-04.png","images/projects/PersonalData.png","images/projects/Spar-09.png","images/projects/Treo.png","images/logo.png","images/logo-mobile.png","images/clients sync //.png$","images/clients/clients-01.png","images/clients/clients-02.png","images/clients/clients-03.png","images/clients/clients-04.png","images/clients/clients-05.png","images/clients/clients-06.png","images/clients/clients-07.png","images/clients/clients-08.png","images/clients/clients-09.png","images/clients/clients-10.png","images/clients/clients-11.png","images/clients/clients-12.png","images/clients/clients-13.png","images/clients/clients-14.png","images/clients/clients-15.png","images/clients/clients-16.png","images/clients/clients-17.png","images/clients/clients-18.png","images/clients/clients-19.png","images/clients/clients-20.png","images/clients/clients-21.png","images/clients/clients-22.png","images/clients/clients-23.png","images/clients/clients-24.png","i18n.js","components/GridBlock.js","const/RouterPath.js","pages/Home/ImageAnimation.js","pages/Home/Home.js","components/Header.js","components/Title.js","components/ContentContainer.js","pages/About/About.js","pages/Technologies/initialStateCard.js","components/TechnologiesCard.js","const/CardItems.js","images/pictogram/Stack.js","images/pictogram/Clouds.js","images/pictogram/Project.js","images/pictogram/Support.js","pages/Technologies/Technologies.js","pages/Skills/Skills.js","pages/Contact/Contact.js","images/pictogram/Email.js","images/pictogram/Phone.js","images/pictogram/Home.js","pages/Ribbon/Ribbon.js","components/TextInput.js","components/Checkbox.js","components/CheckboxGroup.js","components/Radio.js","components/RadioGroup.js","pages/Estimation/FormConstants.js","components/SendButton/SendButton.js","pages/Estimation/EstimationForm.js","pages/Estimation/Estimation.js","components/ImageDialog.js","components/Carousel/CarouselChildren.js","components/Carousel/Carousel.js","const/CarouselItems.js","pages/Projects/Projects.js","pages/Clients/Clients.js","pages/Home/HomeContent.js","components/Link.js","components/Links.js","pages/Footer/Footer.js","pages/MainContrainer.js","components/AppBar.js","components/ScrollToTopButton.js","pages/Root.js","theme/theme.js","App.js","serviceWorker.js","index.js"],"names":["module","exports","map","webpackContext","req","id","webpackContextResolve","__webpack_require__","o","e","Error","code","keys","Object","resolve","resources","en","translation","i18n","use","initReactI18next","init","lng","keySeparator","interpolation","escapeValue","GridBlock","_ref","direction","className","itemClassName","children","alignItems","spacing","justify","wrap","column","onClick","classes","flexGrow","xs","sm","md","lg","xl","other","elements","useMemo","React","Children","child","createElement","Grid","item","clsx","assign","container","defaultProps","memo","withStyles","theme","width","HOME","anchors","ABOUT","CONTACT","TECHNOLOGIES","ESTIMATION","PROJECTS","CLIENTS","useStyles","makeStyles","height","opacity","box","position","top","background","palette","primary","main","animationName","animationDuration","animationTimingFunction","itImage","zIndex","breakpoints","down","doTechnologyImage","props","redBoxHeight","setRedBoxHeight","useState","itImageRef","useRef","setHeight","offsetTop","current","useEffect","window","addEventListener","condition","alt","src","doImage","Box","style","margin","display","justifyContent","ref","Hidden","mdDown","technologyImage","contents","textAlign","button","fontSize","endIcon","transform","withWidth","t","useTranslation","handleClick","useCallback","scroll","scrollTo","document","getElementById","RouterPath","ImageAnimation","Typography","variant","Button","color","ReplyIcon","backgroundPosition","backgroundSize","backgroundImage","BackgroundImage","Switch","Route","exact","path","component","Home","marginBottom","paddingLeft","marginRight","title","toUpperCase","root","padding","only","paddingRight","childBox","maxResolution","maxResolutionMd","ContentContainer","alignContent","Title","about","flexDirection","marginTop","subContent","AboutImage","card1","card2","card3","card4","card","boxShadow","shadows","cardContent","avatarBox","avatar","fill","image","objectFit","text","whiteSpace","itemBox","cursor","filter","items","Avatar","open","setOpen","setState","initialStateCard","createList","x","i","key","icon","withCollapse","Collapse","in","timeout","unmountOnExit","CardUI","CardContent","version","xmlns","xlink","y","viewBox","space","d","uiUxIcon","reactIcon","nodeJsIcon","javeIcon","flutterIcon","blockchainIcon","azureIcon","awsIcon","gcloudIcon","scrumIcon","kanbanIcon","serverlessIcon","dockerIcon","autoDepIcon","flexBasis","idInterval","setTimeout","contains","target","clearTimeout","generateCards","tab","CardItems","forEach","push","TechnologiesCard","skills","skillText","trList","list","Parallax","bgImage","SkillsBackground","bgImageAlt","strength","contactTab","href","empty","blank","mainContainer","textDecoration","between","itemContainer","tabs","Icon","Fragment","length","Math","random","algin","RibbonBackground","formHelper","label","autoComplete","type","required","multiline","getFieldProps","getFieldMeta","useFormikContext","fieldMeta","name","onBlur","onChange","value","isError","error","touched","helperText","TextField","fullWidth","FormHelperText","disabled","checkboxClassName","labelClassName","setFieldValue","oldId","checkbox","CheckboxUI","checked","Boolean","FormControlLabel","undefined","control","formControl","checkboxList","Checkbox","FormControl","FormLabel","FormGroup","RadioUI","radioList","Radio","RadioGroupUI","idTab","likeList","scopeList","marginLeft","errorMail","buttonAnimation","buttonAnimationEnd","setButtonAnimationEnd","classList","toggle","add","timer","remove","CachedIcon","ErrorIcon","CheckIcon","group","up","setError","setErrorMail","setButtonAnimation","handleSubmit","values","resetForm","country","description","email","name_surname","phone","radio","consent","obj","like","scope","fetch","method","headers","body","JSON","stringify","then","response","status","statusText","json","createTextInput","TextInput","textInput","initialValuesMemo","initialValues","validationSchemaMemo","Yup","validateObj","oneOf","checkboxCounter","min","shape","Formik","validationSchema","onSubmit","Form","textInputBox","RadioGroup","CheckboxGroup","SendButton","estimation","lightBackground","cardBox","borderRadius","borderBottomLeftRadius","borderTopLeftRadius","borderBottomRightRadius","borderTopRightRadius","contentWrapper","EstimationForm","ThumbUpIcon","paperFullScreen","right","onClose","Dialog","fullScreen","handleClose","DialogTitle","IconButton","aria-label","closeButton","CloseIcon","contentContainer","paddingTop","animation","imageBox","CarouselChildren","activeItemIndex","setActiveItemIndex","openDialog","setOpenDialog","currentImage","setCurrentImage","moveLeft","moveRight","createChildren","content","createButton","func","smDown","ArrowBackIosIcon","ArrowForwardIosIcon","ImageDialog","dotted","grey","borderColor","dottedBox","currentDotted","Carousel","setTabsValue","postion","setPostion","setInterval","clearInterval","createDottedNavigation","range","swipeStart","changedTouches","clientX","swipeEnd","pos","onTouchStart","onTouchEnd","mobile1","mobile2","mobile3","web1","web2","web3","web4","web5","dedicated1","dedicated2","dedicated3","dedicated4","dedicated5","tabTab","Projects","tabsValue","itemsCounter","counter","CarouselItems","tab1Length","tab2Length","tab3Length","indexTab","slice","includes","TabPanel","index","createTabs","Tab","createTabPanels","_","Tabs","handleChange","event","newValue","imports","require","slideLength","maxWidth","itemsWrapper","firstRow","secondRow","clientsItems","setNumberOfCards","clients","ItemsCarousel","requestToChangeActive","numberOfCards","slidesToScroll","gutter","infiniteLoop","loading","About","Technologies","Skills","Ribbon","Clients","Estimation","Contact","to","routerLink","hash","location","pathname","scrollToTop","handleClickLinkRRD","handleClickLinkRS","LinkRRD","LinkRS","spy","smooth","offset","duration","activeClass","Link","footer","paddingBottom","linkBox","flexWrap","now","Date","Links","year","getFullYear","Header","HomeContent","Footer","appBar","transition","appBarScroll","toolbar","logo","logoScroll","elevation","handleImageClick","scrollRS","AppBarUI","Toolbar","LogoDoItMobile","LogoDoIt","lgUp","edge","menuButton","MenuIcon","Drawer","anchor","fab","bottom","Zoom","Fab","size","KeyboardArrowUpIcon","setScroll","windowSize","setWindowSize","scrollY","screen","availWidth","Helmet","AppBar","MainContrainer","ScrollToTopButton","createMuiTheme","secondary","typography","fontFamily","fontWeightLight","useNextVariants","cutLines","num","textOverflow","overflow","lineClamp","overrides","MuiBackdrop","backgroundColor","MuiDrawer","MuiTab","MuiAppBar","left","console","table","pjson","App","BrowserRouter","ThemeProviderUI","Root","hostname","match","ReactDOM","render","navigator","serviceWorker","ready","registration","unregister"],"mappings":"iGAAAA,EAAOC,QAAU,IAA0B,kC,+xHCA3CD,EAAOC,QAAU,IAA0B,wC,kBCA3CD,EAAOC,QAAU,8sF,kBCAjBD,EAAOC,QAAU,kuC,kBCAjBD,EAAOC,QAAU,0+O,kBCAjBD,EAAOC,QAAU,85U,oBCAjBD,EAAOC,QAAU,IAA0B,mC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,kBCA3CD,EAAOC,QAAU,ksK,kBCAjBD,EAAOC,QAAU,k6G,oBCAjBD,EAAOC,QAAU,IAA0B,gC,kBCA3CD,EAAOC,QAAU,8nR,oBCAjBD,EAAOC,QAAU,IAA0B,oC,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,wC,oBCA3CD,EAAOC,QAAU,IAA0B,sC,oBCA3CD,EAAOC,QAAU,IAA0B,sC,oBCA3CD,EAAOC,QAAU,IAA0B,oC,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,oC,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,8C,oBCA3CD,EAAOC,QAAU,IAA0B,4C,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,0C,oBCA3CD,EAAOC,QAAU,IAA0B,qC,oBCA3CD,EAAOC,QAAU,IAA0B,kC,kBCA3CD,EAAOC,QAAU,s+F,kBCAjBD,EAAOC,QAAU,89Z,qoCCAjB,IAAIC,EAAM,CACT,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBAAoB,IACpB,mBA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","file":"static/js/main.6fff87d8.chunk.js","sourcesContent":["module.exports = __webpack_public_path__ + \"static/media/06-c.47ce6e77.png\";","module.exports = __webpack_public_path__ + \"static/media/background.8361d88c.jpg\";","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/about.c5cfb349.png\";","module.exports = __webpack_public_path__ + \"static/media/05-c.36700bee.png\";","module.exports = __webpack_public_path__ + \"static/media/02-c.74e943d8.png\";","module.exports = __webpack_public_path__ + \"static/media/08-c.5a632fc5.png\";","module.exports = __webpack_public_path__ + \"static/media/09-c.0006044b.png\";","module.exports = __webpack_public_path__ + \"static/media/03-c.e3cdd76e.png\";","module.exports = __webpack_public_path__ + \"static/media/04-c.0a8a406a.png\";","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/11.ca2c058a.png\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/gcloud.5c0da927.png\";","module.exports = __webpack_public_path__ + \"static/media/flutter.0b5a2f8d.png\";","module.exports = __webpack_public_path__ + \"static/media/blockchain.5169db93.png\";","module.exports = __webpack_public_path__ + \"static/media/Artboard.8eb3748a.png\";","module.exports = __webpack_public_path__ + \"static/media/airplane.3cf98416.png\";","module.exports = __webpack_public_path__ + \"static/media/mobile.02944e97.png\";","module.exports = __webpack_public_path__ + \"static/media/mobile2.c3a87425.png\";","module.exports = __webpack_public_path__ + \"static/media/taifho.e4b23ce0.png\";","module.exports = __webpack_public_path__ + \"static/media/foto-01.84d3c9e0.png\";","module.exports = __webpack_public_path__ + \"static/media/foto-03.171f8fd4.png\";","module.exports = __webpack_public_path__ + \"static/media/foto-05.faf9533a.png\";","module.exports = __webpack_public_path__ + \"static/media/micro-management.36117cd9.png\";","module.exports = __webpack_public_path__ + \"static/media/TimeLinePirate.9f0ac5d1.png\";","module.exports = __webpack_public_path__ + \"static/media/foto-02.dd5e1a3f.png\";","module.exports = __webpack_public_path__ + \"static/media/foto-04.5bb8d0f5.png\";","module.exports = __webpack_public_path__ + \"static/media/PersonalData.54d050a1.png\";","module.exports = __webpack_public_path__ + \"static/media/Spar-09.644f507d.png\";","module.exports = __webpack_public_path__ + \"static/media/Treo.8d9d7b5b.png\";","module.exports = \"\"","module.exports = \"\"","var map = {\n\t\"./clients-01.png\": 472,\n\t\"./clients-02.png\": 473,\n\t\"./clients-03.png\": 474,\n\t\"./clients-04.png\": 475,\n\t\"./clients-05.png\": 476,\n\t\"./clients-06.png\": 477,\n\t\"./clients-07.png\": 478,\n\t\"./clients-08.png\": 479,\n\t\"./clients-09.png\": 480,\n\t\"./clients-10.png\": 481,\n\t\"./clients-11.png\": 482,\n\t\"./clients-12.png\": 483,\n\t\"./clients-13.png\": 484,\n\t\"./clients-14.png\": 485,\n\t\"./clients-15.png\": 486,\n\t\"./clients-16.png\": 487,\n\t\"./clients-17.png\": 488,\n\t\"./clients-18.png\": 489,\n\t\"./clients-19.png\": 490,\n\t\"./clients-20.png\": 491,\n\t\"./clients-21.png\": 492,\n\t\"./clients-22.png\": 493,\n\t\"./clients-23.png\": 494,\n\t\"./clients-24.png\": 495\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 471;","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/clients-13.64f84d83.png\";","module.exports = __webpack_public_path__ + \"static/media/clients-14.e509890d.png\";","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/clients-22.73373b7d.png\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/clients-24.cc56aa5d.png\";","import i18n from \"i18next\";\nimport { initReactI18next } from \"react-i18next\";\n\nimport translationEN from './lang/en.json';\n\n// the translations\nconst resources = {\n en: {\n translation: translationEN\n }\n};\n\ni18n\n .use(initReactI18next) // passes i18n down to react-i18next\n .init({\n resources,\n lng: \"en\",\n\n keySeparator: false, // we do not use keys in form messages.welcome\n\n interpolation: {\n escapeValue: false // react already safes from xss\n }\n });\n\nexport default i18n;\n","import React, { memo, useMemo } from 'react'\nimport PropTypes from 'prop-types'\nimport { Grid, withStyles } from '@material-ui/core'\nimport clsx from 'clsx'\n\nconst style = theme => ({\n column: {\n width: '100%'\n },\n flexGrow: {\n flexGrow: 1\n }\n})\n\nfunction GridBlock ({\n direction,\n className,\n itemClassName,\n children,\n alignItems,\n spacing,\n justify,\n wrap,\n column = false,\n onClick,\n classes,\n flexGrow = false,\n xs,\n sm,\n md,\n lg,\n xl,\n ...other\n}) {\n const elements = useMemo(() => {\n return React.Children.map(children, child => {\n if(child ===null) return \"\"\n return \n {child}\n \n })\n }, [children, itemClassName, classes, flexGrow, column,xs,sm,md,lg,xl])\n\n return (\n \n {elements}\n \n )\n}\n\nGridBlock.propTypes = {\n className: PropTypes.string\n}\n\nGridBlock.defaultProps = {\n}\n\nexport default memo(withStyles(style)(GridBlock))\n","const anchors = {\n HOME: 'home',\n ABOUT: 'about',\n CONTACT: 'contact',\n TECHNOLOGIES: \"technologies\",\n // TEAM: 'team',\n ESTIMATION: 'estimation',\n PROJECTS: 'projects',\n CLIENTS: 'clients'\n}\n\nconst path = {\n HOME: '/',\n}\n\nexport default {\n ...path,\n anchors\n}\n","import React, { memo, useMemo, useEffect, useState, useRef } from 'react'\r\nimport { Hidden, makeStyles, Box } from '@material-ui/core'\r\nimport clsx from 'clsx';\r\nimport doImage from '../../images/do.png';\r\nimport itImage from '../../images/it.png';\r\nimport technologyImage from '../../images/technology.png';\r\nimport doTechnologyImage from '../../images/doTechnology.png';\r\nimport GridBlock from '../../components/GridBlock';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n '@keyframes slide': {\r\n '0%': {\r\n height: 0\r\n }\r\n },\r\n '@keyframes show': {\r\n '0%': {\r\n opacity: 0\r\n }\r\n },\r\n box: {\r\n position: 'absolute',\r\n top: 0,\r\n background: `linear-gradient(180deg, rgba(255,0,0,0) 0%, ${theme.palette.primary.main} 70%)`,\r\n width: 75,\r\n animationName: '$slide',\r\n animationDuration: '1.0s',\r\n animationTimingFunction: 'ease-in-out',\r\n },\r\n itImage: {\r\n zIndex: 1,\r\n opacity: 1,\r\n animationName: '$show',\r\n animationDuration: '2.7s',\r\n animationTimingFunction: 'ease-in-out',\r\n [theme.breakpoints.down('md')]: {\r\n width: 80\r\n }\r\n },\r\n doTechnologyImage: {\r\n width: 130\r\n }\r\n}))\r\n\r\nfunction ImageAnimation({ width, ...props }) {\r\n const classes = useStyles(props);\r\n const [redBoxHeight, setRedBoxHeight] = useState(0)\r\n const itImageRef = useRef()\r\n\r\n const setHeight = useMemo(() => {\r\n return (itImageRef) => {\r\n let { height, offsetTop } = itImageRef.current\r\n if (height <= 0) height = 50\r\n if (width === \"lg\" || width === \"xl\") height -= 10\r\n else height += 10\r\n return offsetTop + height\r\n }\r\n }, [width])\r\n\r\n useEffect(() => {\r\n setRedBoxHeight(setHeight(itImageRef))\r\n }, [itImageRef,setHeight])\r\n\r\n useEffect(() => {\r\n window.addEventListener('resize', () => {\r\n setRedBoxHeight(setHeight(itImageRef))\r\n })\r\n }, [setHeight])\r\n\r\n const imageBox = useMemo(() => {\r\n const condition = width !== \"lg\" && width !== \"xl\"\r\n return \r\n \r\n \r\n \r\n \r\n \r\n \r\n \"technology\"\r\n \r\n \r\n }, [width, classes, redBoxHeight])\r\n\r\n return imageBox\r\n}\r\n\r\nexport default memo(ImageAnimation);\r\n","import React, { useCallback, memo } from 'react';\nimport { Button, Typography } from '@material-ui/core';\nimport { makeStyles } from '@material-ui/core/styles';\nimport GridBlock from '../../components/GridBlock';\nimport { useTranslation } from 'react-i18next';\nimport ReplyIcon from '@material-ui/icons/Reply';\nimport { animateScroll as scroll } from 'react-scroll';\nimport RouterPath from '../../const/RouterPath';\nimport withWidth from '@material-ui/core/withWidth';\nimport ImageAnimation from './ImageAnimation';\n\nconst useStyles = makeStyles(theme => ({\n contents: {\n margin: '30px 0 50px 0',\n [theme.breakpoints.down('md')]: {\n width: 260,\n textAlign: 'center'\n }\n },\n button: {\n height: 70,\n width: 300,\n fontSize: 22,\n [theme.breakpoints.down('sm')]: {\n width: 250,\n height: 55,\n fontSize: 18,\n }\n\n },\n endIcon: {\n transform: 'rotateY(180deg)'\n }\n}))\n\nfunction Home({ width, ...props }) {\n const classes = useStyles(props);\n const { t } = useTranslation();\n\n const handleClick = useCallback(\n () => {\n scroll.scrollTo(document.getElementById(RouterPath.anchors.ESTIMATION).offsetTop - 50)\n },\n []\n )\n\n return (\n \n \n \n {t('home_context')}\n \n }\n classes={{\n endIcon: classes.endIcon\n }}\n >\n {t(\"home_context_button\")}\n \n \n )\n}\n\nexport default memo(withWidth()(Home));\n","import React, { memo } from 'react'\nimport { makeStyles } from '@material-ui/core/styles'\nimport BackgroundImage from '../images/background.jpg'\nimport GridBlock from '../components/GridBlock';\nimport { Switch, Route } from 'react-router-dom'\nimport RouterPath from '../const/RouterPath';\nimport Home from '../pages/Home/Home';\n\nconst useStyles = makeStyles(theme => ({\n container: {\n backgroundPosition: 'center center',\n backgroundSize: 'cover',\n backgroundImage: `url(${BackgroundImage})`,\n color: 'white',\n height: '100vh'\n },\n\n}))\n\nfunction Header(props) {\n const classes = useStyles(props)\n\n return (\n \n\n \n \n \n \n\n \n )\n}\n\nexport default memo(Header)\n","import React, { memo } from 'react'\nimport { makeStyles } from '@material-ui/core/styles'\nimport { Typography, Box } from '@material-ui/core';\nimport GridBlock from './GridBlock';\n\nconst useStyles = makeStyles(theme => ({\n container: {\n marginBottom: theme.spacing(4),\n paddingLeft: theme.spacing(8),\n [theme.breakpoints.down('sm')]: {\n marginBottom: theme.spacing(3),\n paddingLeft: theme.spacing(2),\n }\n },\n box: {\n width: 40,\n height: 25,\n background: `linear-gradient(90deg, rgba(255,0,0,0) 0%, ${theme.palette.primary.main} 100%)`,\n marginRight: theme.spacing(2)\n }\n}))\n\nfunction Title({ props, title }) {\n const classes = useStyles(props)\n return (\n \n \n \n {title.toUpperCase()}\n \n \n )\n}\n\nexport default memo(Title)\n","import React from 'react'\nimport GridBlock from './GridBlock';\nimport { makeStyles } from '@material-ui/core/styles'\nimport clsx from 'clsx';\nimport Title from './Title';\nimport { Box } from '@material-ui/core';\n\nconst useStyles = makeStyles(theme => ({\n root: {\n padding: '50px 100px',\n [theme.breakpoints.only('md')]: {\n paddingLeft: ` ${theme.spacing(6)}px`,\n paddingRight: ` ${theme.spacing(6)}px`,\n },\n [theme.breakpoints.down('sm')]: {\n paddingLeft: ` ${theme.spacing(2)}px`,\n paddingRight: ` ${theme.spacing(2)}px`,\n }\n },\n childBox: {\n ...theme.maxResolution,\n [theme.breakpoints.down('md')]: {\n ...theme.maxResolutionMd,\n }\n }\n}))\n\nfunction ContentContainer({\n id,\n props,\n children,\n className,\n title,\n alignContent = \"center\",\n alignItems,\n justify\n}) {\n const classes = useStyles(props)\n return (\n \n \n {title && }\n {children}\n </Box>\n </GridBlock>\n\n )\n}\n\nexport default ContentContainer;\n","import React, { memo } from 'react'\nimport { Typography, Box } from '@material-ui/core';\nimport ContentContainer from '../../components/ContentContainer';\nimport { makeStyles } from '@material-ui/core/styles'\nimport AboutImage from '../../images/about.png'\nimport GridBlock from '../../components/GridBlock';\nimport { useTranslation } from 'react-i18next';\nimport RouterPath from '../../const/RouterPath';\n\nconst useStyles = makeStyles(theme => ({\n about: {\n background: \"black\",\n color: \"white\",\n },\n container: {\n padding: '0 100px',\n [theme.breakpoints.down('md')]: {\n flexDirection: \"column\",\n alignContent: \"center\",\n padding: '0 50px',\n },\n \"&>:first-child\": {\n textAlign: \"justify\",\n width: '50%',\n [theme.breakpoints.down('md')]: {\n width: \"unset\"\n },\n },\n \"&>:nth-child(2)\": {\n '& img': {\n [theme.breakpoints.only('md')]: {\n width: 300\n },\n [theme.breakpoints.down('sm')]: {\n width: 200\n },\n },\n [theme.breakpoints.down('md')]: {\n textAlign: \"center\",\n marginTop: theme.spacing(3),\n }\n },\n },\n subContent:{\n marginTop: theme.spacing(2),\n }\n}))\n\nfunction About(props) {\n const classes = useStyles(props);\n const { t } = useTranslation();\n\n return (\n <ContentContainer\n title={t(\"about_title\")}\n className={classes.about}\n id={RouterPath.anchors.ABOUT}\n >\n <GridBlock justify=\"space-between\" className={classes.container}>\n <Box>\n <Typography variant='body1'>\n {t(\"about_content\")}\n </Typography>\n <Typography variant='body1' className={classes.subContent}>\n {t(\"about_subContent\")}\n </Typography>\n </Box>\n <img alt=\"AboutImage\" src={AboutImage} />\n </GridBlock>\n </ContentContainer>\n )\n}\n\nexport default memo(About)\n","export default {\n card1: false,\n card2: false,\n card3: false,\n card4: false\n}\n","import React, { memo, useCallback, useMemo } from 'react'\r\nimport {\r\n Card as CardUI, CardContent, Typography,\r\n Box, Collapse, withWidth, makeStyles\r\n} from '@material-ui/core';\r\nimport GridBlock from './GridBlock';\r\nimport initialStateCard from '../pages/Technologies/initialStateCard';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n card: {\r\n width: 350,\r\n height: '100%',\r\n '&:hover': {\r\n boxShadow: theme.shadows[9]\r\n },\r\n [theme.breakpoints.down('sm')]: {\r\n width: 260,\r\n height: 'unset'\r\n }\r\n },\r\n cardContent: {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n flexDirection: \"column\",\r\n },\r\n avatarBox: {\r\n margin: `${theme.spacing(2)}px 0`,\r\n textAlign: \"center\",\r\n width: '100%',\r\n },\r\n avatar: {\r\n marginBottom: theme.spacing(2),\r\n fill: theme.palette.primary.main,\r\n width: 100,\r\n height: 100\r\n },\r\n title: {\r\n color: theme.palette.primary.main,\r\n },\r\n image: {\r\n paddingLeft: theme.spacing(),\r\n width: 40,\r\n height: 40,\r\n objectFit: 'contain',\r\n },\r\n text: {\r\n width: 230,\r\n whiteSpace: 'pre-wrap',\r\n [theme.breakpoints.down('sm')]: {\r\n width: 150,\r\n paddingLeft: theme.spacing(3)\r\n }\r\n },\r\n itemBox: {\r\n height: 60,\r\n cursor: \"pointer\",\r\n filter: 'grayscale(100%)',\r\n '&:hover': {\r\n filter: \"unset\"\r\n }\r\n }\r\n}))\r\n\r\nfunction TechnologiesCard({ props, id, title, items, Avatar, open, setOpen, width }) {\r\n const classes = useStyles(props);\r\n\r\n const setState = useCallback(\r\n () => setOpen({\r\n ...initialStateCard,\r\n [id]: !open[id]\r\n }),\r\n [open, id, setOpen],\r\n )\r\n\r\n const createList = useCallback((classes, items) => {\r\n return items.map((x, i) => {\r\n return <GridBlock\r\n key={i}\r\n alignItems=\"center\"\r\n justify=\"space-between\"\r\n className={classes.itemBox}\r\n >\r\n {\r\n x.icon === null ?\r\n <Box className={classes.image} /> :\r\n <img className={classes.image} alt={\"\" + i} src={x.icon} />\r\n }\r\n <Typography variant=\"body2\" className={classes.text}>\r\n {x.text}\r\n </Typography>\r\n </GridBlock>\r\n })\r\n }, [])\r\n\r\n const withCollapse = useMemo(() => {\r\n if (width === 'xs' || width === 'sm') {\r\n return <Collapse in={open[id]} timeout=\"auto\" unmountOnExit>\r\n {createList(classes, items)}\r\n </Collapse>\r\n\r\n } else return createList(classes, items)\r\n }, [width, classes, open, id, createList, items])\r\n\r\n return (\r\n <CardUI\r\n className={classes.card}\r\n >\r\n <CardContent className={classes.cardContent}>\r\n\r\n <Box onClick={setState} className={classes.avatarBox}>\r\n <Avatar className={classes.avatar} />\r\n\r\n <Typography variant=\"h6\" className={classes.title}>\r\n {title}\r\n </Typography>\r\n </Box>\r\n\r\n {withCollapse}\r\n\r\n </CardContent>\r\n </CardUI>\r\n )\r\n}\r\n\r\nexport default memo(withWidth()(TechnologiesCard));\r\n","import reactIcon from '../images/cardIcons/06-c.png';\nimport nodeJsIcon from '../images/cardIcons/05-c.png';\nimport javeIcon from '../images/cardIcons/02-c.png';\nimport uiUxIcon from '../images/cardIcons/08-c.png';\n\nimport azureIcon from '../images/cardIcons/09-c.png';\nimport awsIcon from '../images/cardIcons/03-c.png';\n\nimport scrumIcon from '../images/cardIcons/04-c.png';\nimport kanbanIcon from '../images/cardIcons/01-c.png';\n\nimport Support from '../images/pictogram/Support';\nimport Clouds from '../images/pictogram/Clouds';\nimport Project from '../images/pictogram/Project';\nimport Stack from '../images/pictogram/Stack';\n\nimport serverlessIcon from '../images/cardIcons/10.png';\nimport dockerIcon from '../images/cardIcons/11.png';\n\nimport autoDepIcon from '../images/cardIcons/autodep.png';\nimport gcloudIcon from '../images/cardIcons/gcloud.png';\nimport flutterIcon from '../images/cardIcons/flutter.png';\nimport blockchainIcon from '../images/cardIcons/blockchain.png';\n\nconst stackItems = {\n avatar: Stack,\n title: 'stack',\n items: [\n {\n icon: uiUxIcon,\n text: 'UX /UI'\n },\n {\n icon: reactIcon,\n text: `REACT`\n },\n {\n icon: nodeJsIcon,\n text: 'NODE JS'\n },\n {\n icon: javeIcon,\n text: 'JAVA'\n },\n {\n icon: reactIcon,\n text: `REACT NATIVE`\n },\n {\n icon: flutterIcon,\n text: `FLUTTER`\n },\n {\n icon: blockchainIcon,\n text: \"BLOCKCHAIN\"\n }\n ]\n}\n\nconst cloudItems = {\n avatar: Clouds,\n title: 'cloud',\n items: [\n {\n icon: azureIcon,\n text: `AZURE`\n },\n {\n icon: awsIcon,\n text: 'AWS'\n },\n {\n icon: gcloudIcon,\n text: 'Google'\n }\n ]\n}\n\nconst agileItems = {\n avatar: Project,\n title: 'agile',\n items: [\n {\n icon: scrumIcon,\n text: `SCRUM`\n },\n {\n icon: kanbanIcon,\n text: 'KANBAN'\n }\n ]\n}\n\nconst servicesItems = {\n avatar: Support,\n title: 'services',\n items: [\n {\n icon: serverlessIcon,\n text: `SERVERLESS`\n },\n {\n icon: dockerIcon,\n text: 'DOCKER'\n },\n {\n icon: autoDepIcon,\n text: \"AUTOMATED DEPLOYMENT\"\n }\n ]\n}\n\nexport default [\n stackItems,\n cloudItems,\n agileItems,\n servicesItems\n]\n","import React from 'react'\n\nexport default (props) => {\n return (\n <svg {...props} version=\"1.1\" id=\"Capa_1\" xmlns=\"http://www.w3.org/2000/svg\" xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n\t viewBox=\"0 0 512.001 512.001\" space=\"preserve\">\n<g>\n\t<g>\n\t\t<path d=\"M256,49.25c-5.52,0-10,4.48-10,10s4.48,10,10,10s10-4.48,10-10S261.52,49.25,256,49.25z\"/>\n\t</g>\n</g>\n<g>\n\t<g>\n\t\t<path d=\"M427.478,144.258l-126.62-70.36c-4.826-2.683-10.916-0.944-13.599,3.884c-2.683,4.828-0.943,10.917,3.884,13.599\n\t\t\tl126.62,70.36c1.538,0.855,3.205,1.261,4.849,1.261c3.514,0,6.922-1.855,8.75-5.145\n\t\t\tC434.045,153.029,432.305,146.941,427.478,144.258z\"/>\n\t</g>\n</g>\n<g>\n\t<g>\n\t\t<path d=\"M512,256.136c0.048-3.513-1.752-6.793-4.739-8.642l-72.408-44.774l72.094-41.029c3.11-1.77,5.037-5.067,5.054-8.645\n\t\t\tc0.017-3.579-1.881-6.893-4.975-8.691l-246-143c-3.107-1.806-6.943-1.806-10.051,0l-246,143c-3.094,1.798-4.991,5.113-4.975,8.691\n\t\t\tc0.017,3.578,1.943,6.875,5.054,8.645l72.094,41.029L4.74,247.495c-2.987,1.848-4.787,5.128-4.739,8.642\n\t\t\tc0.048,3.513,1.936,6.743,4.973,8.509l73.589,42.781L4.961,350.362c-3.074,1.793-4.964,5.086-4.961,8.646\n\t\t\tc0.003,3.559,1.897,6.849,4.975,8.638l246,143c1.554,0.903,3.289,1.354,5.025,1.354c1.736,0,3.472-0.452,5.025-1.354l246-143\n\t\t\tc3.077-1.789,4.972-5.079,4.975-8.638c0.003-3.56-1.887-6.852-4.961-8.646l-73.601-42.936l73.589-42.781\n\t\t\tC510.064,262.879,511.952,259.649,512,256.136z M30.057,152.908L256,21.567l225.943,131.341L256,281.494l-154.813-88.105\n\t\t\tL30.057,152.908z M482.128,358.985L256,490.433L29.872,358.985l68.571-40.002l152.532,88.662c1.554,0.903,3.289,1.354,5.025,1.354\n\t\t\tc1.736,0,3.472-0.452,5.025-1.354l152.532-88.662L482.128,358.985z M256,387.433L29.442,255.735l67.509-41.745l154.103,87.701\n\t\t\tc1.533,0.873,3.24,1.309,4.946,1.309s3.413-0.437,4.946-1.309l154.103-87.701l67.51,41.745L256,387.433z\"/>\n\t</g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n</svg>\n\n )\n}\n","import React from 'react'\r\n\r\nexport default (props) => {\r\n return (\r\n <svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\r\n viewBox=\"0 0 512 512\" space=\"preserve\" {...props} >\r\n <g>\r\n <g>\r\n <path d=\"M512,320.126c0-49.185-40.017-89.202-89.202-89.202c-5.264,0-10.49,0.458-15.627,1.368\r\n c-1.027-16.464-5.53-32.634-13.176-47.163c-2.219-4.217-7.435-5.837-11.654-3.617c-4.217,2.22-5.836,7.436-3.617,11.654\r\n c7.469,14.192,11.416,30.232,11.416,46.388c0,0.867-0.03,1.73-0.06,2.589l-0.026,0.819c-0.086,2.791,1.184,5.453,3.408,7.141\r\n c2.225,1.688,5.127,2.197,7.797,1.36c6.944-2.176,14.19-3.28,21.539-3.28c39.671,0,71.946,32.275,71.946,71.946\r\n c0,14.321-4.238,28.168-12.088,39.92c-0.301-0.325-0.618-0.632-0.926-0.95c-0.341-0.354-0.68-0.71-1.029-1.056\r\n c-0.232-0.228-0.47-0.448-0.704-0.672c-0.545-0.521-1.096-1.034-1.659-1.535c-0.088-0.078-0.179-0.154-0.267-0.232\r\n c-10.506-9.216-24.255-14.821-39.296-14.821c-3.14,0-6.272,0.247-9.362,0.734c-9.31-10.528-22.745-16.667-36.962-16.667\r\n c-2.309,0-4.606,0.161-6.882,0.481c-4.678-13.326-13.048-25.267-24.12-34.229c-13.544-10.964-30.616-17.003-48.071-17.003\r\n c-39.396,0-71.931,29.937-76.049,68.258c-2.269-0.262-4.56-0.395-6.861-0.395c-0.969,0-1.931,0.027-2.887,0.073\r\n c-0.367,0.017-0.728,0.052-1.093,0.076c-0.58,0.039-1.162,0.077-1.737,0.133c-0.464,0.044-0.922,0.105-1.382,0.16\r\n c-0.463,0.056-0.925,0.11-1.385,0.177c-0.526,0.077-1.048,0.165-1.569,0.256c-0.374,0.065-0.749,0.128-1.121,0.201\r\n c-0.585,0.112-1.164,0.236-1.742,0.366c-0.286,0.065-0.572,0.129-0.855,0.198c-0.649,0.155-1.293,0.321-1.934,0.498\r\n c-0.181,0.051-0.362,0.102-0.544,0.154c-0.729,0.209-1.453,0.429-2.17,0.665c-0.044,0.015-0.088,0.03-0.133,0.045\r\n c-18.265,6.058-32.598,20.797-38.089,39.313c-0.009,0.028-0.016,0.057-0.024,0.085c-0.243,0.821-0.471,1.648-0.677,2.484\r\n c-0.001,0.003-0.001,0.008-0.002,0.011c-0.424,1.713-0.784,3.451-1.054,5.219H90.144c-40.19,0-72.887-32.698-72.887-72.889\r\n c0-40.19,32.697-72.887,72.887-72.887c6.194,0,12.365,0.783,18.343,2.328c3.497,0.899,7.193-0.469,9.251-3.441\r\n c10.552-15.234,27.891-24.33,46.381-24.33c6.078,0,12.089,0.977,17.869,2.906c2.31,0.772,4.842,0.531,6.967-0.669\r\n c2.124-1.196,3.641-3.237,4.179-5.614c1.972-8.724,5.028-16.94,9-24.536c0.245-0.327,0.47-0.671,0.669-1.034\r\n c12.807-23.498,34.856-41.121,60.495-48.35c0.305-0.086,0.603-0.19,0.893-0.307c8.37-2.244,17.157-3.444,26.206-3.444\r\n c27.917,0,53.798,11.238,72.876,31.644c3.254,3.48,8.714,3.665,12.196,0.41c3.482-3.255,3.664-8.715,0.41-12.196\r\n c-22.053-23.586-53.21-37.114-85.482-37.114c-8.404,0-16.75,0.919-24.887,2.695c-8.401-13.683-23.304-22.196-39.745-22.196\r\n c-1.111,0-2.22,0.039-3.323,0.116c-4.144-28.959-29.112-51.289-59.198-51.289c-25.272,0-47.187,15.441-55.882,38.449\r\n c-1.242-0.118-2.495-0.178-3.75-0.178c-10.942,0-21.302,4.561-28.685,12.427c-2.072-0.276-4.16-0.415-6.25-0.415\r\n c-25.983,0-47.12,21.139-47.12,47.122c0,25.983,21.138,47.122,47.12,47.122h61.542c4.765,0,8.628-3.863,8.628-8.628\r\n s-3.863-8.628-8.628-8.628h-61.54c-16.467,0-29.864-13.398-29.864-29.866c0-16.469,13.398-29.866,29.864-29.866\r\n c2.536,0,5.067,0.321,7.527,0.957c3.499,0.901,7.19-0.472,9.246-3.442c4.133-5.965,10.922-9.527,18.16-9.527\r\n c2.384,0,4.739,0.382,6.999,1.136c2.312,0.773,4.844,0.527,6.966-0.669c2.125-1.197,3.642-3.238,4.179-5.615\r\n c4.405-19.502,21.464-33.123,41.487-33.123c23.459,0,42.545,19.085,42.545,42.543c0,0.366-0.015,0.728-0.027,1.09l-0.013,0.366\r\n c-0.092,2.793,1.177,5.46,3.402,7.151c2.225,1.691,5.132,2.2,7.8,1.367c2.847-0.892,5.813-1.344,8.814-1.344\r\n c8.74,0,16.794,3.816,22.279,10.187c-0.3,0.118-0.593,0.25-0.892,0.37c-0.547,0.217-1.086,0.45-1.63,0.675\r\n c-0.85,0.355-1.7,0.709-2.54,1.083c-1.004,0.444-1.996,0.914-2.989,1.386c-0.341,0.164-0.685,0.321-1.025,0.489\r\n c-7.837,3.831-15.268,8.525-22.102,14.058c-9.258,7.495-17.272,16.358-23.813,26.178c-0.263,0.394-0.516,0.794-0.774,1.19\r\n c-0.548,0.844-1.089,1.692-1.616,2.551c-0.14,0.228-0.291,0.449-0.429,0.677H158.26c-4.765,0-8.628,3.863-8.628,8.628\r\n s3.863,8.628,8.628,8.628h23.406c-1.129,2.834-2.155,5.711-3.058,8.63c-4.763-0.958-9.611-1.44-14.492-1.44\r\n c-22.175,0-43.077,10.009-57.011,27.041c-5.583-1.061-11.264-1.598-16.963-1.598C40.439,229.037,0,269.477,0,319.181\r\n c0,49.706,40.439,90.146,90.144,90.146h81.834c4.041,28.667,28.722,50.797,58.487,50.797h151.06c4.765,0,8.628-3.863,8.628-8.628\r\n s-3.863-8.628-8.628-8.628H230.465c-23.061,0-41.822-18.762-41.822-41.822c0-0.245,0.014-0.487,0.018-0.731\r\n c0.01-0.548,0.023-1.096,0.053-1.639c0.008-0.126,0.021-0.251,0.029-0.378c0.039-0.589,0.083-1.176,0.146-1.758\r\n c0.006-0.056,0.015-0.111,0.022-0.167c2.341-20.851,20.134-37.155,41.555-37.155c4.276,0,8.49,0.642,12.527,1.907\r\n c2.67,0.838,5.578,0.327,7.802-1.365c2.226-1.692,3.493-4.358,3.402-7.154l-0.017-0.472c-0.018-0.513-0.038-1.026-0.038-1.544\r\n c0-32.662,26.572-59.235,59.233-59.235c27.429,0,51.721,19.396,57.76,46.122c0.538,2.378,2.056,4.418,4.18,5.615\r\n c2.126,1.197,4.657,1.44,6.968,0.668c3.286-1.098,6.707-1.653,10.166-1.653c10.522,0,20.388,5.177,26.392,13.846\r\n c2.06,2.975,5.752,4.348,9.256,3.442c3.474-0.899,7.067-1.356,10.676-1.356c0.841,0,1.675,0.032,2.507,0.08\r\n c0.311,0.018,0.619,0.046,0.927,0.071c0.497,0.039,0.992,0.087,1.485,0.143c0.403,0.046,0.806,0.096,1.206,0.153\r\n c0.33,0.047,0.657,0.105,0.985,0.16c10.927,1.853,20.447,7.887,26.838,16.407c0.025,0.032,0.049,0.066,0.073,0.098\r\n c5.271,7.069,8.395,15.826,8.395,25.301c0,23.388-19.029,42.415-42.417,42.415h-29.211c-4.765,0-8.628,3.863-8.628,8.628\r\n s3.863,8.628,8.628,8.628h29.211c32.904,0,59.673-26.768,59.673-59.672c0-8.986-2.009-17.509-5.582-25.16\r\n C505.231,359.603,512,340.247,512,320.126z\"/>\r\n </g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n <g>\r\n </g>\r\n </svg>\r\n \r\n )\r\n}","import React from 'react'\r\n\r\nexport default (props) => {\r\n return (\r\n <svg {...props} height=\"479pt\" viewBox=\"-8 0 479 479.936\" width=\"479pt\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"m458.402344 318.585938-25.085938-6.273438c-2.097656-6.925781-4.882812-13.628906-8.3125-20l13.3125-22.183594c1.890625-3.148437 1.394532-7.179687-1.199218-9.777344l-24.96875-25c-2.597657-2.597656-6.628907-3.089843-9.777344-1.199218l-22.183594 13.3125c-2.878906-1.542969-5.839844-2.96875-8.855469-4.265625-3.65625-1.550781-7.394531-2.902344-11.199219-4.046875l-6.273437-25.089844c-.886719-3.5625-4.085937-6.0625-7.757813-6.0625h-35.289062c-3.671875 0-6.871094 2.5-7.761719 6.0625l-6.269531 25.089844c-6.929688 2.097656-13.628906 4.882812-20 8.3125l-22.183594-13.3125c-3.148437-1.890625-7.179687-1.398438-9.777344 1.199218l-25 24.96875c-2.597656 2.597657-3.089843 6.628907-1.199218 9.777344l13.3125 22.183594c-3.433594 6.371094-6.214844 13.070312-8.3125 20l-25.089844 6.269531c-3.5625.890625-6.0625 4.089844-6.0625 7.761719v35.3125c0 3.671875 2.5 6.871094 6.0625 7.757812l25.089844 6.273438c2.097656 6.925781 4.878906 13.625 8.3125 20l-13.3125 22.183594c-1.890625 3.148437-1.398438 7.179687 1.199218 9.777344l24.96875 24.96875c2.597657 2.59375 6.628907 3.089843 9.773438 1.199218l22.183594-13.3125c6.375 3.429688 13.074218 6.214844 20 8.3125l6.273437 25.085938c.890625 3.5625 4.089844 6.0625 7.761719 6.066406h35.3125c3.671875-.003906 6.871094-2.503906 7.757812-6.066406l6.273438-25.085938c6.925781-2.097656 13.625-4.882812 20-8.3125l22.183594 13.3125c3.148437 1.890625 7.179687 1.394532 9.777344-1.199218l24.964843-24.96875c2.597657-2.597657 3.09375-6.628907 1.203125-9.777344l-13.3125-22.183594c3.429688-6.375 6.214844-13.074219 8.3125-20l25.085938-6.273438c3.5625-.886718 6.0625-4.085937 6.0625-7.757812v-35.28125c.007812-3.652344-2.460938-6.847656-6-7.757812zm-9.933594 36.820312-23.542969 5.890625c-2.863281.710937-5.097656 2.933594-5.824219 5.792969-2.203124 8.667968-5.644531 16.972656-10.226562 24.652344-1.507812 2.53125-1.507812 5.683593 0 8.210937l12.496094 20.800781-16.101563 16.167969-20.800781-12.496094c-2.527344-1.511719-5.679688-1.511719-8.207031 0-7.683594 4.578125-15.988281 8.023438-24.65625 10.222657-2.859375.726562-5.082031 2.964843-5.792969 5.824218l-5.9375 23.527344h-22.816406l-5.886719-23.542969c-.710937-2.859375-2.9375-5.097656-5.792969-5.824219-8.667968-2.203124-16.972656-5.644531-24.65625-10.226562-2.527344-1.507812-5.679687-1.507812-8.207031 0l-20.800781 12.496094-16.167969-16.101563 12.496094-20.800781c1.511719-2.527344 1.511719-5.679688 0-8.207031-4.578125-7.683594-8.023438-15.988281-10.222657-24.65625-.726562-2.855469-2.964843-5.082031-5.824218-5.792969l-23.527344-5.9375v-22.8125l23.542969-5.890625c2.859375-.710937 5.097656-2.933594 5.824219-5.792969 2.199218-8.667968 5.644531-16.972656 10.222656-24.652344 1.511718-2.53125 1.511718-5.683593 0-8.210937l-12.496094-20.800781 16.105469-16.167969 20.800781 12.496094c2.527344 1.511719 5.679688 1.511719 8.207031 0 7.683594-4.578125 15.988281-8.023438 24.65625-10.222657 2.855469-.726562 5.082031-2.964843 5.792969-5.824218l5.933594-23.527344h22.816406l5.890625 23.542969c.710937 2.859375 2.933594 5.097656 5.789063 5.824219 8.667968 2.195312 16.972656 5.636718 24.648437 10.21875 2.53125 1.511718 5.6875 1.511718 8.21875 0l20.796875-12.496094 16.167969 16.109375-12.496094 20.800781c-1.507813 2.527344-1.507813 5.679688 0 8.207031 4.582031 7.683594 8.023437 15.988281 10.226563 24.65625.726562 2.855469 2.960937 5.082031 5.824218 5.792969l23.527344 5.9375zm0 0\"/><path d=\"m328.46875 280c-35.347656 0-64 28.652344-64 64s28.652344 64 64 64c35.34375 0 64-28.652344 64-64-.039062-35.328125-28.671875-63.960938-64-64zm0 112c-26.511719 0-48-21.492188-48-48s21.488281-48 48-48c26.507812 0 48 21.492188 48 48-.027344 26.5-21.503906 47.972656-48 48zm0 0\"/><path d=\"m368.46875 96h16v128h-16zm0 0\"/><path d=\"m32.46875 408v32c0 4.417969 3.582031 8 8 8h168v-16h-160v-24h96c1.238281.011719 2.460938-.261719 3.574219-.800781l32-16c2.714843-1.351563 4.433593-4.125 4.433593-7.160157 0-3.03125-1.71875-5.804687-4.433593-7.160156l-32-16c-1.105469-.566406-2.332031-.867187-3.574219-.878906h-96v-272h304c17.671875 0 32-14.328125 32-32v-16c0-4.417969-3.582031-8-8-8h-24v16h16v8c0 8.835938-7.164062 16-16 16s-16-7.164062-16-16v-24c0-8.835938 7.164062-16 16-16h32c8.835938 0 16 7.164062 16 16v184h16v-184c0-17.671875-14.328125-32-32-32h-352c-17.675781 0-32 14.328125-32 32v24c0 17.671875 14.324219 32 32 32v272h-8c-13.253906 0-24 10.746094-24 24s10.746094 24 24 24zm-16-352v-24c0-8.835938 7.164062-16 16-16h292.445312c-2.878906 4.84375-4.414062 10.367188-4.445312 16v24c.03125 5.632812 1.566406 11.15625 4.445312 16h-292.445312c-8.835938 0-16-7.164062-16-16zm142.109375 328-16 8h-6.109375v-16h6.109375zm-142.109375 0c0-4.417969 3.582031-8 8-8h96v16h-96c-4.417969 0-8-3.582031-8-8zm0 0\"/><path d=\"m.46875 120h16v160h-16zm0 0\"/><path d=\"m312.46875 128v-16h-104c-2.121094 0-4.15625.84375-5.65625 2.34375l-14.617188 14.617188c-34.945312-25.613282-83.355468-21.875-113.953124 8.800781-3.121094 3.121093-3.121094 8.1875 0 11.308593l56.570312 56.570313c1.496094 1.503906 3.53125 2.355469 5.65625 2.359375h80c4.417969 0 8-3.582031 8-8-.007812-22.519531-8.679688-44.171875-24.226562-60.464844l11.539062-11.535156zm-104.449219 64h-68.238281l-48.257812-48.257812c24.59375-19.691407 59.15625-21.035157 85.207031-3.316407l-21.917969 21.917969 11.3125 11.3125 22.847656-22.847656c10.640625 11.308594 17.324219 25.761718 19.046875 41.191406zm0 0\"/><path d=\"m328.46875 112h16v16h-16zm0 0\"/><path d=\"m88.46875 232h16v16h-16zm0 0\"/><path d=\"m120.46875 232h80v16h-80zm0 0\"/><path d=\"m72.46875 264h128v16h-128zm0 0\"/><path d=\"m248.46875 144h16v16h-16zm0 0\"/><path d=\"m280.46875 144h64v16h-64zm0 0\"/><path d=\"m248.46875 176h96v16h-96zm0 0\"/><path d=\"m72.46875 296h104v16h-104zm0 0\"/></svg>\r\n )\r\n}","import React from 'react'\r\n\r\nexport default (props) => {\r\n return (\r\n <svg {...props}height=\"512pt\" viewBox=\"0 0 512 512\" width=\"512pt\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"m90.050781 395.949219c-7.167969 0-14.058593 1.789062-20.171875 5.148437-32.203125-41.28125-49.878906-92.5625-49.878906-145.097656 0-130.132812 105.867188-236 236-236 15.820312 0 31.632812 1.574219 47 4.679688 5.40625 1.09375 10.6875-2.40625 11.78125-7.820313s-2.40625-10.6875-7.820312-11.785156c-16.667969-3.367188-33.8125-5.074219-50.960938-5.074219-68.378906 0-132.667969 26.628906-181.019531 74.980469-48.351563 48.351562-74.980469 112.640625-74.980469 181.019531 0 57.519531 19.53125 113.652344 55.089844 158.652344-4.578125 6.839844-7.039063 14.878906-7.039063 23.296875 0 11.21875 4.371094 21.765625 12.304688 29.695312 7.929687 7.933594 18.476562 12.304688 29.695312 12.304688s21.765625-4.371094 29.699219-12.304688c7.933594-7.929687 12.300781-18.480469 12.300781-29.699219 0-11.214843-4.367187-21.765624-12.300781-29.695312-7.933594-7.933594-18.480469-12.300781-29.699219-12.300781zm15.554688 57.554687c-4.152344 4.15625-9.679688 6.445313-15.554688 6.445313s-11.398437-2.289063-15.554687-6.445313-6.445313-9.679687-6.445313-15.554687c0-5.878907 2.289063-11.402344 6.445313-15.558594 4.152344-4.15625 9.679687-6.441406 15.554687-6.441406s11.398438 2.289062 15.554688 6.441406c4.15625 4.15625 6.445312 9.679687 6.445312 15.558594 0 5.875-2.289062 11.398437-6.445312 15.554687zm0 0\"/><path d=\"m456.902344 97.335938c10.871094-16.308594 9.125-38.605469-5.253906-52.984376-7.933594-7.929687-18.480469-12.300781-29.699219-12.300781s-21.765625 4.371094-29.699219 12.300781c-7.933594 7.933594-12.300781 18.480469-12.300781 29.699219s4.367187 21.765625 12.300781 29.699219 18.480469 12.300781 29.699219 12.300781c7.167969 0 14.058593-1.789062 20.171875-5.148437 32.203125 41.285156 49.878906 92.5625 49.878906 145.097656 0 130.132812-105.867188 236-236 236-15.664062 0-31.328125-1.542969-46.550781-4.589844-5.414063-1.082031-10.683594 2.429688-11.769531 7.84375-1.082032 5.417969 2.429687 10.683594 7.84375 11.769532 16.511718 3.300781 33.496093 4.976562 50.476562 4.976562 68.378906 0 132.667969-26.628906 181.019531-74.980469 48.351563-48.351562 74.980469-112.640625 74.980469-181.019531 0-57.523438-19.535156-113.660156-55.097656-158.664062zm-50.507813-7.726563c-4.15625-4.15625-6.445312-9.679687-6.445312-15.558594 0-5.875 2.289062-11.398437 6.445312-15.554687 4.152344-4.15625 9.679688-6.445313 15.554688-6.445313s11.402343 2.289063 15.558593 6.445313c8.574219 8.578125 8.574219 22.535156 0 31.113281-4.15625 4.152344-9.683593 6.441406-15.558593 6.441406-5.878907 0-11.402344-2.289062-15.554688-6.441406zm0 0\"/><path d=\"m214.734375 428c0 5.523438 4.480469 10 10 10h62.527344c5.523437 0 10-4.476562 10-10v-19.386719c13.148437-3.539062 25.71875-8.75 37.53125-15.554687l13.6875 13.6875c1.875 1.875 4.417969 2.929687 7.074219 2.929687 2.648437 0 5.195312-1.054687 7.070312-2.933593l44.195312-44.226563c3.902344-3.90625 3.902344-10.238281 0-14.140625l-13.671874-13.671875c6.804687-11.8125 12.015624-24.382813 15.554687-37.53125h19.3125c5.523437 0 10-4.476563 10-10v-62.527344c0-5.523437-4.476563-10-10-10h-19.316406c-3.539063-13.144531-8.746094-25.714843-15.550781-37.527343l13.597656-13.597657c1.875-1.875 2.929687-4.421875 2.929687-7.074219-.003906-2.652343-1.058593-5.199218-2.933593-7.074218l-44.230469-44.195313c-3.902344-3.902343-10.234375-3.902343-14.140625.003907l-13.578125 13.582031c-11.8125-6.804688-24.382813-12.015625-37.53125-15.554688v-19.207031c0-5.523438-4.476563-10-10-10h-62.527344c-5.519531 0-10 4.476562-10 10v19.210938c-13.144531 3.535156-25.714844 8.746093-37.527344 15.550781l-13.582031-13.582031c-3.902344-3.902344-10.234375-3.90625-14.140625-.003907l-44.226563 44.199219c-1.878906 1.875-2.933593 4.417969-2.933593 7.070312 0 2.652344 1.054687 5.199219 2.929687 7.074219l13.597656 13.597657c-6.804687 11.8125-12.015624 24.378906-15.554687 37.527343h-19.277344c-5.523437 0-10 4.476563-10 9.996094l-.035156 62.527344c-.003906 2.652343 1.050781 5.199219 2.925781 7.074219s4.417969 2.929687 7.074219 2.929687h19.3125c3.539063 13.148437 8.75 25.71875 15.554687 37.53125l-13.671874 13.671875c-3.902344 3.902344-3.90625 10.234375 0 14.140625l44.195312 44.226563c1.875 1.875 4.417969 2.933593 7.070312 2.933593h.003907c2.652343 0 5.195312-1.054687 7.070312-2.929687l13.683594-13.6875c11.816406 6.804687 24.386719 12.015625 37.53125 15.554687zm-33.609375-55.972656c-3.957031-2.558594-9.164062-2.003906-12.5 1.328125l-12.175781 12.175781-30.058594-30.082031 12.164063-12.167969c3.332031-3.332031 3.886718-8.539062 1.328124-12.496094-9.066406-14.03125-15.441406-29.410156-18.941406-45.714844-.992187-4.605468-5.0625-7.898437-9.777344-7.898437h-17.175781l.023438-42.527344h17.152343c4.714844 0 8.785157-3.289062 9.777344-7.898437 3.5-16.300782 9.875-31.679688 18.941406-45.710938 2.558594-3.957031 2.003907-9.164062-1.328124-12.496094l-12.085938-12.089843 30.082031-30.058594 12.074219 12.078125c3.335938 3.332031 8.539062 3.882812 12.5 1.328125 14.027344-9.066406 29.40625-15.441406 45.710938-18.941406 4.605468-.992188 7.898437-5.066407 7.898437-9.777344v-17.078125h42.527344v17.074219c0 4.714843 3.289062 8.789062 7.898437 9.777343 16.300782 3.503907 31.683594 9.875 45.710938 18.941407 3.957031 2.558593 9.164062 2.007812 12.496094-1.328125l12.078124-12.074219 30.082032 30.058594-12.085938 12.085937c-3.335937 3.335938-3.886718 8.542969-1.328125 12.5 9.066407 14.03125 15.4375 29.410156 18.941407 45.710938.988281 4.609375 5.0625 7.898437 9.777343 7.898437h17.183594v42.527344h-17.183594c-4.714843 0-8.785156 3.292969-9.777343 7.898437-3.5 16.300782-9.875 31.683594-18.941407 45.710938-2.558593 3.960938-2.003906 9.167969 1.328125 12.5l12.164063 12.164062-30.058594 30.082032-12.175781-12.171875c-3.335938-3.335938-8.542969-3.886719-12.5-1.328125-14.03125 9.066406-29.410156 15.4375-45.710938 18.941406-4.609375.992188-7.898437 5.0625-7.898437 9.777344v17.253906h-42.527344v-17.253906c0-4.710938-3.292969-8.785156-7.898437-9.777344-16.300782-3.5-31.679688-9.875-45.710938-18.941406zm0 0\"/><path d=\"m338.628906 256c0-45.5625-37.066406-82.628906-82.628906-82.628906s-82.628906 37.066406-82.628906 82.628906 37.066406 82.628906 82.628906 82.628906 82.628906-37.066406 82.628906-82.628906zm-145.257812 0c0-34.535156 28.09375-62.628906 62.628906-62.628906s62.628906 28.097656 62.628906 62.628906-28.09375 62.628906-62.628906 62.628906-62.628906-28.09375-62.628906-62.628906zm0 0\"/><path d=\"m348.078125 37.820312c2.632813 0 5.210937-1.070312 7.070313-2.929687 1.859374-1.871094 2.929687-4.449219 2.929687-7.082031 0-2.617188-1.066406-5.199219-2.929687-7.070313-1.859376-1.859375-4.4375-2.929687-7.070313-2.929687-2.640625 0-5.207031 1.070312-7.066406 2.929687-1.863281 1.871094-2.933594 4.441407-2.933594 7.070313 0 2.640625 1.070313 5.210937 2.933594 7.082031 1.859375 1.859375 4.425781 2.929687 7.066406 2.929687zm0 0\"/><path d=\"m164.359375 474.359375c-2.628906 0-5.210937 1.070313-7.070313 2.929687-1.859374 1.859376-2.929687 4.441407-2.929687 7.070313 0 2.640625 1.070313 5.210937 2.929687 7.070313 1.859376 1.859374 4.441407 2.929687 7.070313 2.929687s5.210937-1.070313 7.070313-2.929687c1.859374-1.859376 2.929687-4.441407 2.929687-7.070313s-1.070313-5.210937-2.929687-7.070313c-1.859376-1.859374-4.441407-2.929687-7.070313-2.929687zm0 0\"/></svg>\r\n )\r\n}","import React, { memo, useMemo, useState, useEffect } from 'react'\r\nimport ContentContainer from '../../components/ContentContainer';\r\nimport GridBlock from '../../components/GridBlock';\r\nimport { useTranslation } from 'react-i18next';\r\nimport RouterPath from '../../const/RouterPath';\r\nimport TechnologiesCard from '../../components/TechnologiesCard';\r\nimport CardItems from '../../const/CardItems';\r\nimport initialStateCard from './initialStateCard';\r\nimport { makeStyles } from '@material-ui/core/styles'\r\nimport { Box } from '@material-ui/core';\r\nimport withWidth from '@material-ui/core/withWidth';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n container: {\r\n '&>:nth-child(3)': {\r\n display: \"none\",\r\n [theme.breakpoints.down(\"lg\")]: {\r\n display: \"block\",\r\n flexBasis: '100%',\r\n height: 0,\r\n }\r\n },\r\n [theme.breakpoints.down('lg')]: {\r\n justifyContent: \"space-around\",\r\n '&> *': {\r\n marginBottom: theme.spacing(2)\r\n }\r\n },\r\n }\r\n}))\r\n\r\nfunction Technologies({ width, ...props }) {\r\n const classes = useStyles(props);\r\n const { t } = useTranslation();\r\n\r\n const [open, setOpen] = useState(initialStateCard)\r\n\r\n useEffect(() => {\r\n if (width === 'xs' || width === 'sm') {\r\n let idInterval = setTimeout(() => {\r\n window.addEventListener('click', function (e) {\r\n if (!document.getElementById(\"tutaj\").contains(e.target)) {\r\n setOpen(initialStateCard)\r\n }\r\n })\r\n }, 100);\r\n return () => clearTimeout(idInterval);\r\n }\r\n }, [open, width])\r\n\r\n const generateCards = useMemo(() => {\r\n const tab = []\r\n CardItems.forEach((item, i) => {\r\n if (i === 2) tab.push(<Box key={i + 5} />)\r\n tab.push(<TechnologiesCard\r\n id={`card${i + 1}`}\r\n key={i}\r\n open={open}\r\n setOpen={setOpen}\r\n Avatar={item.avatar}\r\n title={t(item.title)}\r\n items={item.items}\r\n />)\r\n })\r\n return tab\r\n }, [t, open])\r\n\r\n return (\r\n <ContentContainer\r\n title={t(\"technologies_title\")}\r\n id={RouterPath.anchors.TECHNOLOGIES}\r\n alignContent=\"stretch\"\r\n >\r\n <GridBlock id=\"tutaj\" justify=\"space-between\" className={classes.container}>\r\n {generateCards}\r\n </GridBlock>\r\n </ContentContainer>\r\n )\r\n}\r\n\r\nexport default memo(withWidth()(Technologies));\r\n","import React, { memo, useMemo } from 'react'\nimport ContentContainer from '../../components/ContentContainer';\nimport { makeStyles } from '@material-ui/core/styles'\nimport GridBlock from '../../components/GridBlock';\nimport { useTranslation } from 'react-i18next';\nimport SkillsBackground from '../../images/Artboard.png';\nimport { Typography } from '@material-ui/core';\nimport { Parallax } from 'react-parallax';\n\nconst useStyles = makeStyles(theme => ({\n skills: {\n ...theme.maxResolution,\n height: 400,\n color: theme.palette.primary.main,\n },\n container: {\n paddingRight: theme.spacing(4),\n },\n skillText: {\n marginBottom: theme.spacing(),\n [theme.breakpoints.down('sm')]: {\n fontSize: '1rem'\n }\n },\n}))\n\nconst trList = [\n \"analysis\",\n \"project_management\",\n \"direct_work_with_client\",\n \"outsourcing\",\n \"fixed_price\",\n \"time_material\",\n]\n\nfunction Skills(props) {\n const classes = useStyles(props);\n const { t } = useTranslation();\n\n const list = useMemo(() => trList.map((x, i) => {\n return <Typography\n key={i}\n variant=\"h6\"\n className={classes.skillText}\n >\n {t(x).toUpperCase()}\n </Typography>\n }), [t, classes])\n\n return (\n <Parallax\n bgImage={SkillsBackground}\n bgImageAlt=\"skills list\"\n strength={250}\n >\n <ContentContainer\n className={classes.skills}\n // title={t(\"skills_title\")}\n alignContent=\"flex-end\"\n alignItems=\"flex-end\"\n justify=\"center\"\n >\n <GridBlock alignItems=\"flex-end\" direction=\"column\" className={classes.container}>\n {list}\n </GridBlock>\n </ContentContainer>\n </Parallax>\n )\n}\n\nexport default memo(Skills)\n","import React, { memo, useMemo } from 'react'\r\nimport { Typography, Box, withWidth } from '@material-ui/core';\r\nimport ContentContainer from '../../components/ContentContainer';\r\nimport { makeStyles } from '@material-ui/core/styles'\r\nimport GridBlock from '../../components/GridBlock';\r\nimport { useTranslation } from 'react-i18next';\r\nimport RouterPath from '../../const/RouterPath';\r\nimport Email from '../../images/pictogram/Email';\r\nimport Home from '../../images/pictogram/Home';\r\nimport Phone from '../../images/pictogram/Phone';\r\n\r\nconst contactTab = [\r\n {\r\n icon: Email,\r\n text: `info@doittechnology.pl`,\r\n href: \"mailto:info@doittechnology.pl\",\r\n },\r\n {\r\n icon: Phone,\r\n text: '+48 884 217 822',\r\n href: \"tel:+48884217822\",\r\n },\r\n {\r\n empty: true\r\n },\r\n {\r\n icon: Home,\r\n text: 'Barbakan 12/5,\\nSzczecin 71-028\\nPoland',\r\n // href: \"https://www.google.pl/maps/place/Barbakan+12,+71-028+Szczecin/@53.411855,14.4931474,17z/data=!3m1!4b1!4m6!3m5!1s0x47aa0f2dacee1265:0xbce9050201e3486e!8m2!3d53.411855!4d14.4957223!16s%2Fg%2F11h2c289k8?entry=ttu\",\r\n blank: '_blank'\r\n }\r\n]\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n about: {\r\n background: \"black\",\r\n color: \"white\",\r\n },\r\n mainContainer: {\r\n padding: `0 ${theme.spacing(8)}px`,\r\n '& a': {\r\n textDecoration: \"unset\",\r\n color: \"white\",\r\n '& :hover': {\r\n textDecoration: \"underline\",\r\n }\r\n },\r\n [theme.breakpoints.down('md')]: {\r\n padding: 0,\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n },\r\n [theme.breakpoints.down('sm')]: {\r\n flexDirection: \"column\",\r\n \"&>:nth-child(2)\": {\r\n margin: `${theme.spacing(4)}px 0`\r\n }\r\n },\r\n [theme.breakpoints.between('md', 'lg')]: {\r\n justifyContent: \"space-around\",\r\n '&>:nth-child(3)': {\r\n flexBasis: \"100%\",\r\n },\r\n },\r\n },\r\n itemContainer: {\r\n width: 300,\r\n height: 150,\r\n padding: `0 ${theme.spacing(5)}px`,\r\n textAlign: \"center\",\r\n whiteSpace: \"pre-wrap\",\r\n '&>:first-child': {\r\n marginBottom: theme.spacing(2),\r\n }\r\n },\r\n icon: {\r\n width: 50,\r\n height: 50,\r\n fill: theme.palette.primary.main,\r\n color: theme.palette.primary.main,\r\n }\r\n}))\r\n\r\nfunction About({ width, ...props }) {\r\n const classes = useStyles(props);\r\n const { t } = useTranslation();\r\n\r\n const tabs = useMemo(() => contactTab.map((x, i) => {\r\n const tab = [];\r\n const Icon = x.icon ? x.icon : <></>;\r\n if ((width === \"lg\" || width === 'md') && i === (contactTab.length / 2)) tab.push(<Box key={Math.random()} />)\r\n if (x.empty) {\r\n tab.push(<div key={i}>\r\n <GridBlock\r\n alignItems=\"center\"\r\n direction=\"column\"\r\n className={classes.itemContainer}\r\n >\r\n </GridBlock>\r\n </div>)\r\n } else {\r\n tab.push(<a key={i} href={x.href} target={x.blank && x.blank}>\r\n <GridBlock\r\n alignItems=\"center\"\r\n direction=\"column\"\r\n className={classes.itemContainer}\r\n >\r\n <Icon className={classes.icon} />\r\n <Typography variant='body1'>\r\n {x.text}\r\n </Typography>\r\n </GridBlock>\r\n </a>)\r\n }\r\n\r\n return tab\r\n }), [classes, width])\r\n\r\n return (\r\n <ContentContainer\r\n title={t(\"contact\")}\r\n className={classes.about}\r\n id={RouterPath.anchors.CONTACT}\r\n alignContent=\"stretch\"\r\n >\r\n <GridBlock justify=\"space-between\" algin=\"center\" className={classes.mainContainer}>\r\n\r\n {tabs}\r\n </GridBlock>\r\n </ContentContainer>\r\n )\r\n}\r\n\r\nexport default memo(withWidth()(About));\r\n\r\n\r\n","import React from 'react'\r\n\r\nexport default (props) => {\r\n return (\r\n <svg {...props} version=\"1.1\" id=\"Warstwa_1\" xmlns=\"http://www.w3.org/2000/svg\" xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\r\n viewBox=\"-243 245 24 24\" space=\"preserve\">\r\n <path d=\"M-223,249h-16c-1.1,0-2,0.9-2,2l0,12c0,1.1,0.9,2,2,2h16c1.1,0,2-0.9,2-2v-12C-221,249.9-221.9,249-223,249z M-223,253l-8,5\r\n l-8-5v-2l8,5l8-5V253z\"/>\r\n </svg>\r\n )\r\n}","import React from 'react'\r\n\r\nexport default (props) => {\r\n return (\r\n <svg {...props} xmlns=\"http://www.w3.org/2000/svg\" height=\"24\" viewBox=\"0 0 24 24\" width=\"24\"><path d=\"M0 0h24v24H0z\" fill=\"none\"/><path d=\"M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z\"/></svg>\r\n )\r\n}","import React from 'react'\r\n\r\nexport default (props) => {\r\n return (\r\n <svg {...props} xmlns=\"http://www.w3.org/2000/svg\" height=\"24\" viewBox=\"0 0 24 24\" width=\"24\"><path d=\"M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z\"/><path d=\"M0 0h24v24H0z\" fill=\"none\"/></svg>\r\n )\r\n}","import React, { memo } from 'react'\r\nimport ContentContainer from '../../components/ContentContainer';\r\nimport { makeStyles } from '@material-ui/core/styles'\r\n// import { useTranslation } from 'react-i18next';\r\nimport RibbonBackground from '../../images/airplane.png';\r\n// import { Typography } from '@material-ui/core';\r\nimport { Parallax } from 'react-parallax';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n skills: {\r\n color: theme.palette.primary.main,\r\n height: 300\r\n },\r\n}))\r\n\r\n\r\nfunction Ribbon(props) {\r\n const classes = useStyles(props);\r\n // const { t } = useTranslation();\r\n\r\n return (\r\n <Parallax\r\n bgImage={RibbonBackground}\r\n bgImageAlt=\"ribbon\"\r\n strength={300}\r\n >\r\n <ContentContainer\r\n className={classes.skills}\r\n // title={t(\"skills_title\")}\r\n justify=\"flex-end\"\r\n >\r\n {/* <Typography>\r\n {t('ribbon_text')}\r\n </Typography> */}\r\n </ContentContainer>\r\n </Parallax>\r\n )\r\n}\r\n\r\nexport default memo(Ribbon)\r\n","import React, { memo } from 'react';\r\nimport { TextField, FormHelperText, makeStyles } from '@material-ui/core';\r\nimport { useFormikContext } from 'formik';\r\n\r\nconst useStyles = makeStyles((theme) => ({\r\n formHelper: {\r\n margin: 0,\r\n paddingLeft: 8,\r\n },\r\n})\r\n);\r\n\r\n\r\nfunction TextInput({\r\n id, label, autoComplete, type, required = false, multiline = false, className\r\n}) {\r\n const classes = useStyles();\r\n\r\n const { getFieldProps, getFieldMeta } = useFormikContext();\r\n\r\n const fieldMeta = getFieldMeta(id);\r\n\r\n const {\r\n name,\r\n onBlur,\r\n onChange,\r\n value,\r\n } = getFieldProps(id);\r\n\r\n const isError = !!fieldMeta.error && fieldMeta.touched\r\n const helperText = fieldMeta.error || '';\r\n\r\n return (\r\n <>\r\n <TextField\r\n id={id}\r\n label={label}\r\n name={name}\r\n autoComplete={autoComplete}\r\n variant=\"outlined\"\r\n margin=\"normal\"\r\n type={type}\r\n fullWidth\r\n required={required}\r\n multiline={multiline}\r\n className={className}\r\n onChange={onChange}\r\n onBlur={onBlur}\r\n value={value}\r\n error={isError}\r\n\r\n />\r\n <FormHelperText\r\n error={isError}\r\n classes={{\r\n root: classes.formHelper,\r\n }}\r\n >\r\n {isError ? helperText : \" \"}\r\n </FormHelperText>\r\n </>\r\n );\r\n}\r\n\r\nexport default memo(TextInput)\r\n","import React, { memo } from 'react'\r\nimport { FormControlLabel, Checkbox as CheckboxUI, FormHelperText, makeStyles } from '@material-ui/core';\r\nimport { useFormikContext } from 'formik';\r\nimport clsx from 'clsx';\r\n\r\nconst useStyles = makeStyles((theme) => ({\r\n formHelper: {\r\n margin: 0,\r\n marginTop: 8,\r\n paddingLeft: 32,\r\n },\r\n error: {\r\n color: \"red\"\r\n }\r\n})\r\n);\r\n\r\nfunction Checkbox({\r\n id,\r\n label,\r\n disabled,\r\n checkboxClassName,\r\n fullWidth,\r\n className,\r\n labelClassName,\r\n required,\r\n tab\r\n}) {\r\n const classes = useStyles();\r\n\r\n const { getFieldProps, getFieldMeta, setFieldValue } = useFormikContext();\r\n\r\n let oldId = id\r\n id = tab ? tab : id\r\n\r\n let {\r\n name,\r\n onBlur,\r\n onChange,\r\n value,\r\n } = getFieldProps(id);\r\n\r\n if (tab) {\r\n value = value[oldId]\r\n name = oldId\r\n onChange = () => {\r\n setFieldValue(`${tab}.${name}`, !value)\r\n }\r\n }\r\n\r\n\r\n const fieldMeta = getFieldMeta(id);\r\n\r\n\r\n const isError = !!fieldMeta.error && fieldMeta.touched\r\n const helperText = fieldMeta.error || '';\r\n\r\n const checkbox = <CheckboxUI\r\n color='primary'\r\n name={name}\r\n checked={value}\r\n onChange={onChange}\r\n onBlur={onBlur}\r\n disabled={disabled}\r\n className={checkboxClassName}\r\n classes={{\r\n root: clsx({ [classes.error]: isError }),\r\n }}\r\n />\r\n if (Boolean(label)) {\r\n return <>\r\n <FormControlLabel\r\n className={className}\r\n style={fullWidth ? { width: '100%' } : undefined}\r\n control={checkbox}\r\n label={label}\r\n classes={{\r\n root: clsx({ [classes.error]: isError }),\r\n label: labelClassName\r\n }}\r\n />\r\n {required &&\r\n <FormHelperText\r\n error={isError}\r\n classes={{\r\n root: classes.formHelper,\r\n }}\r\n >\r\n {isError ? helperText : \" \"}\r\n </FormHelperText>\r\n }\r\n </>\r\n }\r\n return checkbox;\r\n}\r\n\r\nexport default memo(Checkbox)\r\n","import React, { memo, useMemo } from 'react';\r\nimport { makeStyles } from '@material-ui/core/styles';\r\nimport FormLabel from '@material-ui/core/FormLabel';\r\nimport FormControl from '@material-ui/core/FormControl';\r\nimport FormGroup from '@material-ui/core/FormGroup';\r\nimport { useTranslation } from 'react-i18next';\r\nimport Checkbox from './Checkbox';\r\nimport { FormHelperText } from '@material-ui/core';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n root: {\r\n display: 'flex',\r\n },\r\n formControl: {\r\n margin: theme.spacing(3),\r\n [theme.breakpoints.down('xs')]: {\r\n margin: `${theme.spacing(3)}px 0`\r\n }\r\n },\r\n formHelper: {\r\n margin: 0,\r\n marginTop: theme.spacing(-2),\r\n paddingLeft: theme.spacing(3),\r\n },\r\n}));\r\n\r\nfunction CheckboxesGroup({ items, label, error }) {\r\n const classes = useStyles();\r\n const { t } = useTranslation()\r\n\r\n const checkboxList = useMemo(() => items.map((x, i) => {\r\n return <Checkbox id={`checkbox_scope${i + 1}`} key={i} label={t(x)} tab=\"scope\" />\r\n }), [items, t])\r\n\r\n return <>\r\n <FormControl\r\n required\r\n component=\"fieldset\"\r\n className={classes.formControl}\r\n >\r\n <FormLabel component=\"legend\">{label}</FormLabel>\r\n <FormGroup>\r\n {checkboxList}\r\n </FormGroup>\r\n </FormControl>\r\n <FormHelperText\r\n error={error}\r\n classes={{\r\n root: classes.formHelper,\r\n }}\r\n >\r\n {error ? t('checkbox_group_error') : \" \"}\r\n </FormHelperText>\r\n </>\r\n}\r\n\r\nexport default memo(CheckboxesGroup)\r\n","import React, { memo } from 'react'\nimport { FormControlLabel, Radio as RadioUI } from '@material-ui/core';\n\nfunction Radio({\n label,\n value,\n disabled,\n className,\n labelClassName,\n}) {\n\n return <FormControlLabel\n value={value}\n className={className}\n control={<RadioUI color=\"primary\"/>}\n label={label}\n classes={{\n label: labelClassName\n }}\n disabled={disabled}\n />\n}\n\nexport default memo(Radio)\n","import React, { memo, useMemo } from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport FormLabel from '@material-ui/core/FormLabel';\nimport FormControl from '@material-ui/core/FormControl';\nimport { useTranslation } from 'react-i18next';\nimport Radio from './Radio';\nimport { RadioGroup as RadioGroupUI } from '@material-ui/core';\nimport { useFormikContext } from 'formik';\n\nconst useStyles = makeStyles(theme => ({\n root: {\n display: 'flex',\n },\n formControl: {\n margin: theme.spacing(3),\n [theme.breakpoints.down('xs')]: {\n margin: `${theme.spacing(3)}px 0`\n }\n },\n}));\n\nfunction RadioGroup({\n items,\n label,\n id\n}) {\n const classes = useStyles();\n const { t } = useTranslation()\n\n const { getFieldProps } = useFormikContext();\n\n const {\n name,\n onBlur,\n onChange,\n value,\n } = getFieldProps(id);\n\n const radioList = useMemo(() => items.map((x, i) => {\n return <Radio key={i} value={\"\" + i} label={t(x)} />\n }), [items, t])\n\n return (\n <FormControl\n component=\"fieldset\"\n className={classes.formControl}\n >\n <FormLabel component=\"legend\">{label}</FormLabel>\n <RadioGroupUI\n name={name}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n >\n {radioList}\n </RadioGroupUI>\n </FormControl>\n )\n}\n\nexport default memo(RadioGroup)\n","export const idTab = [\r\n \"name_surname\",\r\n \"email\",\r\n \"phone\",\r\n \"country\"\r\n]\r\n\r\nexport const likeList = [\r\n \"checkbox_like1\",\r\n \"checkbox_like2\",\r\n \"checkbox_like3\"\r\n]\r\n\r\nexport const scopeList = [\r\n \"Design( UX/UI )\",\r\n \"React\",\r\n \"Node( js/ts )\",\r\n \"React Native\",\r\n \"Java( Spring )\",\r\n \"Python\",\r\n \"Flutter\",\r\n \"Solidity( Smart Contracts )\"\r\n]\r\n\r\nexport const initialValues = () => {\r\n let scope = {}\r\n scopeList.forEach((x, i) => scope[`checkbox_scope${i + 1}`] = false);\r\n return {\r\n name_surname: '',\r\n email: '',\r\n phone: '',\r\n country: '',\r\n description: '',\r\n radio: \"0\",\r\n scope,\r\n consent: false\r\n }\r\n}\r\n","import React, { memo, useEffect, useRef } from 'react'\r\nimport { makeStyles, Typography } from '@material-ui/core';\r\nimport CheckIcon from '@material-ui/icons/Check';\r\nimport CachedIcon from '@material-ui/icons/Cached';\r\nimport './button.scss';\r\nimport ErrorIcon from '@material-ui/icons/Error';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n // \"@keyframes loading\": {\r\n // \"100%\": {\r\n // transform: \"rotate(360deg)\"\r\n // }\r\n // },\r\n // \"@keyframes scale\": {\r\n // \"0%\": { transform: \"scale(10)\" },\r\n // \"50%\": { transform: \"scale(0.2)\" },\r\n // \"70%\": { transform: \"scale(1.2)\" },\r\n // \"90%\": { transform: \"scale(0.7)\" },\r\n // \"100%\": { transform: \"scale(1)\" },\r\n // },\r\n\r\n // \"*, *:before, *:after\": {\r\n // \"box-sizing\": \"border-box\",\r\n // \"outline\": \"none\",\r\n // },\r\n\r\n // hide: {\r\n // \"display\": \"none\",\r\n // },\r\n // button: {\r\n // \"position\": \"relative\",\r\n // \"display\": \"flex\",\r\n // \"flex-direction\": \"column\",\r\n // \"align-items\": \"center\",\r\n // \"justify-content\": \"center\",\r\n // \"width\": \"12.5rem\",\r\n // \"margin\": \"0\",\r\n // \"padding\": \"1.5rem 3.125rem\",\r\n // \"background-color\": \"red\",\r\n // \"border\": \"none\",\r\n // \"border-radius\": \"0.3125rem\",\r\n // \"box-shadow\": \"0 12px 24px 0 rgba(0,0,0,0.2)\",\r\n // \"color\": \"white\",\r\n // \"font-weight\": \"300\",\r\n // \"text-transform\": \"uppercase\",\r\n // \"overflow\": \"hidden\",\r\n\r\n // \"&:before\": {\r\n // \"position\": \"absolute\",\r\n // \"content\": \"''\",\r\n // \"bottom\": \"0\",\r\n // \"left\": \"0\",\r\n // \"width\": \"0%\",\r\n // \"height\": \"100%\",\r\n // // \"background-color\": \"lighten(blue,10%)\",\r\n // \"background-color\": \"green\",\r\n // },\r\n // \"& span\": {\r\n // \"position\": \"absolute\",\r\n // \"line-height\": 0,\r\n // \"& i\": {\r\n // transformOrigin: \"center center\",\r\n // },\r\n // \"& :nth-of-type(1)\": {\r\n // top: \"50%\",\r\n // transform: \"translateY(-50%)\",\r\n // },\r\n // \"& :nth-of-type(2)\": {\r\n // top: \"100%\",\r\n // transform: \"translateY(0%)\",\r\n // \"font-size\": 24,\r\n // },\r\n // \"& :nth-of-type(3)\": {\r\n // display: \"none\",\r\n // }\r\n // }\r\n // },\r\n // active: {\r\n // \"background-color\": \"blue\",\r\n // \"&:before\": {\r\n // width: \"100%\",\r\n // transition: \"width 3s linear\",\r\n // },\r\n // \"& span\": {\r\n // \"& :nth-of-type(1)\": {\r\n // top: \"-100%\",\r\n // transform: \"translateY(-50%)\",\r\n // },\r\n // \"& :nth-of-type(2)\": {\r\n // top: \"50%\",\r\n // transform: \"translateY(-50%)\",\r\n // \"& svg\": {\r\n // animation: \"loading 500 linear infinite\",\r\n // }\r\n // },\r\n // \"& :nth-of-type(3)\": {\r\n // display: \"none\",\r\n // }\r\n // }\r\n // },\r\n // finished: {\r\n // // \"background-color\": \"lighten(blue,10%)\",\r\n // \"background-color\": \"pink\",\r\n // \"& .submit\": {\r\n // display: \"none\",\r\n // },\r\n // \"& .loading\": {\r\n // display: \"none\",\r\n // },\r\n // \"& .check\": {\r\n // display: \" block !important\",\r\n // \"font-size\": \"24px\",\r\n // animation: \"scale 0.5s linear\",\r\n // \"& svg\": {\r\n // \"transform-origin\": \"center center\",\r\n // }\r\n // },\r\n // },\r\n error: {\r\n fontSize: 10,\r\n marginLeft: theme.spacing(2),\r\n width: 80,\r\n }\r\n}))\r\n\r\n\r\nfunction SendButton({ errorMail, buttonAnimation, buttonAnimationEnd, setButtonAnimationEnd, label, ...props }) {\r\n const classes = useStyles(props);\r\n\r\n const button = useRef(null)\r\n\r\n useEffect(() => {\r\n if (buttonAnimation) {\r\n button.current.classList.toggle('active')\r\n }\r\n if (buttonAnimationEnd) {\r\n button.current.classList.add('finished')\r\n const timer = setTimeout(() => {\r\n setButtonAnimationEnd(false)\r\n }, 2000);\r\n return () => clearTimeout(timer);\r\n }\r\n if (!buttonAnimationEnd && !buttonAnimation && !errorMail) {\r\n button.current.classList.remove('active')\r\n button.current.classList.remove('finished')\r\n }\r\n }, [buttonAnimation, buttonAnimationEnd, errorMail,setButtonAnimationEnd])\r\n\r\n\r\n return (\r\n <div className=\"btn\">\r\n <button ref={button} className=\"button\">\r\n <span className=\"submit\">{label}</span>\r\n <span className=\"loading\">\r\n <CachedIcon />\r\n </span>\r\n <span className=\"check\">\r\n {errorMail ?\r\n <div style={{display: \"flex\", alignItems: \"center\"}}>\r\n <ErrorIcon />\r\n <Typography className={classes.error}>\r\n {\"Something went wrong\"}\r\n </Typography>\r\n </div>\r\n : <CheckIcon />}\r\n </span>\r\n </button>\r\n </div >\r\n )\r\n}\r\n\r\nexport default memo(SendButton)\r\n","import React, { memo, useCallback, useMemo, useState } from 'react'\r\nimport { Formik, Form } from 'formik';\r\nimport TextInput from '../../components/TextInput';\r\nimport { useTranslation } from 'react-i18next';\r\nimport GridBlock from '../../components/GridBlock';\r\nimport { makeStyles, Box } from '@material-ui/core';\r\nimport CheckboxGroup from '../../components/CheckboxGroup';\r\nimport RadioGroup from '../../components/RadioGroup';\r\nimport { idTab, scopeList, likeList, initialValues } from './FormConstants';\r\nimport * as Yup from 'yup';\r\nimport Checkbox from '../../components/Checkbox';\r\nimport SendButton from '../../components/SendButton/SendButton';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n container: {\r\n padding: theme.spacing(3),\r\n '&>:last-child': {\r\n width: 280,\r\n [theme.breakpoints.down('xs')]: {\r\n width: 200,\r\n },\r\n '& button': {\r\n height: 45,\r\n marginTop: theme.spacing(3)\r\n }\r\n }\r\n },\r\n group: {\r\n width: '100%',\r\n [theme.breakpoints.down('sm')]: {\r\n '&>*': {\r\n width: '100%',\r\n }\r\n },\r\n [theme.breakpoints.up('md')]: {\r\n '&> *': {\r\n width: '31%',\r\n },\r\n '&>:last-child': {\r\n width: '35%',\r\n },\r\n }\r\n }\r\n}))\r\n\r\n\r\nfunction EstimationForm(props) {\r\n const classes = useStyles(props);\r\n const { t } = useTranslation();\r\n\r\n const [error, setError] = useState(false)\r\n const [errorMail, setErrorMail] = useState(false)\r\n\r\n const [buttonAnimation, setButtonAnimation] = useState(false)\r\n const [buttonAnimationEnd, setButtonAnimationEnd] = useState(false)\r\n\r\n const handleSubmit = useCallback((values, e) => {\r\n if (errorMail) {\r\n setErrorMail(false)\r\n setButtonAnimation(false)\r\n setButtonAnimationEnd(false)\r\n e.resetForm()\r\n }\r\n else {\r\n setButtonAnimation(true)\r\n const { country, description, email, name_surname, phone, radio, consent, ...other } = values;\r\n let obj = { name_surname, email, phone, country, description, like: t(likeList[radio]), scope: [] };\r\n\r\n Object.keys(other.scope).forEach((x, i) => {\r\n if (other.scope[x]) {\r\n obj.scope.push(scopeList[i])\r\n }\r\n });\r\n\r\n fetch('/api/v1/sendEmail', {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n },\r\n body: JSON.stringify(obj),\r\n })\r\n .then((response) => {\r\n if (response.status !== 200) {\r\n setErrorMail(response.statusText)\r\n } else {\r\n e.resetForm()\r\n }\r\n setButtonAnimation(false)\r\n setButtonAnimationEnd(true)\r\n\r\n return response.json();\r\n })\r\n }\r\n }, [t, errorMail])\r\n\r\n const createTextInput = useMemo(() => idTab.map((x, i) => {\r\n return <TextInput\r\n id={x}\r\n key={i}\r\n label={t(x)}\r\n className={classes.textInput}\r\n />\r\n }), [t, classes])\r\n\r\n const initialValuesMemo = useMemo(() => initialValues(), [])\r\n const validationSchemaMemo = useMemo(() => {\r\n return Yup.lazy((values) => {\r\n let validateObj = {\r\n name_surname: Yup.string().required(t('required')),\r\n email: Yup.string().email(t('email_error')).required(t('required')),\r\n phone: Yup.number(),\r\n country: Yup.string(),\r\n description: Yup.string(),\r\n consent: Yup.bool().oneOf([true], 'Field must be checked'),\r\n }\r\n\r\n let checkboxCounter = 0\r\n Object.values(values.scope).forEach(x => {\r\n if (x) checkboxCounter += 1\r\n });\r\n\r\n if (checkboxCounter < 2) {\r\n validateObj = {\r\n ...validateObj,\r\n scope: Yup.array().min(2)\r\n }\r\n setError(true)\r\n } else {\r\n setError()\r\n }\r\n\r\n return Yup.object().shape(validateObj)\r\n })\r\n\r\n }, [t])\r\n\r\n return (\r\n <Formik\r\n initialValues={initialValuesMemo}\r\n validationSchema={validationSchemaMemo}\r\n onSubmit={handleSubmit}\r\n >\r\n <Form>\r\n <GridBlock justify=\"space-between\" alignItems=\"center\" column className={classes.container}>\r\n <GridBlock justify=\"space-between\" className={classes.group}>\r\n <Box className={classes.textInputBox}>\r\n {createTextInput}\r\n </Box>\r\n <RadioGroup id=\"radio\" items={likeList} label={t('checkbox_group1_label')} />\r\n <CheckboxGroup id=\"scope\" items={scopeList} label={t('checkbox_group2_label')} error={error} />\r\n </GridBlock>\r\n <TextInput\r\n id=\"description\"\r\n label={t(\"description\")}\r\n multiline\r\n />\r\n <Checkbox id=\"consent\" label={t(\"consent\")} required />\r\n <SendButton\r\n label={t(\"home_context_button\")}\r\n buttonAnimation={buttonAnimation}\r\n buttonAnimationEnd={buttonAnimationEnd}\r\n setButtonAnimationEnd={setButtonAnimationEnd}\r\n errorMail={errorMail}\r\n />\r\n </GridBlock>\r\n </Form>\r\n </Formik >\r\n )\r\n}\r\n\r\nexport default memo(EstimationForm)\r\n","import React, { memo } from 'react'\r\nimport { Typography } from '@material-ui/core';\r\nimport ContentContainer from '../../components/ContentContainer';\r\nimport { makeStyles } from '@material-ui/core/styles'\r\nimport GridBlock from '../../components/GridBlock';\r\nimport { useTranslation } from 'react-i18next';\r\nimport RouterPath from '../../const/RouterPath';\r\nimport ThumbUpIcon from '@material-ui/icons/ThumbUp';\r\nimport EstimationForm from './EstimationForm';\r\n\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n estimation: {\r\n background: theme.palette.lightBackground.main\r\n },\r\n cardBox: {\r\n background: 'white',\r\n boxShadow: theme.shadows[1],\r\n borderRadius: theme.spacing(2),\r\n [theme.breakpoints.down('md')]: {\r\n flexDirection: \"column-reverse\",\r\n },\r\n \"&>:first-child\": {\r\n width: '75%',\r\n borderBottomLeftRadius: theme.spacing(2),\r\n borderTopLeftRadius: theme.spacing(2),\r\n\r\n [theme.breakpoints.down('md')]: {\r\n width: \"unset\",\r\n borderTopLeftRadius: 'unset',\r\n borderBottomLeftRadius: theme.spacing(2),\r\n borderBottomRightRadius: theme.spacing(2),\r\n }\r\n },\r\n \"&>:nth-child(2)\": {\r\n textAlign: \"justify\",\r\n padding: theme.spacing(3),\r\n width: '25%',\r\n background: theme.palette.primary.main,\r\n color: 'white',\r\n borderBottomRightRadius: theme.spacing(2),\r\n borderTopRightRadius: theme.spacing(2),\r\n \r\n [theme.breakpoints.down('md')]: {\r\n width: \"unset\",\r\n borderTopRightRadius: theme.spacing(2),\r\n borderTopLeftRadius: theme.spacing(2),\r\n borderBottomRightRadius: 'unset'\r\n }\r\n }\r\n },\r\n avatar: {\r\n width: 100,\r\n height: 100,\r\n marginBottom: theme.spacing(2),\r\n },\r\n contentWrapper:{\r\n marginTop: theme.spacing(2),\r\n whiteSpace: \"pre-wrap\"\r\n }\r\n}))\r\n\r\nfunction Estimation(props) {\r\n const classes = useStyles(props);\r\n const { t } = useTranslation();\r\n\r\n return (\r\n <ContentContainer\r\n title={t(\"estimation_title\")}\r\n id={RouterPath.anchors.ESTIMATION}\r\n className={classes.estimation}\r\n >\r\n <GridBlock justify=\"space-between\" className={classes.cardBox}>\r\n <EstimationForm />\r\n <GridBlock justify=\"space-between\" alignItems=\"center\" direction=\"column\">\r\n <ThumbUpIcon className={classes.avatar} />\r\n <Typography variant='body1'>\r\n {t(\"estimation_title\")}\r\n </Typography>\r\n <Typography variant='body1' className={classes.contentWrapper}>\r\n {t(\"estimation_content\")}\r\n </Typography>\r\n </GridBlock>\r\n </GridBlock >\r\n </ContentContainer >\r\n )\r\n}\r\n\r\nexport default memo(Estimation)\r\n","import React, { memo } from \"react\";\nimport { Dialog, DialogTitle, IconButton } from \"@material-ui/core\";\nimport { makeStyles } from '@material-ui/styles';\nimport CloseIcon from '@material-ui/icons/Close';\n\nconst useStyles = makeStyles(theme => ({\n image: {\n objectFit: \"contain\",\n height: '80vh'\n },\n paperFullScreen: {\n background: `linear-gradient(180deg, rgba(226,226,226,1) 0%, rgba(126,126,126,1) 70%, rgba(226,226,226,1) 100%)`,\n // height: 'unset'\n height: '100vh',\n display: \"flex\",\n justifyContent: \"center\"\n },\n title: {\n position: \"fixed\",\n top: 0,\n right: 0\n }\n}))\nfunction ImageDialog({ props, open, image, onClose }) {\n const classes = useStyles(props);\n\n const handleClose = () => {\n onClose();\n };\n\n return (\n <Dialog\n fullScreen\n open={open}\n onClose={handleClose}\n classes={{\n paperFullScreen: classes.paperFullScreen\n }}\n >\n <DialogTitle className={classes.title}>\n <IconButton aria-label=\"close\" className={classes.closeButton} onClick={onClose}>\n <CloseIcon />\n </IconButton>\n </DialogTitle>\n\n <img className={classes.image} src={image} alt=\"preview-projects\" />\n </Dialog>\n );\n}\n\nexport default memo(ImageDialog)\n","import React, { useMemo, useState, useCallback } from 'react'\nimport ArrowBackIosIcon from '@material-ui/icons/ArrowBackIos';\nimport ArrowForwardIosIcon from '@material-ui/icons/ArrowForwardIos';\nimport { makeStyles } from '@material-ui/styles';\nimport { IconButton, Typography, Box, Hidden } from '@material-ui/core';\nimport GridBlock from '../GridBlock';\nimport clsx from 'clsx';\nimport ImageDialog from '../ImageDialog';\n\nconst useStyles = makeStyles(theme => ({\n '@keyframes show': {\n '0%': {\n opacity: 0\n }\n },\n contentContainer: {\n marginBottom: theme.spacing(2),\n margin: '0 auto',\n },\n cardBox: {\n display: 'flex',\n width: 'unset',\n boxShadow: theme.shadows[6],\n margin: `0 ${theme.spacing(2)}px`,\n\n borderRadius: theme.spacing(2),\n [theme.breakpoints.down('md')]: {\n flexDirection: \"column-reverse\",\n },\n\n \"&>:first-child\": {\n background: `linear-gradient(180deg, rgba(226,226,226,1) 0%, rgba(126,126,126,1) 70%, rgba(226,226,226,1) 100%)`,\n borderBottomLeftRadius: theme.spacing(2),\n borderTopLeftRadius: theme.spacing(2),\n\n [theme.breakpoints.down('md')]: {\n borderTopLeftRadius: 'unset',\n borderBottomLeftRadius: theme.spacing(2),\n borderBottomRightRadius: theme.spacing(2),\n }\n },\n \"&>:nth-child(2)\": {\n width: 300,\n padding: theme.spacing(3),\n background: theme.palette.primary.main,\n color: 'white',\n textAlign: \"left\",\n\n borderTopRightRadius: theme.spacing(2),\n borderBottomRightRadius: theme.spacing(2),\n [theme.breakpoints.up('lg')]: {\n paddingTop: theme.spacing(6)\n },\n [theme.breakpoints.down('md')]: {\n paddingTop: theme.spacing(2),\n textAlign: \"justify\",\n borderBottomRightRadius: 'unset',\n borderTopRightRadius: theme.spacing(2),\n borderTopLeftRadius: theme.spacing(2),\n width: 700,\n height: 200,\n },\n [theme.breakpoints.down('sm')]: {\n paddingTop: theme.spacing(2),\n borderBottomRightRadius: 'unset',\n width: 550,\n height: 150,\n '& p': {\n fontSize: 12\n }\n },\n [theme.breakpoints.only('xs')]: {\n '& p': {\n fontSize: 11\n },\n width: 250,\n height: 200,\n }\n }\n },\n animation: {\n opacity: 1,\n animationName: '$show',\n animationDuration: '1s',\n animationTimingFunction: 'ease-in-out',\n },\n title: {\n margin: `${theme.spacing(3)}px 0 ${theme.spacing(5)}px`,\n [theme.breakpoints.down('sm')]: {\n margin: `${theme.spacing(1)}px 0 ${theme.spacing(2)}px`,\n }\n },\n imageBox: {\n display: \"flex\",\n justifyContent: \"center\",\n [theme.breakpoints.only('xl')]: {\n width: 1000,\n height: 550,\n },\n [theme.breakpoints.only('lg')]: {\n width: 700,\n height: 450,\n },\n [theme.breakpoints.only('md')]: {\n width: 700,\n height: 350,\n },\n [theme.breakpoints.only('sm')]: {\n width: 550,\n height: 350,\n },\n [theme.breakpoints.only('xs')]: {\n width: 250,\n height: 150,\n }\n },\n image: {\n margin: `${theme.spacing(6)}px 0`,\n [theme.breakpoints.down('sm')]: {\n margin: `${theme.spacing(3)}px 0`,\n },\n width: '80%',\n objectFit: \"contain\"\n }\n}))\n\nfunction CarouselChildren({\n length, items, activeItemIndex, setActiveItemIndex,\n openDialog, setOpenDialog, ...props\n}) {\n const classes = useStyles(props);\n\n const [currentImage, setCurrentImage] = useState()\n\n const moveLeft = useCallback(\n (activeItemIndex) => {\n if (activeItemIndex > 0) setActiveItemIndex(activeItemIndex - 1)\n else setActiveItemIndex(length - 1)\n },\n [setActiveItemIndex, length],\n )\n\n const moveRight = useCallback(\n (activeItemIndex) => {\n setActiveItemIndex((activeItemIndex + 1) % length)\n },\n [setActiveItemIndex, length],\n )\n const createChildren = useCallback(() => items.map((x, i) => (\n <Box key={i} justify=\"space-between\" className={classes.cardBox}>\n <Box className={classes.imageBox}>\n <img\n src={x.image}\n alt=\"preview-projects\"\n className={clsx(classes.image, classes.animation)}\n onClick={() => {\n setOpenDialog(true)\n setCurrentImage(x.image)\n }}\n />\n </Box>\n <GridBlock alignItems=\"center\" direction=\"column\">\n {/* <Typography variant='body1' className={clsx(classes.title, classes.animation)}>\n {x.title}\n </Typography> */}\n <Typography variant='body1' className={classes.animation}>\n {x.content}\n </Typography>\n </GridBlock>\n </Box >\n )), [classes, items, setOpenDialog])\n\n const createButton = useMemo(() => {\n return (Icon, func) => {\n return <IconButton onClick={() => func(activeItemIndex)}>\n <Icon />\n </IconButton>\n }\n }, [activeItemIndex])\n\n return <>\n <GridBlock wrap=\"nowrap\" justify=\"center\" alignItems=\"center\" className={classes.contentContainer}>\n <Hidden smDown>\n {createButton(ArrowBackIosIcon, moveLeft)}\n </Hidden>\n {createChildren()[activeItemIndex]}\n <Hidden smDown>\n {createButton(ArrowForwardIosIcon, moveRight)}\n </Hidden>\n </GridBlock >\n <ImageDialog image={currentImage} open={openDialog} onClose={() => setOpenDialog(false)} />\n </>\n}\n\nexport default CarouselChildren\n","import React, { useState, useCallback, useMemo, useEffect } from 'react'\r\nimport { makeStyles } from '@material-ui/styles';\r\nimport { Box } from '@material-ui/core';\r\nimport GridBlock from '../GridBlock';\r\nimport range from 'lodash/range';\r\nimport clsx from 'clsx';\r\nimport CarouselChildren from './CarouselChildren';\r\n// import CarouselItems from '../../const/CarouselItems';\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n mainContainer: {\r\n margin: '0 auto',\r\n },\r\n '@keyframes show': {\r\n '0%': {\r\n opacity: 0\r\n }\r\n },\r\n dotted: {\r\n marginRight: theme.spacing(2),\r\n width: 10,\r\n height: 10,\r\n borderRadius: '100%',\r\n // border: `1px solid black`,\r\n background: theme.palette.grey[400],\r\n [theme.breakpoints.up('md')]: {\r\n '&:hover': {\r\n cursor: \"pointer\",\r\n borderColor: theme.palette.primary.main,\r\n background: theme.palette.primary.main\r\n },\r\n },\r\n },\r\n dottedBox: {\r\n [theme.breakpoints.down('xs')]: {\r\n width: 200,\r\n marginLeft: theme.spacing(4),\r\n '&>*': {\r\n marginBottom: theme.spacing()\r\n }\r\n },\r\n },\r\n currentDotted: {\r\n // borderColor: theme.palette.primary.main,\r\n background: theme.palette.primary.main\r\n },\r\n}))\r\n\r\n\r\nfunction Carousel({\r\n activeItemIndex,\r\n setActiveItemIndex,\r\n value,\r\n setTabsValue,\r\n length,\r\n items,\r\n ...props\r\n}) {\r\n const classes = useStyles(props);\r\n const [openDialog, setOpenDialog] = useState(false)\r\n const [postion, setPostion] = useState(0);\r\n\r\n useEffect(() => {\r\n if (!openDialog) {\r\n let id = setInterval(() => {\r\n setActiveItemIndex((activeItemIndex + 1) % length);\r\n }, 8000);\r\n return () => clearInterval(id);\r\n }\r\n }, [openDialog, activeItemIndex, items, length, setActiveItemIndex]);\r\n\r\n const createDottedNavigation = useMemo(() => {\r\n return <GridBlock className={classes.dottedBox}>\r\n {\r\n range(length).map(i => {\r\n return <Box\r\n key={i}\r\n className={\r\n clsx(\r\n { [classes.currentDotted]: activeItemIndex === i },\r\n classes.dotted)\r\n }\r\n onClick={() => {\r\n setActiveItemIndex(i)\r\n }}\r\n />\r\n })\r\n }\r\n </GridBlock>\r\n }, [classes, activeItemIndex, length, setActiveItemIndex])\r\n\r\n const swipeStart = useCallback(\r\n (e) => setPostion(e.changedTouches[0].clientX),\r\n [],\r\n )\r\n\r\n const swipeEnd = useCallback(\r\n (e) => {\r\n let pos = postion - e.changedTouches[0].clientX;\r\n if (pos > 0) {\r\n setActiveItemIndex((activeItemIndex + 1) % length)\r\n }\r\n else if (pos < 0) {\r\n if (activeItemIndex > 0) setActiveItemIndex(activeItemIndex - 1)\r\n else setActiveItemIndex(length - 1)\r\n }\r\n },\r\n [activeItemIndex, setActiveItemIndex, postion, length],\r\n )\r\n\r\n return (\r\n <GridBlock\r\n justify=\"center\"\r\n alignItems=\"center\"\r\n direction=\"column\"\r\n className={classes.mainContainer}\r\n >\r\n <Box onTouchStart={swipeStart} onTouchEnd={swipeEnd}>\r\n <CarouselChildren\r\n items={items}\r\n activeItemIndex={activeItemIndex}\r\n setActiveItemIndex={setActiveItemIndex}\r\n openDialog={openDialog}\r\n setOpenDialog={setOpenDialog}\r\n length={length}\r\n />\r\n </Box>\r\n {createDottedNavigation}\r\n </GridBlock >\r\n\r\n )\r\n}\r\n\r\n\r\nexport default Carousel\r\n","import mobile1 from '../images/projects/mobile.png'\r\nimport mobile2 from '../images/projects/mobile2.png'\r\nimport mobile3 from '../images/projects/taifho.png'\r\n\r\n\r\nimport dedicated1 from '../images/projects/foto-01.png'\r\nimport dedicated2 from '../images/projects/foto-03.png'\r\nimport dedicated3 from '../images/projects/foto-05.png'\r\nimport dedicated4 from '../images/projects/micro-management.png'\r\nimport dedicated5 from '../images/projects/TimeLinePirate.png'\r\n\r\n\r\nimport web1 from '../images/projects/foto-02.png'\r\nimport web2 from '../images/projects/foto-04.png'\r\nimport web3 from '../images/projects/PersonalData.png'\r\nimport web4 from '../images/projects/Spar-09.png'\r\nimport web5 from '../images/projects/Treo.png'\r\n\r\nexport default [\r\n {\r\n key: \"mobile\",\r\n image: mobile1,\r\n // title: \"title\",\r\n content: 'Mobile application for managing prescriptions. The Doctor can make a preception, filling all the information about the patient, the medicines and doses, and then save it. Later, the prescription is generated, and can be printed out, or generated as a QR code and send directly to a Pharmacy without the need for the patien to have the physical prescriotions with himself.'\r\n },\r\n {\r\n key: \"mobile\",\r\n image: mobile2,\r\n // title: \"title\",\r\n content: 'Mobile application for reading ithe information from physical Business cards and extracting them to the app. The user have the possibility to scan those cards and the application will read the data and save it. Apart from that, there is also an option to create events and assign the extracted contacts to the specific events, to group the contact and manage them.'\r\n },\r\n {\r\n key: \"mobile\",\r\n image: mobile3,\r\n // title: \"title\",\r\n content: 'An absorbing mobile game where the goal is to move all of your pawns across the board. This japanese board game is somewhat mix of chess and checkers – it require a lot of planning and strategic thinking. There are 3 levels of difficulty, an option to play with advanced AI, animated movements, an option to login via Facebook or Google account and even a ranking system.'\r\n },\r\n {\r\n key: \"web\",\r\n image: web1,\r\n // title: \"title\",\r\n content: 'A web application made for checking the efficiency of the employees. The application is based on multiple questionnaries that are made specially to measure the activity of the workers. Based on those information, the Employer can reassing people and better distribute the task among them.'\r\n },\r\n {\r\n key: \"web\",\r\n image: web2,\r\n // title: \"title\",\r\n content: 'A web application done specially for creating and managing events that are meant to be different activities for groups of children and their patrons. There are a lot of different possibilieties: creating personal accounts, managing events, creating and distributing badges as a form of reward for completing the activity, and also checking the history of closed events.'\r\n },\r\n {\r\n key: \"web\",\r\n image: web3,\r\n // title: \"title\",\r\n content: 'Web application done for a swedish partner, designed as a platform to sell personal information of the people that agreed for it. The client have a variety of different options, like creating personal account and search for the specific pieces of information, based on the advanced filtering methods. The buyer also have the opportunity to buy only the data that is new, excluding the data he/she already own.'\r\n },\r\n {\r\n key: \"web\",\r\n image: web4,\r\n // title: \"title\",\r\n content: 'Design project made for SPAR stores. The design was carefully created to go on with the theme of the stores itself. The idea was to create a new, freash webpage view that will match the current standards.'\r\n },\r\n {\r\n key: \"web\",\r\n image: web5,\r\n // title: \"title\",\r\n content: 'A web service for managing export and import pallet transport done between the EU countries. The application is designed to calculate the cost of the freight based on the pallet type, the dimensions of the wares. The client have the possibility to pick the initial and destination country with the post code.'\r\n },\r\n {\r\n key: \"dedicated\",\r\n image: dedicated1,\r\n // title: \"title\",\r\n content: `Dedicated app made for institutions that manage financial transactions. It handles the validation of all the personal data – bank numbers, personal ID's, etc. The user can additionally create statistics about financial operations, export files with all the data of the choosen operations. In case of interest, please contact with us about providing the license.`\r\n },\r\n {\r\n key: \"dedicated\",\r\n image: dedicated2,\r\n // title: \"title\",\r\n content: 'Web platform created for selling tickets to the musical events. It was designed to create events, managing the tickets, creating promotions and adding gifts to the order. There are a lot of possibilities for user, from picking up the best places on the event, to adding some gadgets and souvenirs to the basket.'\r\n },\r\n {\r\n key: \"dedicated\",\r\n image: dedicated3,\r\n // title: \"title\",\r\n content: 'Dedicated CMS system for managing the application content of the Cracow Opera Ballet Studio. The user have the possibility to manage different sections of the applications, changing the content, etc. It is designed to match the expectations of the client, but also to be simple and self-explanatory.'\r\n },\r\n {\r\n key: \"dedicated\",\r\n image: dedicated4,\r\n // title: \"title\",\r\n content: `Dedicated app made for work management of the employees. The system handles such tasks as planning work schedules, time management, salaries, managing records of fixed assets, issues report and many more. In case of interest, please contact with us about proving the license.`\r\n },\r\n {\r\n key: \"dedicated\",\r\n image: dedicated5,\r\n // title:,\r\n content: 'A dedicated application made for museum. It was designed as a responsive map that showed the places of voyages of the last pirate that sailed Baltic sea – Eryk Pomorski. The user was able to tocuh the timeline to see all the places visited by a pirate. After the date was chosen on the timeline, the map was zooming to the specific spot that was visited in that period.'\r\n }\r\n]\r\n","import React, { useState, useMemo, useEffect, useCallback } from 'react'\r\nimport ContentContainer from '../../components/ContentContainer';\r\nimport RouterPath from '../../const/RouterPath';\r\nimport { useTranslation } from 'react-i18next';\r\nimport Carousel from '../../components/Carousel/Carousel';\r\nimport { Tabs, Tab, makeStyles } from '@material-ui/core';\r\nimport GridBlock from '../../components/GridBlock';\r\nimport _ from 'lodash';\r\nimport CarouselItems from '../../const/CarouselItems';\r\nimport range from 'lodash/range';\r\n\r\nconst tabTab = [\r\n 'mobile',\r\n 'web',\r\n 'dedicated'\r\n]\r\n\r\nconst useStyles = makeStyles(theme => ({\r\n tabs: {\r\n marginBottom: theme.spacing(2),\r\n },\r\n tab: {\r\n [theme.breakpoints.only('md')]: {\r\n fontSize: 16\r\n },\r\n [theme.breakpoints.down('sm')]: {\r\n fontSize: 14\r\n },\r\n }\r\n}))\r\n\r\nfunction Projects(props) {\r\n const classes = useStyles(props);\r\n const { t } = useTranslation();\r\n\r\n const [tabsValue, setTabsValue] = useState(0)\r\n const [activeItemIndex, setActiveItemIndex] = useState(0);\r\n\r\n const itemsCounter = useCallback((key) => {\r\n let counter = 0;\r\n CarouselItems.forEach(x => {\r\n if (x.key === key) counter++\r\n });\r\n return counter\r\n }, [])\r\n\r\n let tab1Length = itemsCounter(\"mobile\")\r\n let tab2Length = tab1Length + itemsCounter(\"web\")\r\n let tab3Length = tab2Length + itemsCounter(\"dedicated\")\r\n\r\n const indexTab = useCallback(\r\n () => {\r\n let tab = []\r\n range(tab3Length).forEach((i) => {\r\n tab.push(i)\r\n });\r\n return tab\r\n },\r\n [tab3Length],\r\n )\r\n\r\n useEffect(() => {\r\n if (tabsValue === 0) {\r\n if (!indexTab().slice(1, tab1Length).includes(activeItemIndex)) {\r\n setActiveItemIndex(0)\r\n }\r\n }\r\n if (tabsValue === 1) {\r\n if (!indexTab().slice(tab1Length, tab2Length).includes(activeItemIndex)) {\r\n setActiveItemIndex(3)\r\n }\r\n }\r\n if (tabsValue === 2) {\r\n if (!indexTab().slice(tab2Length + 1, tab3Length).includes(activeItemIndex)) {\r\n setActiveItemIndex(8)\r\n }\r\n }\r\n //eslint-disable-next-line\r\n }, [tabsValue, tab1Length, tab2Length, tab3Length])\r\n\r\n useEffect(() => {\r\n if (activeItemIndex >= 0 && activeItemIndex < tab1Length) {\r\n setTabsValue(0)\r\n }\r\n if (activeItemIndex >= tab1Length && activeItemIndex < tab2Length) {\r\n setTabsValue(1)\r\n }\r\n if (activeItemIndex >= tab2Length && activeItemIndex < tab3Length) {\r\n setTabsValue(2)\r\n }\r\n }, [activeItemIndex, tab1Length, tab2Length, tab3Length])\r\n\r\n const handleChange = (event, newValue) => setTabsValue(newValue)\r\n\r\n const TabPanel = (props) => {\r\n const { value, index } = props;\r\n return value === index && <Carousel\r\n activeItemIndex={activeItemIndex}\r\n setActiveItemIndex={setActiveItemIndex}\r\n length={CarouselItems.length}\r\n items={CarouselItems}\r\n setTabsValue={setTabsValue}\r\n />\r\n }\r\n\r\n const createTabs = useMemo(() => {\r\n return tabTab.map((x, i) => (\r\n <Tab\r\n id={i}\r\n key={i}\r\n label={t(x)}\r\n className={classes.tab}\r\n />))\r\n }, [classes, t])\r\n\r\n const createTabPanels = useMemo(() => {\r\n return _.range(3).map((x, i) => <TabPanel key={i} value={tabsValue} index={i} />)\r\n //eslint-disable-next-line\r\n }, [tabsValue, setActiveItemIndex, activeItemIndex])\r\n\r\n return (\r\n <ContentContainer\r\n title={t(\"project_title\")}\r\n id={RouterPath.anchors.PROJECTS}\r\n alignContent=\"stretch\"\r\n >\r\n <GridBlock alignItems=\"center\" justify=\"center\" direction=\"column\">\r\n <Tabs\r\n value={tabsValue}\r\n onChange={handleChange}\r\n aria-label=\"simple tabs example\"\r\n className={classes.tabs}\r\n >\r\n {createTabs}\r\n </Tabs>\r\n {createTabPanels}\r\n </GridBlock>\r\n </ContentContainer>\r\n )\r\n}\r\n\r\nexport default Projects\r\n","import React, { useMemo, useState, useEffect } from 'react'\nimport ContentContainer from '../../components/ContentContainer';\nimport { makeStyles } from '@material-ui/core/styles'\nimport { useTranslation } from 'react-i18next';\nimport RouterPath from '../../const/RouterPath';\nimport ItemsCarousel from 'react-items-carousel';\nimport GridBlock from '../../components/GridBlock';\nimport { Box } from '@material-ui/core';\nimport _ from 'lodash';\nimport withWidth from '@material-ui/core/withWidth';\n\nconst imports = require.context('../../images/clients/', true, /\\.png$/);\nconst tab = Object.values(imports.keys())\nconst slideLength = tab.length / 2\n\nfunction Clients({ width, ...props }) {\n\n const [activeItemIndex, setActiveItemIndex] = useState(0);\n\n useEffect(() => {\n let id = setInterval(() => {\n setActiveItemIndex(activeItemIndex + 1);\n }, 3000);\n return () => clearInterval(id);\n }, [activeItemIndex]);\n\n const classes = useStyles(props);\n const { t } = useTranslation();\n\n const firstRow = tab.slice(0, slideLength)\n const secondRow = tab.slice(slideLength)\n\n const clientsItems = _.range(slideLength)\n\n const setNumberOfCards = useMemo(() => {\n switch (width) {\n case 'xs':\n case 'sm': return 1;\n case 'md': return 2;\n default: return 3;\n }\n }, [width])\n\n return (\n <ContentContainer\n title={t(\"clients_title\")}\n className={classes.clients}\n id={RouterPath.anchors.CLIENTS}\n alignContent=\"stretch\"\n >\n <GridBlock justify=\"center\" className={classes.container}>\n <ItemsCarousel\n requestToChangeActive={setActiveItemIndex}\n activeItemIndex={activeItemIndex}\n numberOfCards={setNumberOfCards}\n slidesToScroll={1}\n gutter={20}\n infiniteLoop\n classes={{\n itemsWrapper: classes.itemsWrapper,\n }}\n >\n {clientsItems.map((i) => {\n return (\n <Box key={i} className={classes.imageBox}>\n <img loading=\"lazy\" alt={`clients-${i}`} src={imports(firstRow[i])} />\n <img loading=\"lazy\" alt={`clients-${i}`} src={imports(secondRow[i])} />\n </Box>\n )\n })}\n </ItemsCarousel>\n </GridBlock>\n </ContentContainer>\n )\n}\n\nconst useStyles = makeStyles(theme => ({\n container: {\n paddingTop: theme.spacing(3),\n [theme.breakpoints.down('md')]: {\n maxWidth: 700,\n margin: '0 auto',\n },\n [theme.breakpoints.down('sm')]: {\n maxWidth: 300,\n margin: '0 auto',\n '&>:first-child': {\n width: 300,\n }\n }\n },\n itemsWrapper: {\n [theme.breakpoints.up('md')]: {\n width: '70vw',\n }\n },\n imageBox: {\n textAlign: \"center\",\n '&>*': {\n width: \"60%\",\n },\n '&>:first-child': {\n marginBottom: theme.spacing(4),\n }\n }\n}))\n\nexport default withWidth()(Clients);\n","import React, { memo } from 'react'\n\nimport About from '../About/About';\nimport Technologies from '../Technologies/Technologies';\nimport Skills from '../Skills/Skills';\n// import Team from '../Team/Team';\nimport Contact from '../Contact/Contact';\nimport Ribbon from '../Ribbon/Ribbon';\nimport Estimation from '../Estimation/Estimation';\nimport Projects from '../Projects/Projects';\nimport Clients from '../Clients/Clients';\n\nfunction HomeContent() {\n\n return <>\n <About />\n <Technologies />\n <Skills />\n <Projects />\n {/* <Team /> */}\n <Ribbon />\n <Clients />\n <Estimation />\n <Contact />\n </>\n}\n\nexport default memo(HomeContent)\n","import React, { memo, useEffect, useCallback } from 'react'\nimport { Link as LinkRS, animateScroll as scroll } from 'react-scroll'\nimport RouterPath from '../const/RouterPath';\nimport { Link as LinkRRD } from \"react-router-dom\";\n\nconst Link = ({ label, to, routerLink = false, onClose= () => {} }) => {\n\n useEffect(() => {\n const hash = window.location.hash.slice(1)\n if (document.getElementById(hash)) {\n if (window.location.hash === \"\" &&\n window.location.pathname === RouterPath.HOME) {\n scroll.scrollToTop();\n }\n else scroll.scrollTo(document.getElementById(hash).offsetTop + 100 )\n }\n // eslint-disable-next-line\n }, [window.location.pathname])\n\n const handleClickLinkRRD = useCallback(() => scroll.scrollTo(0), [])\n \n // const handleClickLinkRS = useCallback(() => history.push(`${RouterPath.HOME}#${to}`), [history, to])\n\n const handleClickLinkRS = useCallback(() => onClose(),[onClose])\n\n\n if (routerLink) {\n return (\n <LinkRRD\n to={to}\n onClick={handleClickLinkRRD}\n >\n {label}\n </LinkRRD>\n )\n }\n else {\n return (\n <LinkRS\n spy\n smooth={\"easeInQuad\"}\n to={to}\n offset={-50}\n duration={500}\n activeClass='active'\n onClick={handleClickLinkRS}\n >\n {label.toUpperCase()}\n </LinkRS>\n )\n }\n}\n\nexport default memo(Link);\n","import React, { memo } from 'react'\r\nimport Link from './Link'\r\nimport RouterPath from '../const/RouterPath';\r\nimport { useTranslation } from 'react-i18next';\r\n\r\nfunction Links({onClose}) {\r\n const { t } = useTranslation();\r\n\r\n return <>\r\n <Link onClose={onClose} label={t('home')} to={RouterPath.anchors.HOME} />\r\n <Link onClose={onClose} label={t('about')} to={RouterPath.anchors.ABOUT} />\r\n <Link onClose={onClose} label={t('technologies')} to={RouterPath.anchors.TECHNOLOGIES} />\r\n <Link onClose={onClose} label={t('projects')} to={RouterPath.anchors.PROJECTS} />\r\n {/* <Link onClose={onClose} label={t('team')} to={RouterPath.anchors.TEAM} /> */}\r\n <Link onClose={onClose} label={t('clients')} to={RouterPath.anchors.CLIENTS} />\r\n <Link onClose={onClose} label={t('estimation')} to={RouterPath.anchors.ESTIMATION} />\r\n <Link onClose={onClose} label={t('contact')} to={RouterPath.anchors.CONTACT} />\r\n </>\r\n}\r\n\r\nexport default memo(Links)\r\n","import React, { memo } from 'react'\nimport GridBlock from '../../components/GridBlock';\nimport { makeStyles, Typography, Box } from '@material-ui/core';\nimport { useTranslation } from 'react-i18next';\nimport Links from '../../components/Links';\nimport ContentContainer from '../../components/ContentContainer';\n\nconst useStyles = makeStyles(theme => ({\n footer: {\n color: \"white\",\n background: '#323437',\n [theme.breakpoints.down('sm')]: {\n paddingBottom: theme.spacing(2)\n }\n },\n container: {\n [theme.breakpoints.down('sm')]: {\n alignItems: \"flex-end\",\n marginBottom: theme.spacing(),\n },\n [theme.breakpoints.down('xs')]: {\n marginBottom: theme.spacing(),\n }\n },\n text: {\n marginRight: theme.spacing(6),\n [theme.breakpoints.down('sm')]: {\n marginTop: theme.spacing(3),\n marginLeft: theme.spacing(4),\n }\n },\n linkBox: {\n '& a': {\n fontSize: 12,\n cursor: 'pointer',\n },\n [theme.breakpoints.up('md')]: {\n '& a': {\n marginRight: theme.spacing(2)\n }\n },\n [theme.breakpoints.down('sm')]: {\n marginLeft: theme.spacing(4),\n display: \"flex\",\n flexWrap: 'wrap',\n '& a': {\n marginBottom: theme.spacing(),\n width: '50%'\n }\n },\n [theme.breakpoints.only('md')]: {\n marginBottom: theme.spacing(3)\n }\n }\n}))\n\nfunction Footer(props) {\n const classes = useStyles(props);\n const { t } = useTranslation();\n\n const now = new Date();\n\n return (\n <ContentContainer\n className={classes.footer}\n alignContent=\"stretch\"\n >\n <GridBlock justify=\"space-between\" alignItems=\"baseline\" className={classes.container}>\n <Box className={classes.linkBox}>\n <Links />\n </Box>\n <Typography variant=\"body1\" className={classes.text}>\n {t(\"footer_text\", { year: now.getFullYear() })}\n </Typography>\n </GridBlock>\n </ContentContainer>\n )\n}\n\n\nexport default memo(Footer);\n","import React, { memo } from 'react'\n// import { makeStyles } from '@material-ui/core/styles'\nimport Header from '../components/Header';\nimport HomeContent from './Home/HomeContent';\nimport Footer from './Footer/Footer';\n\nfunction MainContrainer() {\n return <>\n <Header />\n <HomeContent />\n <Footer />\n </>\n}\n\nexport default memo(MainContrainer);\n","import React, { memo, useMemo, useCallback, useState } from 'react'\nimport { makeStyles } from '@material-ui/core/styles'\nimport clsx from 'clsx'\nimport { AppBar as AppBarUI, Toolbar, Box, Drawer, IconButton, Hidden } from '@material-ui/core'\nimport LogoDoIt from '../images/logo.png'\nimport LogoDoItMobile from '../images/logo-mobile.png'\nimport { animateScroll as scrollRS } from 'react-scroll'\nimport Links from './Links'\nimport withWidth from '@material-ui/core/withWidth';\nimport MenuIcon from '@material-ui/icons/Menu';\n\nconst useStyles = makeStyles(theme => ({\n mainContainer: {\n margin: '0 auto'\n },\n appBar: {\n background: 'unset',\n transition: 'background 0.2s',\n position: 'fixed',\n display: 'flex',\n fontSize: 14,\n alignItems: 'center',\n height: 70,\n [theme.breakpoints.down('md')]: {\n height: 60,\n alignItems: 'normal',\n justifyContent: \"center\",\n background: 'black',\n },\n },\n appBarScroll: {\n background: 'white',\n transition: 'background 0.3s',\n '& a': {\n color: 'black',\n '&:hover': {\n color: theme.palette.primary.main,\n },\n '&:after': {\n background: \"unset\"\n }\n },\n\n },\n toolbar: {\n ...theme.maxResolution,\n margin: \"unset\",\n [theme.breakpoints.up('lg')]: {\n marginRight: theme.spacing(7),\n width: '100%',\n '&>:first-child': {\n flexGrow: 1,\n marginLeft: theme.spacing(10)\n },\n '&>:last-child': {\n marginRight: theme.spacing(2)\n },\n },\n },\n logo: {\n paddingTop: theme.spacing(5),\n cursor: \"pointer\",\n width: 120,\n transition: 'width 0.3s',\n [theme.breakpoints.down('md')]: {\n paddingTop: \"unset\",\n width: 60\n },\n '&:hover': {\n opacity: 0.9,\n }\n },\n logoScroll: {\n paddingTop: theme.spacing(),\n width: 80,\n transition: 'width 0.3s'\n }\n}))\n\nfunction AppBar({ props, scroll, width }) {\n\n const classes = useStyles(props)\n\n const [open, setOpen] = useState(false)\n\n const elevation = useMemo(() => {\n if (width !== \"lg\" && width !== \"xl\") return 1\n else return scroll ? 1 : 0\n }, [scroll, width])\n\n const handleImageClick = useCallback(\n () => {\n // history.push(RouterPath.HOME)\n scrollRS.scrollToTop()\n },\n [],\n )\n\n return (\n <Box className={classes.mainContainer}>\n <AppBarUI\n className={\n clsx(\n { [classes.appBarScroll]: scroll && (width === \"lg\" || width === \"xl\") },\n classes.appBar\n )\n }\n elevation={elevation}\n position='static'\n >\n <Toolbar className={classes.toolbar}>\n <Box>\n <img\n src={(width !== \"lg\" && width !== \"xl\") ? LogoDoItMobile : LogoDoIt}\n alt='Company Logo'\n className={clsx(\n { [classes.logoScroll]: scroll && (width === \"lg\" || width === \"xl\") },\n classes.logo\n )}\n onClick={handleImageClick}\n />\n </Box>\n <Hidden lgUp>\n <Box style={{ flexGrow: 1 }} />\n <IconButton\n edge=\"end\"\n className={classes.menuButton}\n color=\"primary\"\n aria-label=\"menu\"\n onClick={() => setOpen(!open)}\n >\n <MenuIcon />\n </IconButton>\n </Hidden>\n {\n (width === \"lg\" || width === \"xl\") ?\n <Links />\n :\n <Drawer\n anchor=\"right\"\n open={open}\n onClose={() => setOpen()}\n >\n <Links onClose={() => setOpen()} />\n </Drawer>\n }\n </Toolbar>\n </AppBarUI>\n </Box>\n )\n\n}\n\nexport default memo(withWidth()(AppBar));\n","import React, { useCallback, memo } from 'react'\nimport { Fab, Zoom } from '@material-ui/core'\nimport { animateScroll as scrollRS } from 'react-scroll'\nimport KeyboardArrowUpIcon from '@material-ui/icons/KeyboardArrowUp';\nimport { makeStyles } from '@material-ui/core/styles'\n\nconst useStyles = makeStyles(theme => ({\n fab: {\n cursor: \"pointer\",\n position: 'fixed',\n bottom: 15,\n right: 15,\n [theme.breakpoints.down('sm')]: {\n width: 40,\n height: 40\n }\n },\n}))\n\nfunction ScrollToTopButton({props, scroll}) {\n const classes = useStyles(props)\n\n const scrollToTop = useCallback(() => scrollRS.scrollToTop(), [])\n\n return (\n <Zoom in={scroll}>\n <Fab\n size=\"large\"\n color=\"primary\"\n className={classes.fab}\n aria-label=\"scroll back to top\"\n onClick={scrollToTop}\n >\n <KeyboardArrowUpIcon />\n </Fab>\n </Zoom >\n )\n}\n\nexport default memo(ScrollToTopButton)\n","import React, { useState, useEffect, memo } from \"react\";\nimport MainContrainer from \"./MainContrainer\";\nimport AppBar from \"../components/AppBar\";\nimport ScrollToTopButton from \"../components/ScrollToTopButton\";\nimport { Helmet } from \"react-helmet\";\n\nfunction Root() {\n const [scroll, setScroll] = useState(false);\n const [windowSize, setWindowSize] = useState(false);\n\n useEffect(() => {\n document.addEventListener(\"scroll\", () => {\n if (window.scrollY > 100) setScroll(true);\n else setScroll(false);\n });\n }, [scroll]);\n\n useEffect(() => {\n window.addEventListener(\"resize\", () => {\n if (window.screen.availWidth > 2600) setWindowSize(true);\n else setWindowSize(false);\n });\n }, [windowSize, setWindowSize]);\n\n useEffect(() => {\n window.addEventListener(\"load\", () => {\n if (window.screen.availWidth > 2600) setWindowSize(true);\n else setWindowSize(false);\n });\n }, [windowSize, setWindowSize]);\n\n return (\n <>\n <Helmet>\n {windowSize ? (\n <meta\n name=\"viewport\"\n content=\"width=1920, initial-scale=2, maximum-scale=2\"\n ></meta>\n ) : (\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n )}\n </Helmet>\n <AppBar scroll={scroll} />\n <MainContrainer />\n <ScrollToTopButton scroll={scroll} />\n </>\n );\n}\n\nexport default memo(Root);\n","import { createMuiTheme } from '@material-ui/core/styles'\n\nconst muiTheme = createMuiTheme({\n palette: {\n primary: {\n main: '#ed1c24'\n },\n secondary: {\n main: '#fff'\n },\n lightBackground: {\n main: '#f2f2f2',\n }\n },\n typography: {\n fontFamily: [\n \"Ubuntu\",\n ],\n fontWeightLight: 100,\n useNextVariants: true,\n\n cutLines: (num) => ({\n textOverflow: 'ellipsis',\n display: '-webkit-box',\n '-webkit-box-orient': 'vertical',\n overflow: 'hidden',\n lineClamp: num\n })\n\n },\n overrides: {\n MuiBackdrop: {\n \"root\": {\n backgroundColor: \"unset\"\n }\n },\n MuiDrawer: {\n \"paper\": {\n width: 200,\n padding: 24,\n '& a': {\n marginBottom: 24,\n }\n }\n },\n MuiTab: {\n \"root\": {\n fontSize: 18,\n \"&$selected\": {\n \"color\": \"#ed1c24\"\n }\n }\n },\n MuiAppBar: {\n root: {\n '& a': {\n marginRight: 32,\n color: \"white\",\n cursor: \"pointer\",\n textAlign: \"center\",\n position: \"relative\",\n textDecoration: 'unset',\n '&:hover:after': {\n width: '90%',\n },\n '&:after': {\n left: '0',\n right: '0',\n width: '0%',\n content: `''`,\n height: '2px',\n bottom: '-2px',\n margin: 'auto',\n background: '#aaa',\n position: 'absolute',\n color: 'transparent',\n transition: 'all .5s',\n },\n }\n }\n },\n }\n})\n\nconst theme = {\n maxResolution: {\n maxWidth: 1920,\n margin: '0 auto'\n },\n}\n\nexport default {\n ...muiTheme,\n ...theme\n}","import React from \"react\";\nimport { BrowserRouter } from \"react-router-dom\";\nimport { ThemeProvider as ThemeProviderUI } from \"@material-ui/styles\";\nimport Root from \"./pages/Root\";\nimport theme from \"./theme/theme\";\nimport pjson from \"../package.json\";\n\nconsole.table({ version: pjson.version });\n\nfunction App() {\n return (\n <BrowserRouter>\n <ThemeProviderUI theme={theme}>\n <Root />\n </ThemeProviderUI>\n </BrowserRouter>\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\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)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing\n if (installingWorker == null) {\n return\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n )\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration)\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.')\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration)\n }\n }\n }\n }\n }\n })\n .catch(error => {\n console.error('Error during service worker registration:', error)\n })\n}\n\nfunction checkValidServiceWorker (swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' }\n })\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type')\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload()\n })\n })\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config)\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n )\n })\n}\n\nexport function unregister () {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister()\n })\n }\n}\n","import 'react-app-polyfill/ie9';\nimport 'react-app-polyfill/ie11';\nimport 'react-app-polyfill/stable';\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport './i18n';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\n\nReactDOM.render(<App />, document.getElementById('root'))\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister()\n"],"sourceRoot":""}