{"version":3,"sources":["assets/images/logo.png","helper/const.js","components/Loading.jsx","helper/loadable.js","components/Nav.jsx","components/Header.jsx","components/Footer.jsx","Router.jsx","App.js","serviceWorker.js","index.js"],"names":["module","exports","COLOR","navColor","buttonColor","textColor","BREAK_POINT","sm","md","lg","xl","GlobalStyle","createGlobalStyle","Loader","styled","div","LoaderInner","Loading","Array","from","length","map","v","k","key","loadingComponent","loader","loading","Loadable","NavButton","props","theme","active","NavList","ul","NavItem","li","NavWrapper","nav","NAV_CONFIG","text","url","NavLink","label","to","activeOnlyWhenExact","setShowNav","path","exact","children","match","onClick","Nav","useState","showNav","item","Logo","img","HeaderWrapper","header","mask","Welcome","Header","setMask","handleHeaderMask","scrollTop","document","documentElement","body","useEffect","addEventListener","debounce","hideLogo","src","defaultLogo","alt","href","target","rel","FooterWrapper","footer","Footer","Produce","loadable","Contact","Purchase","Sales","Store","Quality","Case","About","Main","main","ThemeWrapper","Router","setTheme","setHideLogo","render","onChangeTheme","App","className","Boolean","window","location","hostname","ReactDOM","getElementById","navigator","serviceWorker","ready","then","registration","unregister"],"mappings":"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","file":"static/js/main.2eecb397.chunk.js","sourcesContent":["module.exports = __webpack_public_path__ + \"static/media/logo.ab0ce251.png\";","const COLOR = {\n navColor: '#3f5db3',\n buttonColor: '#afa394',\n textColor: '#333743'\n}\n\nconst BREAK_POINT = {\n sm: 768,\n md: 1024,\n lg: 1200,\n xl: 1440\n}\n\nconst HOST_URL = 'http://jx.tlanx.com';\n\nexport {\n COLOR,\n BREAK_POINT,\n HOST_URL\n}\n","import React from 'react';\nimport styled, { createGlobalStyle } from 'styled-components';\n\nconst GlobalStyle = createGlobalStyle`\n @keyframes line-scale {\n 0% {\n transform: scaley(1);\n }\n 50% {\n transform: scaley(0.4);\n }\n 100% {\n transform: scaley(1);\n }\n }\n`;\n\nconst Loader = styled.div`\n display: inline-block;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n`;\n\nconst LoaderInner = styled.div`\n div {\n display: inline-block;\n width: 5px;\n height: 50px;\n border-radius: 2px;\n margin: 2px 5px;\n animation-fill-mode: both;\n background-color: '#2B3C43';\n &:nth-child(1) {\n animation: line-scale 1s 0.1s infinite cubic-bezier(.2, .68, .18, 1.08);\n }\n &:nth-child(2) {\n animation: line-scale 1s 0.2s infinite cubic-bezier(.2, .68, .18, 1.08);\n }\n &:nth-child(3) {\n animation: line-scale 1s 0.3s infinite cubic-bezier(.2, .68, .18, 1.08);\n }\n &:nth-child(4) {\n animation: line-scale 1s 0.4s infinite cubic-bezier(.2, .68, .18, 1.08);\n }\n &:nth-child(5) {\n animation: line-scale 1s 0.5s infinite cubic-bezier(.2, .68, .18, 1.08);\n }\n }\n`;\n\nconst Loading = () => (\n \n \n \n {\n Array.from({length:5}).map((v, k) =>
)\n }\n
\n
\n);\n\nexport default Loading;","import React from 'react';\nimport Loadable from 'react-loadable';\nimport Loading from '../components/Loading';\n\nconst loadingComponent = () => \n\nexport default (loader,loading = loadingComponent) => Loadable({\n loader,\n loading\n});","import React, {useState} from 'react';\nimport styled from 'styled-components';\nimport { Route, Link } from 'react-router-dom';\n\nimport {COLOR, BREAK_POINT} from '../helper/const';\n\nconst NavButton = styled.div`\n @media (min-width: ${BREAK_POINT.xl - 1}px) {\n display: none;\n }\n position: absolute;\n top: 10px;\n left: 15px;\n width: 40px;\n height: 40px;\n vertical-align: middle;\n text-align: center;\n line-height: 40px;\n z-index: 1;\n color: ${props => props.theme === 'black' ? COLOR.textColor : '#fff'};\n cursor: pointer;\n i {\n display: inline-block;\n width: 50%;\n height: 2px;\n vertical-align: middle;\n background-color: ${props => props.active ? 'transparent' : 'currentColor'};\n &::before,\n &::after {\n content: '';\n display: block;\n position: relative;\n z-index: 0;\n width: 100%;\n height: 100%;\n top: -8px;\n background-color: currentColor;\n transform-origin: -4%;\n transition: all .2s;\n }\n &::before {\n ${props => props.active && (`\n transform: rotate(45deg);\n `)}\n }\n &::after {\n top: auto;\n bottom: -6px;\n ${props => props.active && (`\n transform: rotate(-45deg);\n `)}\n }\n }\n &:hover {\n i {\n &::before {\n top: ${props => props.active ? '-8px' : '-9px'};\n }\n &::after {\n bottom: ${props => props.active ? '-6px' : '-7px'};\n }\n }\n }\n`;\n\nconst NavList = styled.ul`\n display: ${props => props.active ? 'block' : 'none'};\n position: absolute;\n left: 30px;\n top: 0;\n ${props => props.active && `\n position: static;\n `}\n @media (min-width: ${BREAK_POINT.xl}px) {\n display: block;\n }\n`;\n\nconst NavItem = styled.li`\n display: inline-block;\n margin-right: 5px;\n padding: 30px 10px 17px;\n font-size: 1.4rem;\n font-weight: 600;\n background-color: ${props => props.active ? '#3f5db3' : ''};\n &:last-child {\n margin-right: 0;\n }\n a {\n color: ${props => props.active || props.theme === 'white' ? '#fff' : '#333'};\n text-decoration: none;\n }\n`;\n\nconst NavWrapper = styled.nav`\n ${props => props.active && `\n position: fixed;\n top: 0;\n bottom: 0;\n width: 240px;\n z-index: 9;\n background-color: ${COLOR.textColor};\n box-shadow: 3px 0 3px 3px rgba(0, 0, 0, .3);\n ${NavItem} {\n display: block;\n padding: 20px 10px;\n margin-right: 0;\n a {\n color: #fff;\n }\n }\n ${NavButton} {\n color: #fff;\n }\n ${NavList} {\n margin-top: 60px;\n }\n `}\n`;\n\nconst NAV_CONFIG = [\n {\n text: '生产数智',\n url: '/produce'\n },\n {\n text: '采购数智',\n url: '/purchase'\n },\n {\n text: '库房数智',\n url: '/store'\n },\n {\n text: '销售数智',\n url: '/sales'\n },\n {\n text: '质量数智',\n url: '/quality'\n },\n {\n text: '企业案例',\n url: '/case'\n },\n {\n text: '联系我们',\n url: '/contact'\n }\n];\n\nconst NavLink = ({ label, to, activeOnlyWhenExact, theme, setShowNav }) => {\n return (\n (\n setShowNav(false)}>\n {label}\n \n )}\n />\n );\n}\n\n\nconst Nav = props => {\n const [showNav, setShowNav] = useState(false);\n return (\n \n setShowNav(!showNav)}>\n \n {\n NAV_CONFIG.map(item => (\n \n ))\n }\n \n \n )\n}\n\nexport default Nav;","import React, {useEffect, useState} from 'react';\nimport styled from 'styled-components';\nimport { Link } from 'react-router-dom';\nimport {debounce} from 'lodash';\n\nimport {COLOR, BREAK_POINT} from '../helper/const';\nimport Nav from './Nav';\nimport defaultLogo from '../assets/images/logo.png';\n\nconst Logo = styled.img`\n position: absolute;\n left: 50%;\n transform: translateX(-50%);\n margin-top: 10px;\n align-self: center;\n height: 60px;\n @media (max-width: ${BREAK_POINT.sm}px) {\n margin-top: 8px;\n height: 50px;\n }\n`;\n\nconst HeaderWrapper = styled.header`\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n z-index: 2;\n background-color: ${props => props.mask && COLOR.textColor};\n min-height: ${props => props.mask ? '60px' : 'auto'};\n box-shadow: ${props => props.mask ? '0 3px 3px 3px rgba(0, 0, 0, .3)' : ''};\n ${Logo} {\n margin-top: ${props => props.mask && '8px'};\n }\n`;\n\nconst Welcome = styled.div`\n position: fixed;\n top: 5px;\n right: 15px;\n width: 190px;\n text-align: left;\n color: ${props => props.theme === 'black' ? COLOR.textColor : '#fff'};\n h4 {\n display: none;\n margin: 0;\n text-align: right;\n line-height: 55px;\n font-size: 1.3rem;\n }\n @media (max-width: ${BREAK_POINT.md}px) {\n h3, p {\n display: none;\n }\n h4 {\n display: block;\n }\n }\n strong {\n margin-right: 10px;\n color: ${props => props.theme === 'black' ? '#000' : '#fff'};\n }\n span {\n margin-left: 10px;\n margin-right: 10px;\n color: ${props => props.theme === 'black' ? '#000' : '#fff'};\n }\n p {\n margin-top: 5px;\n line-height: 1.4;\n opacity: .7;\n color: ${props => props.theme === 'black' ? '#000' : '#fff'};\n }\n a {\n text-decoration: none;\n color: #ccc;\n }\n`;\n\nconst Header = props => {\n const [mask, setMask] = useState(false);\n const handleHeaderMask = () => {\n const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;\n setMask(scrollTop > 60);\n }\n useEffect(() => {\n document.addEventListener('scroll', debounce(handleHeaderMask, 50));\n }, [])\n return (\n \n