{"version":3,"sources":["components/Dialogs.js","components/Pages.js","pages/Layout.js","components/Controls.js","components/Containers.js","components/Components.js","pages/ProductSpecsPage.js","pages/QuantitiesPage.js","pages/OrderReviewPage.js","pages/PaymentPage.js","pages/OrderConfirmationPage.js","pages/ArtworkPage.js","pages/Home.js","pages/Overview.js","pages/IconsPage.js","pages/ValidationDemoPage.js","App.js","registerServiceWorker.js","index.js"],"names":["Modal","props","onCloseClick","bind","this","onClick","className","children","Component","displayName","name","Confirmation","onCancelClick","onSaveClick","BackSplash","onMouseMove","clear","Colorbar","Header","viewBox","fill","xmlns","window","location","d","ContactPopOver","state","visible","toggle","setState","href","Breadcrumbs","instance","steps","number","title","step","self","map","idx","key","total","length","active","visited","BreadcrumbStep","size","ProgressRing","progress","strokeWidth","center","radius","circumference","Math","PI","circleOneStroke","circleTwoStroke","progressOffset","style","width","height","lineHeight","containerStyle","stroke","cx","cy","r","strokeDasharray","strokeDashoffset","Title","Layout","Container","Textbox","value","valid","isValueValid","focused","notifyListeners","onChange","onInit","evt","target","requireValidInput","preventDefault","result","type","ValidationType","Success","id","required","Required","regex","Regex","Matches","Invalid","onValidate","getStyle","autoComplete","readOnly","maxLength","parseInt","placeholder","onFocus","onBlur","Dropdown","validation","CustomDropdown","selectionVisible","onToggle","onItemClick","forEach","item","disabled","getSelectedItem","Checkbox","checked","RadioButton","ValidationOrchestrator","onValidatingFunc","inputValidations","invalidField","hasValidated","inputValidation","push","reverse","i","validate","getInvalidFieldName","isValid","InputValidation","show","validationResults","items","validationOrchestrator","register","React","Children","child","cloneElement","getFirstInvalidField","ctrl","validationType","onValidating","Object","keys","convertToArray","requiredText","invalidText","getErrorMessage","exp","match","RegExp","exec","Searchbox","delay","onSubmit","useState","val","setVal","timeoutRef","setTimeoutRef","submit","onKeyUp","clearTimeout","keyCode","timeout","setTimeout","Row","Column","Card","transparent","subtitle","ExpandableCard","collapsed","expanded","ToggleContainer","toggleText","TileContainer","ImageTileCircle","src","backgroundImage","Carousel","index","setIndex","orientation","setOrientation","onNextClick","getAnimationStyle","Page","ButtonTile","text","ExpandableTab","setCollapsed","SectionTitle","description","image","SectionLabel","ContextHelp","showModal","getImageClass","Info","Money","currency","amount","EditLink","DownloadLink","UploadLink","MessageLink","onIconClick","getClassName","Alert","SkuEditor","SkuDisplay","GrandTotal","SideLabel","ProductSpecsPage","showPopup","setActiveStep","imageUrl","QuantitiesPage","OrderReviewPage","editAddress","PaymentPage","controls","sameAsShipping","cardExpanded","achExpanded","cardChange","achChange","ach","collapse","card","OrderConfirmationPage","ArtworkPage","Home","Overview","showConfirmation","showBackSplash","stylesheets","noflex","alert","txt","ComponentInfo","html","document","getElementById","innerHTML","ss","IconsPage","root","IconDescription","ValidationDemoPage","hasErrors","element","focus","y","getBoundingClientRect","top","pageYOffset","scrollTo","behavior","App","exact","path","component","isLocalhost","Boolean","hostname","registerValidSW","swUrl","navigator","serviceWorker","then","registration","onupdatefound","installingWorker","installing","onstatechange","controller","console","log","catch","error","baseUrl","getElementsByTagName","getAttribute","rootElement","ReactDOM","render","basename","URL","process","origin","addEventListener","fetch","response","status","headers","get","indexOf","ready","unregister","reload","checkValidServiceWorker","registerServiceWorker"],"mappings":"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","file":"static/js/main.be8a3227.chunk.js","sourcesContent":["import React, { Component } from 'react';\r\n\r\n\r\nexport class Modal extends Component {\r\n static displayName = Modal.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.onCloseClick = this.onCloseClick.bind(this);\r\n }\r\n\r\n onCloseClick() {\r\n if (this.props.onCloseClick) {\r\n this.props.onCloseClick(this);\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n \r\n
\r\n
\r\n {this.props.children}\r\n
\r\n
Close
\r\n
\r\n
\r\n );\r\n }\r\n}\r\n\r\nexport class Confirmation extends Component {\r\n static displayName = Confirmation.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.onCancelClick = this.onCancelClick.bind(this);\r\n this.onSaveClick = this.onSaveClick.bind(this);\r\n }\r\n\r\n onCancelClick() {\r\n if (this.props.onCancelClick) {\r\n this.props.onCancelClick(this);\r\n }\r\n }\r\n\r\n onSaveClick() {\r\n if (this.props.onSaveClick) {\r\n this.props.onSaveClick(this);\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n \r\n
\r\n
\r\n {this.props.children}\r\n
\r\n
Cancel
\r\n
Save
\r\n
\r\n
\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\nexport class BackSplash extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.onClick = this.onClick.bind(this);\r\n this.onMouseMove = this.onMouseMove.bind(this);\r\n }\r\n\r\n /*\r\n componentDidMount() {\r\n document.body.classList.add('noscroll');\r\n }\r\n\r\n componentWillUnmount() {\r\n document.body.classList.remove('noscroll');\r\n }\r\n */\r\n\r\n onClick() {\r\n if (this.props.onClick) {\r\n this.props.onClick(this);\r\n }\r\n }\r\n\r\n onMouseMove() {\r\n if (this.props.onMouseMove) {\r\n this.props.onMouseMove(this);\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n {this.props.children}\r\n
\r\n );\r\n }\r\n}\r\n\r\n","import React, { Component } from 'react';\r\nimport { User, Mail, Phone } from 'react-feather';\r\nimport { BackSplash } from './Dialogs';\r\n\r\nexport class Colorbar extends Component {\r\n static displayName = Colorbar.name;\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n );\r\n }\r\n}\r\n\r\nexport class Header extends Component {\r\n static displayName = Header.name;\r\n\r\n render() {\r\n return (\r\n
\r\n \r\n\r\n {window.location = '/'} }>\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n
\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\nexport class ContactPopOver extends Component {\r\n static displayName = ContactPopOver.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n visible: false\r\n };\r\n\r\n this.toggle = this.toggle.bind(this);\r\n }\r\n\r\n toggle() {\r\n this.setState({ visible: !this.state.visible });\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n \r\n {this.state.visible &&\r\n
\r\n \r\n
\r\n
\r\n

Developer Developer

\r\n

example@epacflexibles.com

\r\n

(123)456-7890

\r\n
\r\n
\r\n }\r\n
\r\n );\r\n }\r\n}\r\n\r\n\r\nexport class Breadcrumbs extends Component {\r\n static displayName = Breadcrumbs.name;\r\n static instance = null;\r\n\r\n constructor(props) {\r\n super(props);\r\n Breadcrumbs.instance = this;\r\n\r\n this.steps = [\r\n {\r\n number: 1,\r\n title: 'Product Specs'\r\n },\r\n {\r\n number: 2,\r\n title: 'Quantities & Shipping'\r\n },\r\n {\r\n number: 3,\r\n title: 'Order Review'\r\n },\r\n {\r\n number: 4,\r\n title: 'Payment & Checkout'\r\n },\r\n {\r\n number: 5,\r\n title: 'Order Confirmation'\r\n },\r\n {\r\n number: 6,\r\n title: 'Artwork Upload'\r\n },\r\n ];\r\n\r\n this.state = {\r\n step: this.steps[0]\r\n }\r\n }\r\n\r\n setActiveStep(number) {\r\n this.setState({\r\n step: number > 0 ? this.steps[number - 1] : null\r\n });\r\n }\r\n\r\n render() {\r\n let self = this;\r\n return (\r\n
\r\n {this.state.step &&\r\n
\r\n

{this.state.step.title}

\r\n
\r\n {this.steps.map((step, idx) => {\r\n return (\r\n \r\n )\r\n })}\r\n
\r\n
\r\n }\r\n
\r\n );\r\n }\r\n}\r\n\r\nexport class BreadcrumbStep extends Component {\r\n static displayName = BreadcrumbStep.name;\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n\r\n
\r\n {this.props.number}\r\n \r\n
\r\n\r\n
\r\n {this.props.title}\r\n
\r\n );\r\n }\r\n}\r\n\r\nexport class ProgressRing extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.size = this.props.size;\r\n this.progress = (100 / this.props.total) * this.props.step;\r\n this.strokeWidth = 8;\r\n\r\n this.center = this.size / 2;\r\n this.radius = this.size / 2 - this.strokeWidth / 2;\r\n this.circumference = 2 * Math.PI * this.radius;\r\n this.circleOneStroke = '#EEEEEE';\r\n this.circleTwoStroke = '#7CBD42';\r\n\r\n this.progressOffset = ((100 - this.progress) / 100) * this.circumference;\r\n\r\n this.style = {\r\n width: this.props.size,\r\n height: this.props.size,\r\n lineHeight: '80px'\r\n }\r\n\r\n this.containerStyle = {\r\n height: this.props.size,\r\n lineHeight: '80px'\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n
{this.props.step} of {this.props.total}
\r\n
\r\n\r\n

{this.props.title}

\r\n\r\n
\r\n )\r\n }\r\n}\r\n\r\n\r\nexport class Title extends Component {\r\n static displayName = Title.name;\r\n\r\n render() {\r\n return (\r\n
\r\n \r\n
\r\n );\r\n }\r\n}","import React, { Component } from 'react';\r\nimport { Container } from 'reactstrap';\r\nimport { Header, Title } from '../components/Pages';\r\n\r\nexport class Layout extends Component {\r\n static displayName = Layout.name;\r\n\r\n render () {\r\n return (\r\n
\r\n
\r\n \r\n <Container>\r\n {this.props.children}\r\n </Container>\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component, useEffect, useState } from 'react';\r\nimport { ChevronDown, PlayCircle, Search } from 'react-feather';\r\nimport { BackSplash } from './Dialogs';\r\n\r\n\r\n\r\nexport class Textbox extends Component {\r\n static displayName = Textbox.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = { \r\n value: this.props.value ? this.props.value : '',\r\n valid: this.isValueValid(this.props.value),\r\n focused: false\r\n }\r\n\r\n this.notifyListeners(this.props.value);\r\n this.onChange = this.onChange.bind(this);\r\n\r\n if (this.props.onInit) {\r\n this.props.onInit(this);\r\n }\r\n }\r\n\r\n onChange(evt) {\r\n let value = evt.target.value;\r\n let valid = this.isValueValid(value);\r\n\r\n if (this.props.requireValidInput === true) {\r\n if (valid || value.length===0) {\r\n this.setState({\r\n value: value,\r\n valid: valid\r\n });\r\n }\r\n }\r\n else {\r\n this.setState({\r\n value: value,\r\n valid: valid\r\n });\r\n }\r\n\r\n this.notifyListeners(value);\r\n evt.preventDefault();\r\n }\r\n\r\n notifyListeners(value) {\r\n let result = this.isValueValid(value);\r\n if (this.props.onChange) {\r\n this.props.onChange(value, result.valid);\r\n }\r\n }\r\n\r\n isValueValid(value) {\r\n let result = { valid: true, type: ValidationType.Success, id: this.props.id };\r\n\r\n if (this.props.required === true) {\r\n if (!value || value.length === 0) {\r\n result = { valid: false, type: ValidationType.Required, id: this.props.id };\r\n }\r\n }\r\n\r\n if (this.props.regex) {\r\n let valid = Regex.Matches(this.props.regex, value); \r\n if (!valid) {\r\n result = { valid: false, type: ValidationType.Invalid, id: this.props.id };\r\n }\r\n } \r\n\r\n if (this.props.onValidate) {\r\n this.props.onValidate(result, this);\r\n }\r\n\r\n return result;\r\n }\r\n\r\n\r\n getStyle(focused) {\r\n let result = 'control textbox';\r\n\r\n if (!focused) {\r\n let validation = this.isValueValid(this.state.value);\r\n if (!validation.valid) {\r\n result += ' error';\r\n }\r\n else {\r\n if (this.state.value) {\r\n result += ' valid';\r\n }\r\n }\r\n }\r\n\r\n return result;\r\n }\r\n\r\n render() {\r\n return (\r\n <input id={this.props.id} className={this.getStyle(this.state.focused)} type={this.props.type ? this.props.type : 'text'} autoComplete='none' value={this.state.value} readOnly={this.props.readOnly} onChange={this.onChange} maxLength={parseInt(this.props.maxLength) > 0 ? parseInt(this.props.maxLength) : 255} placeholder={this.props.placeholder ? this.props.placeholder : 'Input text here'} required={this.props.required === true ? true : false} onFocus={() => this.setState({ focused: true })} onBlur={() => this.setState({ focused: false })} />\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\n\r\nexport class Dropdown extends Component {\r\n static displayName = Dropdown.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n value: this.props.value ? this.props.value : '-1',\r\n valid: this.isValueValid(this.props.value),\r\n focused: false\r\n }\r\n\r\n this.notifyListeners(this.props.value);\r\n this.onChange = this.onChange.bind(this);\r\n }\r\n\r\n onChange(evt) {\r\n let value = evt.target.value;\r\n let valid = this.isValueValid(value);\r\n\r\n this.setState({\r\n value: value,\r\n valid: valid\r\n });\r\n\r\n this.notifyListeners(value);\r\n evt.preventDefault();\r\n }\r\n\r\n notifyListeners(value) {\r\n let validation = this.isValueValid(value);\r\n if (this.props.onChange) {\r\n this.props.onChange(value, validation.valid)\r\n }\r\n }\r\n\r\n isValueValid(value) {\r\n let result = { valid: true, type: ValidationType.Success, id: this.props.id };\r\n\r\n if (this.props.required === true) {\r\n if (!value || value === \"-1\") {\r\n result = { valid: false, type: ValidationType.Required, id: this.props.id };\r\n }\r\n }\r\n\r\n if (this.props.onValidate) {\r\n this.props.onValidate(result, this);\r\n }\r\n\r\n return result;\r\n }\r\n\r\n getStyle(focused) {\r\n let result = 'control dropdown';\r\n if (!focused) {\r\n let validation = this.isValueValid(this.state.value);\r\n if (!validation.valid) {\r\n result += ' error';\r\n }\r\n else {\r\n if (this.state.value) {\r\n result += ' valid';\r\n }\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n render() {\r\n return (\r\n <select id={this.props.id} className={this.getStyle(this.state.focused)} value={this.state.value} onChange={this.onChange} onFocus={() => this.setState({ focused: true })} onBlur={() => this.setState({ focused: false })}>\r\n { this.props.children}\r\n </select>\r\n )\r\n }\r\n}\r\n\r\n\r\nexport class CustomDropdown extends Component {\r\n static displayName = Dropdown.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n selectionVisible: false,\r\n value: this.props.value ? this.props.value : -1\r\n }\r\n\r\n this.notifyListeners(this.props.value );\r\n\r\n this.onToggle = this.onToggle.bind(this);\r\n this.onItemClick = this.onItemClick.bind(this);\r\n }\r\n\r\n getSelectedItem() {\r\n let result = this.props.children[0];\r\n this.props.children.forEach(item => {\r\n if (item.props && item.props.value == this.state.value) {\r\n result = item;\r\n }\r\n });\r\n return result;\r\n }\r\n\r\n\r\n onToggle() {\r\n this.setState({ selectionVisible: !this.state.selectionVisible });\r\n }\r\n\r\n onItemClick(idx, item) {\r\n if (item.props && item.props.disabled !== true) {\r\n this.setState({\r\n value: item.props.value,\r\n selectionVisible: false\r\n });\r\n\r\n this.notifyListeners(item.props.value);\r\n }\r\n }\r\n\r\n notifyListeners(value) {\r\n let validation = this.isValueValid(value);\r\n if (this.props.onChange) {\r\n this.props.onChange(value, validation.valid);\r\n }\r\n }\r\n\r\n isValueValid(value) {\r\n let result = { valid: true, type: ValidationType.Success, id: this.props.id };\r\n\r\n if (this.props.required === true) {\r\n if (!value || value == \"-1\") {\r\n result = { valid: false, type: ValidationType.Required, id: this.props.id };\r\n }\r\n }\r\n\r\n if (this.props.onValidate) {\r\n this.props.onValidate(result, this);\r\n }\r\n\r\n return result;\r\n }\r\n\r\n getStyle() {\r\n let result = 'control dropdown selector';\r\n var validation = this.isValueValid(this.state.value);\r\n if (!validation.valid) {\r\n result += ' error';\r\n }\r\n else {\r\n if (this.state.value) {\r\n result += ' valid';\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n\r\n render() {\r\n\r\n return (\r\n <div className='customDropdown'>\r\n <div className={!this.state.selectionVisible ? this.getStyle() : 'control dropdown selector focus'} onClick={this.onToggle}>\r\n <div className='listItem'>{this.getSelectedItem()}</div>\r\n <div className='chevron'><ChevronDown className='icon' /></div>\r\n </div> \r\n\r\n {this.state.selectionVisible &&\r\n <div>\r\n <BackSplash clear={true} onClick={() => { this.setState({ selectionVisible: false }) }} />\r\n <div className='optionsContainer'>\r\n {this.props.children.map((item, idx) => {\r\n return (\r\n <div key={'list_item' + idx} className={item.props && item.props.disabled === true ? 'listItem disabled' : 'listItem'} onClick={() => { this.onItemClick(idx, item)}}>\r\n {item}\r\n </div>\r\n )\r\n })}\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n )\r\n }\r\n\r\n}\r\n\r\n\r\n\r\nexport class Checkbox extends Component {\r\n static displayName = Checkbox.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n value: this.props.value ? this.props.value : false,\r\n valid: this.isValueValid(this.props.value)\r\n\r\n }\r\n\r\n this.notifyListeners(this.props.value);\r\n this.onChange = this.onChange.bind(this);\r\n }\r\n\r\n onChange(evt) {\r\n let value = evt.target.checked;\r\n\r\n let valid = this.isValueValid(value);\r\n\r\n this.setState({\r\n value: value,\r\n valid: valid\r\n });\r\n\r\n this.notifyListeners(value);\r\n }\r\n\r\n notifyListeners(value) {\r\n let validation = this.isValueValid(value);\r\n if (this.props.onChange) {\r\n this.props.onChange(value, validation.valid)\r\n }\r\n }\r\n\r\n isValueValid(value) {\r\n let result = { valid: true, type: ValidationType.Success, id: this.props.id };\r\n if (this.props.required === true) {\r\n if (!value || value === false) {\r\n result = { valid: false, type: ValidationType.Required, id: this.props.id };\r\n }\r\n }\r\n\r\n if (this.props.onValidate) {\r\n this.props.onValidate(result, this);\r\n }\r\n\r\n return result;\r\n }\r\n\r\n getStyle() {\r\n let result = 'controlContainer control checkbox';\r\n let validation = this.isValueValid(this.state.value);\r\n\r\n if (!validation.valid) {\r\n result += ' error';\r\n }\r\n else {\r\n if (this.state.value) {\r\n result += ' valid';\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n render() {\r\n return (\r\n <div className={this.getStyle()}>\r\n <label><input id={this.props.id} type=\"checkbox\" className={'checkbox'} checked={this.state.value} onChange={this.onChange} /><div className='payload'>{this.props.children}</div></label>\r\n </div>\r\n )\r\n }\r\n}\r\n\r\n\r\nexport class RadioButton extends Component {\r\n static displayName = RadioButton.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n value: this.props.value ? this.props.value : false,\r\n valid: this.isValueValid(this.props.value)\r\n\r\n }\r\n\r\n this.notifyListeners(this.props.value);\r\n this.onChange = this.onChange.bind(this);\r\n }\r\n\r\n onChange(evt) {\r\n let value = evt.target.checked;\r\n let valid = this.isValueValid(value);\r\n\r\n this.setState({\r\n value: value,\r\n valid: valid\r\n });\r\n\r\n this.notifyListeners(value);\r\n }\r\n\r\n notifyListeners(value) {\r\n let validation = this.isValueValid(value);\r\n if (this.props.onChange) {\r\n this.props.onChange(value, validation.valid)\r\n }\r\n }\r\n\r\n isValueValid(value) {\r\n let result = { valid: true, type: ValidationType.Success, id: this.props.id };\r\n if (this.props.required === true) {\r\n if (!value || value === \"-1\") {\r\n result = { valid: false, type: ValidationType.Required, id: this.props.id };\r\n }\r\n }\r\n\r\n if (this.props.onValidate) {\r\n this.props.onValidate(result, this);\r\n }\r\n\r\n return result;\r\n }\r\n\r\n getStyle() {\r\n let result = 'control radiobutton';\r\n let validation = this.isValueValid(this.state.value);\r\n if (!validation.valid) {\r\n result += ' error';\r\n }\r\n else {\r\n if (this.state.value) {\r\n result += ' valid';\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n render() {\r\n return (\r\n <label className='controlContainer radiobutton'><input type=\"radio\" className={this.getStyle()} checked={this.state.value} name={this.props.name} onChange={this.onChange} /> <div className='payload'>{this.props.children}</div></label>\r\n )\r\n }\r\n}\r\n\r\n\r\nexport const ValidationType = {\r\n Success: 0,\r\n Required: 1,\r\n Invalid: 2\r\n}\r\n\r\n\r\nexport class ValidationOrchestrator {\r\n\r\n constructor(onValidatingFunc) {\r\n this.inputValidations = [];\r\n\r\n this.invalidField = null;\r\n this.onValidatingFunc = onValidatingFunc;\r\n this.hasValidated = false;\r\n }\r\n\r\n register(inputValidation) {\r\n this.inputValidations.push(inputValidation);\r\n }\r\n\r\n validate() {\r\n let result = true;\r\n this.inputValidations.reverse().forEach(i => {\r\n if (!i.validate()) {\r\n this.invalidField = i;\r\n result = false;\r\n }\r\n });\r\n this.hasValidated = true;\r\n return result;\r\n }\r\n\r\n getInvalidFieldName() {\r\n return this.invalidField\r\n ? this.invalidField.getInvalidFieldName()\r\n : null;\r\n }\r\n\r\n onValidating() {\r\n if (this.onValidatingFunc && this.hasValidated) {\r\n let isValid = true;\r\n let items = this.inputValidations.reverse();\r\n items.forEach(i => {\r\n if (!i.isValid()) {\r\n isValid = false;\r\n }\r\n });\r\n \r\n this.onValidatingFunc(isValid);\r\n }\r\n }\r\n}\r\n\r\nexport class InputValidation extends Component {\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n type: ValidationType.Success,\r\n show: false\r\n };\r\n\r\n this.validationResults = {};\r\n this.items = [];\r\n\r\n if (this.props.validationOrchestrator) {\r\n this.props.validationOrchestrator.register(this);\r\n }\r\n\r\n this.onValidate = this.onValidate.bind(this);\r\n\r\n this.children = React.Children.map(this.props.children,\r\n child => React.cloneElement(child, {\r\n onValidate: this.onValidate\r\n })\r\n );\r\n\r\n }\r\n\r\n getInvalidFieldName() {\r\n var item = this.getFirstInvalidField();\r\n return item ? item.id : null;\r\n }\r\n\r\n isValid() {\r\n var item = this.getFirstInvalidField();\r\n return item == null;\r\n }\r\n\r\n validate() { \r\n this.setState({\r\n show: true\r\n });\r\n return this.isValid();\r\n }\r\n\r\n onValidate(result, ctrl) {\r\n\r\n this.validationResults[ctrl.props.id] = result;\r\n let item = this.getFirstInvalidField();\r\n let validationType = item ? item.type : ValidationType.Success;\r\n\r\n this.setState({\r\n type: validationType\r\n });\r\n\r\n if (this.props.validationOrchestrator) {\r\n this.props.validationOrchestrator.onValidating();\r\n }\r\n\r\n }\r\n\r\n convertToArray() {\r\n var result = [];\r\n for (var key of Object.keys(this.validationResults)) {\r\n result.push(this.validationResults[key]);\r\n }\r\n return result.reverse();\r\n }\r\n\r\n getFirstInvalidField() {\r\n var result = null;\r\n var items = this.convertToArray(this.validationResults);\r\n\r\n if (items && items.length > 0) {\r\n items.forEach(i => {\r\n if (i.type !== ValidationType.Success && result == null) {\r\n result = i;\r\n }\r\n });\r\n }\r\n return result;\r\n }\r\n\r\n getErrorMessage(show) {\r\n if (show) {\r\n switch (this.state.type) {\r\n case 1:\r\n return (<span className='error-message'>{this.props.requiredText}</span>)\r\n break;\r\n case 2:\r\n return (<span className='error-message'>{this.props.invalidText}</span>)\r\n break;\r\n }\r\n }\r\n return null;\r\n }\r\n\r\n render() {\r\n return (\r\n <div className='input-validation'>\r\n { this.children}\r\n { this.getErrorMessage(this.state.show || !this.props.validationOrchestrator)}\r\n </div>\r\n );\r\n }\r\n};\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\nexport class Regex {\r\n\r\n static Matches(exp, value) {\r\n var result = true;\r\n var regex = exp ? exp : null;\r\n if (regex) {\r\n var r = new RegExp(regex, 'g');\r\n var match = r.exec(value); \r\n if (match == null || match[0] !== value) {\r\n result = false;\r\n }\r\n }\r\n return result;\r\n }\r\n}\r\n\r\n\r\n\r\nexport const Searchbox = ({ id, value, className, maxLength, delay, placeholder, onSubmit }) => {\r\n\r\n const [val, setVal] = React.useState(value ? value : '');\r\n const [timeoutRef, setTimeoutRef] = React.useState(null);\r\n const timeout = null;\r\n\r\n\r\n const submit = () => {\r\n if (onSubmit) {\r\n onSubmit(val);\r\n }\r\n }\r\n\r\n const onKeyUp = evt => {\r\n clearTimeout(timeoutRef);\r\n if (evt.keyCode === 13) {\r\n submit();\r\n }\r\n else { \r\n var timeout = setTimeout(() => {\r\n submit();\r\n }, delay ? parseInt(delay) : 1000);\r\n setTimeoutRef(timeout);\r\n }\r\n }\r\n\r\n const onChange = evt => {\r\n setVal(evt.target.value);\r\n }\r\n\r\n return (\r\n <div className={`control search ${className ? className : ''}`}>\r\n <input id={id} type='text' className={'control textbox'} value={val} placeholder={placeholder ? placeholder : 'Search'} maxLength={maxLength} onKeyUp={onKeyUp} onChange={onChange} />\r\n <Search className='icon' onClick={() => { submit() }} />\r\n </div>\r\n )\r\n\r\n}","import React, { Component, useState } from 'react';\r\nimport { CheckCircle, ChevronRight, ChevronLeft, ChevronDown, Info } from 'react-feather';\r\n\r\n\r\nexport class Row extends Component {\r\n static displayName = Row.name;\r\n\r\n render() {\r\n return (\r\n <div className='row'>\r\n {this.props.children}\r\n </div>\r\n );\r\n }\r\n}\r\n\r\nexport class Column extends Component {\r\n static displayName = Column.name;\r\n\r\n render() {\r\n return (\r\n <div className={this.props.width ? 'column w' + this.props.width : 'column w2'}>\r\n <div className='spacer'>\r\n {this.props.children}\r\n </div>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\nexport class Card extends Component {\r\n static displayName = Card.name;\r\n\r\n render() {\r\n return (\r\n <div className={this.props.transparent === true ? 'card transparent' : 'card'}>\r\n {this.props.title &&\r\n <div className='title'>\r\n <div className='imageContainer'>\r\n <CheckCircle className='icon' />\r\n </div>\r\n\r\n <div className='textContainer'>\r\n <div className='titleText'>{this.props.title}</div>\r\n {this.props.subtitle &&\r\n <div className='subText'>{this.props.subtitle}</div>\r\n }\r\n </div>\r\n </div>\r\n }\r\n\r\n <div className='container'>\r\n {this.props.children}\r\n </div>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\nexport class ExpandableCard extends Component {\r\n static displayName = ExpandableCard.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n collapsed: this.props.expanded ? !this.props.expanded : true\r\n };\r\n\r\n this.toggle = this.toggle.bind(this);\r\n }\r\n\r\n componentDidMount() {\r\n if (this.props.onInit) {\r\n this.props.onInit(this);\r\n }\r\n }\r\n\r\n toggle() {\r\n let collapsed = !this.state.collapsed;\r\n this.setState({ collapsed: collapsed });\r\n if (this.props.onChange && collapsed === false) {\r\n this.props.onChange(collapsed);\r\n }\r\n }\r\n\r\n collapse() {\r\n this.setState({ collapsed: true });\r\n }\r\n\r\n expand() {\r\n this.setState({ collapsed: false });\r\n }\r\n\r\n render() {\r\n return (\r\n <div className={'card expandable'}>\r\n {this.props.title &&\r\n <div className='title' onClick={this.toggle}>\r\n <div className='imageContainer'>\r\n {this.state.collapsed\r\n ? <ChevronRight className='icon' />\r\n : <ChevronDown className='icon' />\r\n }\r\n </div>\r\n\r\n <div className='textContainer'>\r\n <div className='titleText'>{this.props.title}</div>\r\n {this.props.subtitle &&\r\n <div className='subText'>{this.props.subtitle}</div>\r\n }\r\n </div>\r\n </div>\r\n }\r\n\r\n {!this.state.collapsed &&\r\n <div className='container'>\r\n {this.props.children}\r\n </div>\r\n }\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\nexport class ToggleContainer extends Component {\r\n static displayName = ToggleContainer.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n visible: false\r\n };\r\n }\r\n\r\n render() {\r\n return (\r\n <div className={this.state.visible ? 'toggleContainer' : 'toggleContainer'}>\r\n\r\n {this.state.visible\r\n ? <div>{this.props.children}</div>\r\n : <div className='toggle'><span onClick={() => { this.setState({ visible: true }) }}>{this.props.toggleText}</span></div>\r\n }\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\nexport const TileContainer = ({ children }) => {\r\n\r\n return (\r\n <div className='tileContainer'>\r\n {children}\r\n </div>\r\n )\r\n}\r\n\r\n\r\nexport const ImageTile = ({ id, src, value, className, onClick }) => {\r\n\r\n const handleClick = () => {\r\n if (onClick) {\r\n onClick();\r\n }\r\n }\r\n\r\n return (\r\n <div id={id} className={`imageTile ${className ? className : ''}`} onClick={handleClick}>\r\n <div className='image' style={{ backgroundImage: `url(${src})` }} />\r\n <div className='caption'><span>{value}</span></div>\r\n </div>\r\n )\r\n}\r\n\r\n\r\nexport const ImageTileCircle = ({ id, src, value, className, onClick }) => {\r\n\r\n const handleClick = () => {\r\n if (onClick) {\r\n onClick();\r\n }\r\n }\r\n\r\n return (\r\n <div id={id} className={`imageTileCircle ${className ? className : ''}`} onClick={handleClick}>\r\n <div className='image' style={{ backgroundImage: `url(${src})` }} />\r\n <div className='caption'><span>{value}</span></div>\r\n </div>\r\n )\r\n}\r\n\r\n\r\n\r\nexport const Carousel = ({ children }) => {\r\n\r\n const [index, setIndex] = useState(0);\r\n const [orientation, setOrientation] = useState(null);\r\n\r\n const onPreviousClick = () => {\r\n var idx = index;\r\n if (idx > 0) {\r\n idx = idx - 1;\r\n }\r\n else {\r\n idx = children.length - 1;\r\n }\r\n setOrientation('previous');\r\n setIndex(idx);\r\n }\r\n\r\n const onNextClick = () => {\r\n var idx = index;\r\n if (idx < children.length - 1) {\r\n idx = idx + 1;\r\n }\r\n else {\r\n idx = 0;\r\n }\r\n setOrientation('next');\r\n setIndex(idx);\r\n }\r\n\r\n const getAnimationStyle = () => {\r\n var result = '';\r\n\r\n if (orientation == 'next') {\r\n result = 'slide-in-left';\r\n }\r\n\r\n if (orientation == 'previous') {\r\n result = 'slide-in-right';\r\n }\r\n\r\n return result;\r\n }\r\n\r\n return (\r\n <div className='carousel'>\r\n <div className='nav' onClick={onPreviousClick}>\r\n <ChevronLeft className='icon' />\r\n </div>\r\n <div className='window'>\r\n <div className='item-container' onClick={onNextClick}>\r\n {children.map((child, i) => {\r\n return (\r\n <div key={`child${i}`} className={index == i ? `carousel-item visibility-visible ${getAnimationStyle()}` : 'carousel-item visibility-hidden'}>{child}</div>\r\n )\r\n })}\r\n </div>\r\n </div>\r\n <div className='nav' onClick={onNextClick}>\r\n <ChevronRight className='icon' />\r\n </div>\r\n </div>\r\n )\r\n}\r\n\r\nexport const Page = ({ children }) => {\r\n\r\n return (\r\n <div className='page'>\r\n {children}\r\n </div>\r\n )\r\n}\r\n\r\n\r\n\r\nexport const ButtonTile = ({ id, className, width, height, children, onClick, text }) => {\r\n\r\n return (\r\n <div id={id} className={className ? `buttonTile ${className}` : 'buttonTile'} style={{ width: width ? width : 280, height: height ? height : 400 }}>\r\n <div className='header'>\r\n <Info className=\"icon\" />\r\n </div>\r\n\r\n <div className='content'>\r\n {children}\r\n </div>\r\n\r\n {text && onClick &&\r\n <div className='footer'>\r\n <button className='btn btn-secondary' onClick={onClick}>{text}</button>\r\n </div>\r\n }\r\n </div>\r\n )\r\n}\r\n\r\n\r\nexport const ExpandableTab = ({ children, className, title }) => {\r\n\r\n const [collapsed, setCollapsed] = useState(true);\r\n\r\n return (\r\n <div>\r\n <div className={className ? `expandableTab ${className}` : 'expandableTab'}>\r\n {!collapsed &&\r\n <div className='backsplash' onClick={() => { setCollapsed(!collapsed) }} />\r\n }\r\n <div className='component'>\r\n <div className={collapsed ? 'content hidden scale-up-ver-top' : 'content visible scale-up-ver-top'}>\r\n <div className='panel'>\r\n {children}\r\n </div>\r\n </div>\r\n <div className='tab' onClick={() => { setCollapsed(!collapsed) }}>{title}</div>\r\n </div>\r\n </div>\r\n </div>\r\n )\r\n\r\n}","import React, { Component, useEffect, useState } from 'react';\r\nimport { Info } from 'react-feather';\r\nimport { BackSplash, Modal } from './Dialogs';\r\nimport { Edit, Upload, ArrowDownCircle, MessageSquare } from 'react-feather';\r\nimport { Textbox, Dropdown } from './Controls';\r\n\r\nexport class SectionTitle extends Component {\r\n static displayName = SectionTitle.name;\r\n\r\n render() {\r\n return (\r\n <div className='sectionTitle'>\r\n {this.props.description\r\n ? <ContextHelp title={this.props.children} description={this.props.description} image={this.props.image}>\r\n <h3>{this.props.children}</h3>\r\n </ContextHelp>\r\n : <h3>{this.props.children}</h3>\r\n } \r\n </div>\r\n );\r\n }\r\n}\r\n\r\nexport class SectionLabel extends Component {\r\n static displayName = SectionLabel.name;\r\n\r\n render() {\r\n return (\r\n <div className='sectionLabel'>\r\n <div className='description'>{this.props.description}</div>\r\n <div className='action'>{this.props.children}</div>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\nexport class ContextHelp extends Component {\r\n static displayName = Info.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n showModal: false\r\n }\r\n\r\n this.onClick = this.onClick.bind(this);\r\n }\r\n\r\n onClick() {\r\n this.setState({ showModal: true });\r\n }\r\n\r\n getImageClass() {\r\n return `background-${this.props.image}`; \r\n }\r\n\r\n render() {\r\n return (\r\n <div className={this.props.fill === true ? 'contextHelp fill' : 'contextHelp'}>\r\n \r\n {this.props.children &&\r\n <div className={this.props.fill === true ? 'payload fill' : 'payload'}>\r\n {this.props.children}\r\n </div>\r\n }\r\n <Info className='icon' onClick={this.onClick} />\r\n\r\n\r\n {this.state.showModal &&\r\n <Modal onCloseClick={() => { this.setState({ showModal: false }) }}>\r\n <div className='sectionModalContent'>\r\n {this.props.image &&\r\n <div className={`image ${this.getImageClass()}`}></div>\r\n }\r\n <h3>{this.props.title}</h3>\r\n <div className='content'>{this.props.description}</div>\r\n </div>\r\n </Modal>\r\n }\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\nexport class Money extends Component {\r\n static displayName = Money.name;\r\n\r\n render() {\r\n return (\r\n <div className='money'>\r\n <span className='currency color-light-grey'>{this.props.currency}</span><span className='amount color-grey'>{this.props.amount}</span>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\nexport class EditLink extends Component {\r\n static displayName = EditLink.name;\r\n\r\n render() {\r\n return (\r\n <div className='iconLink'>\r\n <span onClick={this.props.onClick}><Edit className='icon' />{this.props.children}</span>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\nexport class DownloadLink extends Component {\r\n static displayName = DownloadLink.name;\r\n\r\n render() {\r\n return (\r\n <div className='iconLink'>\r\n <a href={this.props.href}><ArrowDownCircle className='icon' />{this.props.children}</a>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\nexport class UploadLink extends Component {\r\n static displayName = UploadLink.name;\r\n\r\n render() {\r\n return (\r\n <div className='iconLink'>\r\n <a href={this.props.href}><Upload className='icon' />{this.props.children}</a>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\nexport class MessageLink extends Component {\r\n static displayName = DownloadLink.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n visible: false\r\n }\r\n\r\n this.onIconClick = this.onIconClick.bind(this);\r\n }\r\n\r\n onIconClick() {\r\n this.setState({ visible: !this.state.visible });\r\n }\r\n\r\n getClassName() {\r\n let result = 'iconLink';\r\n\r\n switch (this.props.type) {\r\n case 'warn':\r\n result += ' warn';\r\n break;\r\n case 'error':\r\n result += ' error';\r\n break;\r\n }\r\n return result;\r\n }\r\n\r\n render() {\r\n return (\r\n <div className={this.getClassName()}>\r\n\r\n <span><MessageSquare className='icon' onClick={this.onIconClick} /><span onClick={this.props.onClick}>{this.props.children}</span></span>\r\n\r\n {this.state.visible &&\r\n <div className='safety'>\r\n <BackSplash clear={true} onClick={this.onIconClick} />\r\n <div className='popover' onClick={this.onIconClick}>This is a test</div>\r\n </div>\r\n }\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\nexport class Alert extends Component {\r\n static displayName = UploadLink.name;\r\n\r\n getClassName() {\r\n let result = 'alert';\r\n\r\n switch (this.props.type) {\r\n case 'warn':\r\n result += ' warn';\r\n break;\r\n case 'error':\r\n result += ' error';\r\n break;\r\n case 'success':\r\n result += ' success';\r\n break;\r\n default:\r\n result += ' info';\r\n break;\r\n }\r\n return result;\r\n }\r\n\r\n render() {\r\n return (\r\n <div className={this.getClassName()}>\r\n <div className='alert-content'>\r\n {this.props.children}\r\n </div>\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\nexport class SkuEditor extends Component {\r\n static displayName = SkuEditor.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n }\r\n\r\n render() {\r\n return (\r\n <div className='skus editor'>\r\n <ContextHelp title={'test'} description={'test'} fill={true}>\r\n <Dropdown>\r\n <option value={-1}>Select Quantity Range</option>\r\n <option value={1000}>1000...1999</option>\r\n <option value={2000}>2000...2999</option>\r\n <option value={3000}>3000...3999</option>\r\n </Dropdown>\r\n </ContextHelp>\r\n\r\n <span className='text success'>Select higher quantity to receive lower unit price</span>\r\n\r\n <table>\r\n <thead>\r\n <tr>\r\n <th className='description'><span>SKU Description <ContextHelp title='SKU Description' description='content' /></span></th>\r\n <th className='unitPrice'>Unit Price <ContextHelp title='Unit Price' description='content' /></th>\r\n <th className='quantity'>Quantity <ContextHelp title='Quantity' description='content' /></th>\r\n <th className='totalPrice'>Total Price <ContextHelp title='Total Price' description='content' /></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr>\r\n <td className='description'><Textbox required={true} /></td>\r\n <td className='unitPrice'><Money currency={'GBP'} amount={'0.1234'} /></td>\r\n <td className='quantity'><Textbox type='number' required={true} regex={'[0-9]*'} requireValidInput={true} maxLength={6} /></td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.12'} /></td>\r\n </tr>\r\n\r\n <tr>\r\n <td className='description'><Textbox required={true} /></td>\r\n <td className='unitPrice'><Money currency={'GBP'} amount={'0.1234'} /></td>\r\n <td className='quantity'><Textbox type='number' required={true} regex={'[0-9]*'} requireValidInput={true} maxLength={6} /></td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.12'} /></td>\r\n </tr>\r\n\r\n <tr className='totals'>\r\n <td className='description'></td>\r\n <td className='unitPrice'>Total</td>\r\n <td className='quantity'>8000</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1160'} /></td>\r\n </tr>\r\n\r\n </tbody>\r\n\r\n </table>\r\n </div>\r\n )\r\n }\r\n}\r\n\r\n\r\nexport class SkuDisplay extends Component {\r\n static displayName = SkuDisplay.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n }\r\n\r\n render() {\r\n return (\r\n <div className='skus display'>\r\n <table>\r\n <thead>\r\n <tr>\r\n <th className='description'></th>\r\n <th className='unitPrice'>Unit Price</th>\r\n <th className='quantity'>Quantity</th>\r\n <th className='totalPrice'>Total Price</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n\r\n <tr>\r\n <td className='description'>Chocolate</td>\r\n <td className='unitPrice'><Money currency={'GBP'} amount={'1.2346'} /></td>\r\n <td className='quantity'>10000</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n\r\n <tr>\r\n <td className='description'>Vanilla</td>\r\n <td className='unitPrice'><Money currency={'GBP'} amount={'1.2346'} /></td>\r\n <td className='quantity'>10000</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n\r\n <tr>\r\n <td className='description'>Strawberry</td>\r\n <td className='unitPrice'><Money currency={'GBP'} amount={'1.2346'} /></td>\r\n <td className='quantity'>10000</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n\r\n </tbody>\r\n\r\n </table>\r\n </div>\r\n )\r\n }\r\n}\r\n\r\n\r\n\r\nexport class GrandTotal extends Component {\r\n static displayName = GrandTotal.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n }\r\n\r\n render() {\r\n return (\r\n <div className='skus display grandTotal'>\r\n <table>\r\n <tbody>\r\n <tr>\r\n <td></td>\r\n <td className='name'>Subtotal</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n <tr>\r\n <td></td>\r\n <td className='name'>Overage</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n <tr>\r\n <td></td>\r\n <td className='name'>Shipping</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n <tr>\r\n <td></td>\r\n <td className='name'>Total Amount</td>\r\n <td className='totalPrice'><Money currency={'GBP'} amount={'1234.56'} /></td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n )\r\n }\r\n}\r\n\r\n\r\nexport class SideLabel extends Component {\r\n static displayName = GrandTotal.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n visible: true\r\n }\r\n\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n {this.state.visible &&\r\n <div className='sidelabel' onClick={() => { this.setState({visible: false})}}>\r\n {this.props.children}\r\n </div>\r\n }\r\n </div>\r\n )\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Textbox } from '../components/Controls';\r\nimport { Column, Row, Card } from '../components/Containers';\r\nimport { Confirmation } from '../components/Dialogs';\r\nimport { EditLink, DownloadLink, SectionTitle, SectionLabel, SideLabel } from '../components/Components';\r\n\r\n\r\nexport class ProductSpecsPage extends Component {\r\n static displayName = ProductSpecsPage.name;\r\n \r\n constructor(props) {\r\n super(props); \r\n\r\n this.state = {\r\n showPopup: false\r\n }\r\n\r\n Breadcrumbs.instance.setActiveStep(1);\r\n }\r\n \r\n render () {\r\n return (\r\n <div>\r\n <SideLabel>ePac App</SideLabel>\r\n <h3>Client Name <br />Plow Bottom Pouch for Nutrition Bar (Barrier)</h3> \r\n <p>Order # 52944</p>\r\n\r\n <Card title='Dieline'>\r\n <p>Component will be restyled separately</p>\r\n </Card>\r\n\r\n <Card title='Features'>\r\n <Row>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='zipper'>Zipper</SectionTitle>\r\n <SectionLabel description=\"Press-To-Close\"><EditLink onClick={() => { this.setState({ showPopup: true }) }}>40 mm</EditLink></SectionLabel>\r\n </Column>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='tearnotch'>Tear Notch</SectionTitle>\r\n <SectionLabel description=\"Standard\"><EditLink onClick={() => { this.setState({ showPopup: true }) }}>22 mm</EditLink></SectionLabel>\r\n </Column>\r\n </Row>\r\n <Row>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='hanghole'>Hang Hole</SectionTitle>\r\n <SectionLabel description=\"Sombrero\"><EditLink onClick={() => { this.setState({ showPopup: true }) }}>6.5 mm</EditLink></SectionLabel>\r\n </Column>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='valve'>Valve</SectionTitle>\r\n <SectionLabel description=\"Included\" />\r\n </Column>\r\n </Row>\r\n </Card>\r\n\r\n <Card title='Specifications'>\r\n <Row>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='material'>Material</SectionTitle>\r\n <SectionLabel description=\"SPEC-3\"><DownloadLink href='https://productdi-api-gb.epacllc.com/api/structureSpecs/3/pdf'>Information Sheet</DownloadLink></SectionLabel>\r\n </Column>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='sku'>SKU Count</SectionTitle>\r\n <SectionLabel description=\"3\"/>\r\n </Column>\r\n </Row>\r\n <Row>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='eyemark'>Eyemark Placement</SectionTitle>\r\n <SectionLabel description=\"Outside - Both Sides\"/>\r\n </Column>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='colorspec'>Color Specification</SectionTitle>\r\n <SectionLabel description=\"CMYK + W + W\" />\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='corner'>Rounded Corners</SectionTitle>\r\n <SectionLabel description=\"Yes\" />\r\n </Column>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='seal'>Seal Width</SectionTitle>\r\n <SectionLabel description=\"8 mm\" />\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' image='connect'>ePac Connect</SectionTitle>\r\n <SectionLabel description=\"None\" />\r\n </Column>\r\n <Column>\r\n </Column>\r\n </Row>\r\n </Card>\r\n\r\n <Card title='Instructions' subtitle='Optional'>\r\n <SectionTitle description='Lorem Ipsum is simply dummy text of the printing and typesetting industry.' imageUrl='instructions'>Color Instructions</SectionTitle>\r\n <Textbox />\r\n </Card>\r\n\r\n {this.state.showPopup &&\r\n <Confirmation onCancelClick={() => { this.setState({ showPopup: false }) }} onSaveClick={() => { this.setState({ showPopup: false }) }}>\r\n <h3>Zipper</h3>\r\n <p>Please enter the offset in mm:</p>\r\n <Textbox type='number' value={'22.0'} regex={'[0-9]*(\\.[0-9]{0,4})?'} required={true} requireValidInput={true} />\r\n </Confirmation>\r\n }\r\n\r\n <button className='btn btn-secondary pull-right' onClick={() => { window.location = '/quantities' }}>Next</button>\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Textbox, Dropdown } from '../components/Controls';\r\nimport { Column, Row, Card, ToggleContainer } from '../components/Containers';\r\nimport { UploadLink, SectionTitle, SkuEditor, SideLabel } from '../components/Components';\r\n\r\n\r\nexport class QuantitiesPage extends Component {\r\n static displayName = QuantitiesPage.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n showPopup: false\r\n }\r\n\r\n Breadcrumbs.instance.setActiveStep(2);\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <SideLabel>ePac App</SideLabel>\r\n <h3>Client Name <br />Plow Bottom Pouch for Nutrition Bar (Barrier)</h3>\r\n <p>Order # 52944</p>\r\n\r\n <Card title='Quantities'>\r\n <SkuEditor />\r\n </Card>\r\n\r\n <Card title='Shipping Address' subtitle='This section can be edited later'> \r\n <Row>\r\n <Column>\r\n <SectionTitle>Country</SectionTitle>\r\n <Dropdown required={ true }>\r\n <option value={-1}>Select Country</option>\r\n <option value={1}>United Kingdom</option>\r\n <option value={2}>United States</option>\r\n <option value={3}>France</option>\r\n </Dropdown> \r\n </Column>\r\n <Column>\r\n <SectionTitle>City</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n </Row> \r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>Address Line 1</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Postal Code</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n </Row> \r\n\r\n <Row>\r\n <Column>\r\n <ToggleContainer toggleText='+ Add Address Line 2'>\r\n <SectionTitle>Address Line 2</SectionTitle>\r\n <Textbox />\r\n </ToggleContainer>\r\n\r\n <ToggleContainer toggleText='+ Add Company Name'>\r\n <SectionTitle>Company Name</SectionTitle>\r\n <Textbox />\r\n </ToggleContainer>\r\n\r\n </Column>\r\n <Column>\r\n <SectionTitle>State</SectionTitle>\r\n <Dropdown required={true}>\r\n <option value={-1}>Select State</option>\r\n <option value={1}>CA</option>\r\n <option value={2}>MS</option>\r\n <option value={3}>Al</option>\r\n </Dropdown> \r\n </Column>\r\n </Row> \r\n\r\n </Card>\r\n\r\n <Card title='ePac Connect Contact' subtitle='Some explanation about this section'> \r\n <Row>\r\n <Column>\r\n <SectionTitle>Full Name</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Email Address</SectionTitle>\r\n <Textbox type='email' required={true} />\r\n </Column>\r\n </Row> \r\n </Card>\r\n\r\n <Card title='Purchase Order & Attachments' subtitle='Optional' >\r\n <SectionTitle>Enter PO#</SectionTitle>\r\n <Textbox />\r\n\r\n <SectionTitle>Attach PO</SectionTitle>\r\n <UploadLink>Browse...</UploadLink>\r\n\r\n </Card>\r\n\r\n <button className='btn btn-tertiary-outline' onClick={() => { window.location = '/' }}>Back</button>\r\n <button className='btn btn-secondary pull-right' onClick={() => { window.location = '/review' }}>Checkout</button>\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Textbox, Dropdown, Checkbox } from '../components/Controls';\r\nimport { Column, Row, Card, ToggleContainer } from '../components/Containers';\r\nimport { DownloadLink, EditLink, SectionTitle, SkuDisplay, GrandTotal, SideLabel } from '../components/Components';\r\n\r\n\r\nexport class OrderReviewPage extends Component {\r\n static displayName = OrderReviewPage.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n editAddress: false\r\n }\r\n\r\n Breadcrumbs.instance.setActiveStep(3);\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <SideLabel>SalesForce</SideLabel>\r\n <h3>Client Name <br />Plow Bottom Pouch for Nutrition Bar (Barrier)</h3>\r\n <p>Order # 52944</p>\r\n\r\n {this.state.editAddress\r\n ?\r\n <Card title='Shipping Address'>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Country</SectionTitle>\r\n <Dropdown required={true} value={1}>\r\n <option value={-1}>Select Country</option>\r\n <option value={1}>United Kingdom</option>\r\n <option value={2}>United States</option>\r\n <option value={3}>France</option>\r\n </Dropdown>\r\n </Column>\r\n <Column>\r\n <SectionTitle>City</SectionTitle>\r\n <Textbox required={true} value={'Worcester Park'} />\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>Address Line 1</SectionTitle>\r\n <Textbox required={true} value={'1 Chapel Hill'} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Postal Code</SectionTitle>\r\n <Textbox required={true} value={'SW1A 2AA'}/>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <ToggleContainer toggleText='+ Add Address Line 2'>\r\n <SectionTitle>Address Line 2</SectionTitle>\r\n <Textbox />\r\n </ToggleContainer>\r\n\r\n <ToggleContainer toggleText='+ Add Company Name'>\r\n <SectionTitle>Company Name</SectionTitle>\r\n <Textbox />\r\n </ToggleContainer>\r\n\r\n </Column>\r\n <Column>\r\n <SectionTitle>State</SectionTitle>\r\n <Textbox value={'Surrey'} />\r\n </Column>\r\n </Row>\r\n\r\n <button className='btn btn-tertiary-outline' onClick={() => { this.setState({ editAddress: false }) }}>Cancel</button>\r\n <button className='btn btn-secondary pull-right' onClick={() => { this.setState({ editAddress: false }) }}>Save</button>\r\n\r\n </Card>\r\n :\r\n < Card title='Shipping Address' subtitle={<EditLink onClick={() => { this.setState({ editAddress: true})} }>Edit</EditLink>}>\r\n <Row>\r\n <Column width={3}>\r\n <p>\r\n John Smith <br />\r\n 1 Chapel Hill <br />\r\n SW1A 2AA <br />\r\n </p>\r\n </Column>\r\n <Column width={3}>\r\n <p>\r\n Worcester Park <br />\r\n Surrey <br />\r\n United Kingdom <br />\r\n </p>\r\n </Column>\r\n <Column width={3}>\r\n <p>PO #123-456-789</p>\r\n <DownloadLink>Download Attachment</DownloadLink>\r\n </Column>\r\n </Row>\r\n </Card>\r\n }\r\n\r\n <Card title='SKU Description'>\r\n <SkuDisplay /> \r\n </Card>\r\n\r\n <Card transparent={true}>\r\n <GrandTotal />\r\n <div className='pull-right'><Checkbox required={true}>By placing this order I agree to <a href='http://www.epacflexibles.com'>ePac's Terms and Conditions</a></Checkbox></div>\r\n </Card>\r\n \r\n\r\n <button className='btn btn-secondary pull-right' onClick={() => { window.location = '/payment' }}>Proceed To Payment</button>\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Textbox, Dropdown, Checkbox, RadioButton } from '../components/Controls';\r\nimport { Column, Row, Card, ExpandableCard, ToggleContainer } from '../components/Containers';\r\nimport { SectionTitle, SideLabel } from '../components/Components';\r\n\r\n\r\n\r\nexport class PaymentPage extends Component {\r\n static displayName = PaymentPage.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.controls = {};\r\n\r\n this.state = {\r\n sameAsShipping: true,\r\n cardExpanded: true,\r\n achExpanded: false\r\n }\r\n\r\n Breadcrumbs.instance.setActiveStep(4);\r\n\r\n this.cardChange = this.cardChange.bind(this);\r\n this.achChange = this.achChange.bind(this);\r\n }\r\n\r\n cardChange() {\r\n this.controls.ach.collapse();\r\n }\r\n\r\n achChange() {\r\n this.controls.card.collapse();\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <SideLabel>SalesForce</SideLabel>\r\n <h3>Client Name <br />Plow Bottom Pouch for Nutrition Bar (Barrier)</h3>\r\n <p>Order # 52944</p>\r\n\r\n <ExpandableCard title='Credit or Debit Card' expanded={this.state.cardExpanded} onInit={ctrl => { this.controls['card'] = ctrl }} onChange={this.cardChange}>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Name on Card</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Valid Through</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n </Row>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Card Number</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>CVC Code</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n </Row>\r\n </ExpandableCard>\r\n\r\n <ExpandableCard title='ACH Direct Deposit' expanded={this.state.achExpanded} onInit={ctrl => { this.controls['ach'] = ctrl }} onChange={this.achChange}>\r\n <RadioButton name='accountType' value={true}>Personal Account</RadioButton>\r\n <RadioButton name='accountType'>Business Account</RadioButton>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Full Name</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Account Number</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n </Row>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Bank Name</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Routing Number</SectionTitle>\r\n <Textbox required={true} />\r\n </Column>\r\n </Row>\r\n </ExpandableCard>\r\n\r\n {!this.state.sameAsShipping\r\n ?\r\n <Card title='Billing Address' subtitle={<Checkbox value={this.state.sameAsShipping} onChange={(value) => { this.setState({ sameAsShipping: value }) }}>Same as Shipping Address</Checkbox>}>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Country</SectionTitle>\r\n <Dropdown required={true} value={1}>\r\n <option value={-1}>Select Country</option>\r\n <option value={1}>United Kingdom</option>\r\n <option value={2}>United States</option>\r\n <option value={3}>France</option>\r\n </Dropdown>\r\n </Column>\r\n <Column>\r\n <SectionTitle>City</SectionTitle>\r\n <Textbox required={true} value={'Worcester Park'} />\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>Address Line 1</SectionTitle>\r\n <Textbox required={true} value={'1 Chapel Hill'} />\r\n </Column>\r\n <Column>\r\n <SectionTitle>Postal Code</SectionTitle>\r\n <Textbox required={true} value={'SW1A 2AA'} />\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <ToggleContainer toggleText='+ Add Address Line 2'>\r\n <SectionTitle>Address Line 2</SectionTitle>\r\n <Textbox />\r\n </ToggleContainer>\r\n\r\n <ToggleContainer toggleText='+ Add Company Name'>\r\n <SectionTitle>Company Name</SectionTitle>\r\n <Textbox />\r\n </ToggleContainer>\r\n\r\n </Column>\r\n <Column>\r\n <SectionTitle>State</SectionTitle>\r\n <Textbox value={'Surrey'} />\r\n </Column>\r\n </Row>\r\n </Card>\r\n :\r\n < Card title='Billing Address' subtitle={<Checkbox value={this.state.sameAsShipping} onChange={(value) => { this.setState({ sameAsShipping: value }) }}>Same as Shipping Address</Checkbox>}>\r\n <Row>\r\n <Column width={3}>\r\n <p>\r\n John Smith <br />\r\n 1 Chapel Hill <br />\r\n SW1A 2AA <br />\r\n </p>\r\n </Column>\r\n <Column width={3}>\r\n <p>\r\n Worcester Park <br />\r\n Surrey <br />\r\n United Kingdom <br />\r\n </p>\r\n </Column>\r\n <Column width={3}>\r\n <p>PO #123-456-789</p>\r\n </Column>\r\n </Row>\r\n </Card>\r\n }\r\n\r\n <button className='btn btn-tertiary-outline' onClick={() => { window.location = '/review' }}>Back</button>\r\n <button className='btn btn-secondary pull-right' onClick={() => { window.location = '/confirmation' }}>Submit Payment</button>\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Card } from '../components/Containers';\r\nimport { SectionTitle, SideLabel } from '../components/Components';\r\n\r\n\r\nexport class OrderConfirmationPage extends Component {\r\n static displayName = OrderConfirmationPage.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n Breadcrumbs.instance.setActiveStep(5);\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <SideLabel>SalesForce</SideLabel>\r\n <h3>Client Name <br />Plow Bottom Pouch for Nutrition Bar (Barrier)</h3>\r\n\r\n <Card title={<span>Thank you for Placing Your Order <span className='color-blue'>#52944</span></span>}>\r\n <SectionTitle>Next Steps:</SectionTitle>\r\n\r\n <ol>\r\n <li>You will receive a confirmation email with your order details and a link to download the dielines for each SKU, or download the dielines from link below.<br /><br /><a href='http://www.epacflexibles.com'>Download Dielines</a></li>\r\n <li>Review the <a href='http://www.epacflexibles.com'>Artwork Instructions</a> to ensure proper production of artwork.</li>\r\n <li>In the next step, upload your artwork file for each SKU and click Submit.</li>\r\n </ol> \r\n\r\n <p>We'll take it from there!</p>\r\n\r\n </Card>\r\n\r\n <button className='btn btn-secondary pull-right' onClick={() => { window.location = '/artwork' }}>Proceed To Artwork Upload</button>\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Column, Row, Card } from '../components/Containers'; \r\nimport { UploadLink, SectionTitle, SideLabel } from '../components/Components';\r\n\r\nexport class ArtworkPage extends Component {\r\n static displayName = ArtworkPage.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n Breadcrumbs.instance.setActiveStep(6);\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <SideLabel>ePac App</SideLabel>\r\n <h3>Client Name <br />Plow Bottom Pouch for Nutrition Bar (Barrier)</h3>\r\n <p>Order # 52944</p>\r\n\r\n <Card title='Prepare Your Artwork for Upload'>\r\n \r\n <ol>\r\n <li>After downloading the dielines, read through the Artwork Instructions to ensure production and no delays in the process.<br /><br /><a href='http://www.epacflexibles.com'>Download Dielines</a></li>\r\n <li>Save the completed artwork files on your computer.</li>\r\n <li>Upload the artwork file for each SKU below.</li>\r\n </ol>\r\n\r\n </Card>\r\n\r\n\r\n <Card title='Upload Your Artwork'>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>SKU Description</SectionTitle>\r\n </Column>\r\n <Column>\r\n <SectionTitle>Artwork Upload</SectionTitle>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <span>Vanilla</span>\r\n </Column>\r\n <Column>\r\n <UploadLink>Upload</UploadLink>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <span>Chocolate</span>\r\n </Column>\r\n <Column>\r\n <UploadLink>Upload</UploadLink>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <span>Strawberry</span>\r\n </Column>\r\n <Column>\r\n <UploadLink>Upload</UploadLink>\r\n </Column>\r\n </Row>\r\n </Card>\r\n \r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\nimport { Breadcrumbs } from '../components/Pages';\r\n\r\nimport './Custom.css'\r\n\r\nexport class Home extends Component {\r\n static displayName = Home.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n Breadcrumbs.instance.setActiveStep(0);\r\n }\r\n\r\n render() {\r\n return (\r\n <div className='home'>\r\n <h1>Epac Style Guide</h1>\r\n\r\n <table>\r\n <tbody>\r\n <tr>\r\n <td><a href='/overview'>Components Overview</a></td><td>An Overview of the used page components.</td>\r\n </tr>\r\n <tr>\r\n <td><a href='/icons'>Icons</a></td><td>Used icons.</td>\r\n </tr>\r\n <tr>\r\n <td><a href='/validation'>Input Validation Demo</a></td><td>Demonstration of the input validation logic.</td>\r\n </tr>\r\n </tbody>\r\n </table> \r\n </div>\r\n );\r\n }\r\n}\r\n","import React, { Component } from 'react';\r\nimport { Colorbar, ContactPopOver, Breadcrumbs, Header, Title } from '../components/Pages';\r\nimport { Card, ExpandableCard, ToggleContainer, Row, Column, TileContainer, ImageTileCircle, ButtonTile, Carousel, Page, ExpandableTab } from '../components/Containers';\r\nimport { Modal, Confirmation, BackSplash } from '../components/Dialogs';\r\nimport { Searchbox, Textbox, Dropdown, CustomDropdown, Checkbox, RadioButton, InputValidation } from '../components/Controls';\r\nimport { SectionTitle, SectionLabel, ContextHelp, Money, EditLink, DownloadLink, UploadLink, MessageLink, Alert } from '../components/Components';\r\n\r\nimport './Custom.css'\r\n\r\nexport class Overview extends Component {\r\n static displayName = Overview.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n showPopup: false,\r\n showConfirmation: false,\r\n showBackSplash: false\r\n }\r\n\r\n Breadcrumbs.instance.setActiveStep(0);\r\n }\r\n\r\n render() {\r\n return (\r\n <div className='overview'>\r\n <h1>Component Overview</h1> \r\n\r\n <Card>\r\n <p>Add the following style sheets to your page:</p>\r\n <div className='scrollable'>\r\n <ul>\r\n <li><a target='_blank' href=\"/styles/Fonts.css\">/styles/Fonts.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Epac.css\">/styles/Epac.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Components.css\">/styles/Components.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Containers.css\">/styles/Containers.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Controls.css\">/styles/Controls.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Dialogs.css\">/styles/Dialogs.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Pages.css\">/styles/Pages.css</a></li>\r\n <li><a target='_blank' href=\"/styles/Animations.css\">/styles/Animations.css</a></li>\r\n </ul>\r\n </div>\r\n\r\n <Alert>Please note! Different styles are applied in mobile mode! You also will need to use the Browser Developer Tools to analyze the html of some of the dynamic elements.</Alert>\r\n </Card>\r\n\r\n\r\n <h2>Fonts</h2>\r\n <p>All used fonts are of the family Montserrat</p>\r\n\r\n <ComponentInfo name='Headers' description='The used Headers.' stylesheets={['Epac']} noflex={ true}>\r\n <h1>Header 1</h1>\r\n <h2>Header 2</h2>\r\n <h3>Header 3</h3>\r\n <h4>Header 4</h4>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Paragraph' description='' stylesheets={['Epac']} noflex={true}>\r\n <p>This is a Paragraph</p>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Lists (ordered)' description='' stylesheets={['Epac']} noflex={true}>\r\n <ol>\r\n <li>Item 1</li>\r\n <li>Item 2</li>\r\n <li>Item 3</li>\r\n <li>Item 4</li>\r\n </ol>\r\n </ComponentInfo>\r\n\r\n\r\n <ComponentInfo name='Alerts' description='' stylesheets={['Epac', 'Components']}>\r\n <Alert type='info'>This is an alert! Valid types are success, warn, error, info.</Alert>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Spinner' description='' stylesheets={['Epac']}>\r\n <div className='spinner-circle' />\r\n </ComponentInfo>\r\n\r\n\r\n\r\n <h2>Buttons</h2>\r\n <p>The following displays the used button styles:</p>\r\n\r\n <ComponentInfo name='Button (Primary)' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-primary'>Primary Button</button>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button (Primary - outline)' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-primary-outline'>Primary Button</button>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button (Secondary)' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-secondary'>Secondary Button</button>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button (Secondary - outline)' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-secondary-outline'>Secondary Button</button>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button (Tertiary)' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-tertiary'>Tertiary Button</button>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button (Tertiary - outline)' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-tertiary-outline'>Tertiary Button</button>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button Round Bottom' stylesheets={['Epac']} noflex={true}>\r\n <button className='btn btn-secondary btn-round-bottom'>Round Button</button>\r\n </ComponentInfo>\r\n\r\n\r\n <h2>Page Components</h2>\r\n <p>The Page components are used to design the overall page layout for all pages. To render the page components the styesheet Pages.css is required.</p>\r\n\r\n <ComponentInfo name='Header' description='This component displays the Page Header.' stylesheets={['Epac', 'Pages']}>\r\n <Header />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Title' description='This component displays the Page Title includign Breadcrumbs.' stylesheets={['Epac', 'Pages']}>\r\n <Title />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Colorbar' description='Color bar used on the top of the page.' stylesheets={['Epac', 'Pages']}>\r\n <Colorbar />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Contact Pop Over' description='Show the contact info.' stylesheets={['Epac', 'Pages']}>\r\n <ContactPopOver />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Breadcrumbs' description='This component displays the progress of the checkout experience.' stylesheets={['Epac', 'Pages']}>\r\n <Breadcrumbs/>\r\n </ComponentInfo>\r\n\r\n\r\n <h2>Containers</h2>\r\n <p>Containers are used to display related information.</p>\r\n\r\n\r\n <ComponentInfo name='Page' description='This component displays Page Container.' stylesheets={['Epac', 'Containers']} noflex={true}>\r\n <Page>\r\n <h1>Title 1</h1>\r\n <h2>Title 2</h2>\r\n <h3>Title 3</h3>\r\n </Page>\r\n </ComponentInfo>\r\n\r\n\r\n <ComponentInfo name='Card' description='This component displays a Card.' stylesheets={['Epac', 'Containers']}>\r\n <Card title='Title' subtitle='Sub Title' />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Expandable Card' description='This component displays an Expandable Card.' stylesheets={['Epac', 'Containers']}>\r\n <ExpandableCard title='Title'>\r\n <p>Here we go...</p>\r\n </ExpandableCard>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Toggle Container' description='This component displays a container that can be toggled.' stylesheets={['Epac', 'Containers']}>\r\n <ToggleContainer toggleText='A Toggle Text'>\r\n <p>Here we go...</p>\r\n </ToggleContainer>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Grid' description='This component displays a Grid with rows and columns.' stylesheets={['Epac', 'Containers']} noflex={true}> \r\n <Row>\r\n <Column width={4}>R1/C1</Column>\r\n <Column width={4}>R1/C2</Column>\r\n <Column width={4}>R1/C3</Column>\r\n <Column width={4}>R1/C4</Column>\r\n </Row>\r\n <Row>\r\n <Column width={4}>R2/C1</Column>\r\n <Column width={4}>R2/C2</Column>\r\n <Column width={4}>R2/C3</Column>\r\n <Column width={4}>R2/C4</Column>\r\n </Row>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Image Tile' description='This component displays a Image Tile.' stylesheets={['Epac', 'Containers']}>\r\n <TileContainer>\r\n <ImageTileCircle value='Lorem ipsum dolor sit amet, consectetur adipiscing elit' src='/images/product.png' />\r\n <ImageTileCircle value='Product 2' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 3' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 4' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 5' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 6' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 7' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 8' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 9' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n <ImageTileCircle value='Product 10' src='/images/product.png' onClick={() => { alert('Selected') }} />\r\n </TileContainer>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Button Tile' description='This component displays a Button Tile.' stylesheets={['Epac', 'Containers']}>\r\n <TileContainer>\r\n <ButtonTile text='Click' onClick={() => { alert('clicked') }}><div className='sample'><h3>Title</h3><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non consectetur lectus, at ullamcorper dolor. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam mi ligula, lacinia in luctus et, hendrerit ac lectus. Aenean at condimentum turpis. Maecenas ut convallis elit. Sed et finibus sem. Proin scelerisque efficitur nunc, in fermentum sapien feugiat et. Sed non sem eu urna congue malesuada quis quis massa. Sed sed felis eget nisi feugiat faucibus ac eu magna. Proin sit amet rhoncus lacus. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non consectetur lectus, at ullamcorper dolor. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam mi ligula, lacinia in luctus et, hendrerit ac lectus. Aenean at condimentum turpis. Maecenas ut convallis elit. Sed et finibus sem. Proin scelerisque efficitur nunc, in fermentum sapien feugiat et. Sed non sem eu urna congue malesuada quis quis massa. Sed sed felis eget nisi feugiat faucibus ac eu magna. Proin sit amet rhoncus lacus.</p></div></ButtonTile>\r\n <ButtonTile text='Click' onClick={() => { alert('clicked') }}><div className='sample'><h3>Title</h3><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non consectetur lectus, at ullamcorper dolor. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam mi ligula, lacinia in luctus et, hendrerit ac lectus. Aenean at condimentum turpis. Maecenas ut convallis elit. Sed et finibus sem. Proin scelerisque efficitur nunc, in fermentum sapien feugiat et. Sed non sem eu urna congue malesuada quis quis massa. Sed sed felis eget nisi feugiat faucibus ac eu magna. Proin sit amet rhoncus lacus.</p></div></ButtonTile>\r\n <ButtonTile text='Click' onClick={() => { alert('clicked') }}><div className='sample'><h3>Title</h3><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non consectetur lectus, at ullamcorper dolor. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam mi ligula, lacinia in luctus et, hendrerit ac lectus. Aenean at condimentum turpis. Maecenas ut convallis elit. Sed et finibus sem. Proin scelerisque efficitur nunc, in fermentum sapien feugiat et. Sed non sem eu urna congue malesuada quis quis massa. Sed sed felis eget nisi feugiat faucibus ac eu magna. Proin sit amet rhoncus lacus.</p></div></ButtonTile>\r\n <ButtonTile text='Click' onClick={() => { alert('clicked') }}><div className='sample'><h3>Title</h3><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non consectetur lectus, at ullamcorper dolor. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam mi ligula, lacinia in luctus et, hendrerit ac lectus. Aenean at condimentum turpis. Maecenas ut convallis elit. Sed et finibus sem. Proin scelerisque efficitur nunc, in fermentum sapien feugiat et. Sed non sem eu urna congue malesuada quis quis massa. Sed sed felis eget nisi feugiat faucibus ac eu magna. Proin sit amet rhoncus lacus.</p></div></ButtonTile>\r\n <ButtonTile text='Click' onClick={() => { alert('clicked') }}><div className='sample'><h3>Title</h3><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non consectetur lectus, at ullamcorper dolor. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam mi ligula, lacinia in luctus et, hendrerit ac lectus. Aenean at condimentum turpis. Maecenas ut convallis elit. Sed et finibus sem. Proin scelerisque efficitur nunc, in fermentum sapien feugiat et. Sed non sem eu urna congue malesuada quis quis massa. Sed sed felis eget nisi feugiat faucibus ac eu magna. Proin sit amet rhoncus lacus.</p></div></ButtonTile>\r\n </TileContainer>\r\n </ComponentInfo>\r\n\r\n \r\n <ComponentInfo name='Expandable Tab' description='' stylesheets={['Epac', 'Containers']}>\r\n <ExpandableTab title='Your Selections'><p>Very Nice Content</p></ExpandableTab>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Carousel' description='' stylesheets={['Epac', 'Containers, Animations']}>\r\n <Carousel>\r\n <div className='sample background-light-grey'>1</div>\r\n <div className='sample background-light-grey'>2</div>\r\n <div className='sample background-light-grey'>3</div>\r\n </Carousel>\r\n </ComponentInfo>\r\n\r\n\r\n\r\n\r\n\r\n <h2>Dialog Components</h2>\r\n <p>Dialog Components include Modal Popups and Confirmation elements.</p>\r\n\r\n <ComponentInfo name='Modal' description='This component displays a Modal.' stylesheets={['Epac', 'Dialogs']}>\r\n <button className='btn btn-primary' onClick={() => { this.setState({ showModal: true }) }}>Show Modal</button>\r\n <div className={this.state.showModal ? '' : 'hidden'}>\r\n <Modal onCloseClick={() => { this.setState({ showModal: false }) }}>\r\n <p>This is the content</p>\r\n </Modal>\r\n </div>\r\n </ComponentInfo>\r\n \r\n <ComponentInfo name='Confirmation' description='This component displays a Confirmation.' stylesheets={['Epac', 'Dialogs']}>\r\n <button className='btn btn-primary' onClick={() => { this.setState({ showConfirmation: true }) }}>Show Confirmation</button>\r\n <div className={this.state.showConfirmation ? '' : 'hidden'}>\r\n <Confirmation onCancelClick={() => { this.setState({ showConfirmation: false }) }} onSaveClick={() => { this.setState({ showConfirmation: false }) }}>\r\n <p>This is the content</p>\r\n </Confirmation>\r\n </div>\r\n </ComponentInfo>\r\n\r\n\r\n <ComponentInfo name='Back Splash' description='This component displays a Back Splash.' stylesheets={['Epac', 'Dialogs']}>\r\n <button className='btn btn-primary' onClick={() => { this.setState({ showBackSplash: true }) }}>Show Back Splash</button>\r\n <div className={this.state.showBackSplash ? '' : 'hidden'}>\r\n <BackSplash onClick={() => { this.setState({ showBackSplash: false }) }}>\r\n </BackSplash>\r\n </div>\r\n </ComponentInfo>\r\n\r\n\r\n <h2>Controls</h2>\r\n <p>Controls are used to capture the user input.</p>\r\n\r\n <ComponentInfo name='Textbox (Input Required)' description='This component displays a Textbox.' stylesheets={['Epac', 'Controls']}>\r\n <Textbox placeholder='Enter a number' type='number' regex='[0-9]*' required={true} requireValidInput={true} />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Textbox (Input Optional)' description='This component displays a Textbox.' stylesheets={['Epac', 'Controls']}>\r\n <Textbox placeholder='Enter text' />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Textbox (Readonly)' description='This component displays a Textbox.' stylesheets={['Epac', 'Controls']}>\r\n <Textbox placeholder='Enter text' readOnly={true} />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Searchbox' description='This component displays a Searchbox. Enter Key, click on search icon or delayed key press submits search term.' stylesheets={['Epac', 'Controls']}>\r\n <Searchbox delay={500} onSubmit={txt => { alert(txt); }} />\r\n </ComponentInfo>\r\n\r\n\r\n <ComponentInfo name='Dropdown (Input Required)' description='This component displays a Dropdown.' stylesheets={['Epac', 'Controls']}>\r\n <Dropdown required={true}>\r\n <option value={-1}>Select a color</option>\r\n <option value={1}>Red</option>\r\n <option value={2}>Blue</option>\r\n <option value={3}>Green</option> \r\n </Dropdown>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Dropdown (Input Optional)' description='This component displays a Dropdown.' stylesheets={['Epac', 'Controls']}>\r\n <Dropdown>\r\n <option value={-1}>Select a color</option>\r\n <option value={1}>Red</option>\r\n <option value={2}>Blue</option>\r\n <option value={3}>Green</option>\r\n </Dropdown>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Dropdown (Custom - Sample 1)' description='This component displays a Dropdown.' stylesheets={['Epac', 'Controls']}>\r\n <div className='quantitySelector'>\r\n <CustomDropdown>\r\n <div className='item' value={-1}>Select Quantity Range...</div>\r\n <div className='item' disabled={true}><div className='quantity'>Quantity</div><div className='unitPrice'>Unit Price</div></div>\r\n <div className='item' value={1}><div className='quantity'>10,000 - 19,999</div><div className='unitPrice'><Money currency='GBP' amount='0.145' /></div></div>\r\n <div className='item' value={2}><div className='quantity'>20,000 - 29,999</div><div className='unitPrice'><Money currency='GBP' amount='0.139' /></div></div>\r\n <div className='item' value={3}><div className='quantity'>30,000 - 39,999</div><div className='unitPrice'><Money currency='GBP' amount='0.127' /></div></div>\r\n <div className='item' value={4}><div className='quantity'>40,000 - 49,999</div><div className='unitPrice'><Money currency='GBP' amount='0.115' /></div></div>\r\n </CustomDropdown>\r\n </div>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Dropdown (Custom - Sample 2)' description='This component displays a Dropdown.' stylesheets={['Epac', 'Controls']}>\r\n <div className='unwindSelector'>\r\n <CustomDropdown required={true} value={4}>\r\n <div value={1}><div className='imageContainer'><img src='/images/unwind_1.png' /></div><span>Option 1</span></div>\r\n <div value={2}><div className='imageContainer'><img src='/images/unwind_2.png' /></div><span>Option 2</span></div>\r\n <div value={3}><div className='imageContainer'><img src='/images/unwind_3.png' /></div><span>Option 3</span></div>\r\n <div value={4}><div className='imageContainer'><img src='/images/unwind_4.png' /></div><span>Option 4</span></div>\r\n <div value={5}><div className='imageContainer'><img src='/images/unwind_5.png' /></div><span>Option 5</span></div>\r\n <div value={6}><div className='imageContainer'><img src='/images/unwind_6.png' /></div><span>Option 6</span></div>\r\n <div value={7}><div className='imageContainer'><img src='/images/unwind_7.png' /></div><span>Option 7</span></div>\r\n <div value={8}><div className='imageContainer'><img src='/images/unwind_8.png' /></div><span>Option 8</span></div>\r\n </CustomDropdown>\r\n </div>\r\n </ComponentInfo>\r\n\r\n\r\n\r\n\r\n <ComponentInfo name='Checkbox (Required)' description='This component displays a Checkbox.' stylesheets={['Epac', 'Controls']}>\r\n <Checkbox id='cbx' required={true}>My opinion counts</Checkbox>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Checkbox (Optional)' description='This component displays a Checkbox.' stylesheets={['Epac', 'Controls']}>\r\n <Checkbox id='cbx2'>My opinion counts</Checkbox>\r\n </ComponentInfo>\r\n\r\n\r\n <ComponentInfo name='Radio Button' description='This component displays a Radio Button.' stylesheets={['Epac', 'Controls']}>\r\n <RadioButton name='group1' value={true}>Option 1</RadioButton>\r\n <RadioButton name='group1'>Option 2</RadioButton>\r\n </ComponentInfo>\r\n\r\n\r\n <h2>Other Components</h2>\r\n <p>Collection of components to ensure consistent user experience</p>\r\n\r\n <ComponentInfo name='Section Title' description='This component displays a Section Title.' stylesheets={['Epac', 'Components']}>\r\n <SectionTitle>My Title</SectionTitle>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Section Title (with help)' description='This component displays a Section Title with help.' stylesheets={['Epac', 'Components']}>\r\n <SectionTitle description='My help content' imageUrl='https://epacflexibles.com/wp-content/uploads/2020/02/Closures.png'>My Title</SectionTitle>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Section Label' description='This component displays a Section Label.' stylesheets={['Epac', 'Components']}>\r\n <SectionLabel description='My help content' />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Context Help' description='This component displays a Help.' stylesheets={['Epac', 'Components']}>\r\n <ContextHelp title='My Title' description='Some Help Content' />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Money' description='This component displays Money.' stylesheets={['Epac', 'Components']} noflex={true}>\r\n <Money currency='USD' amount='123.45' />\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Edit Link' description='This component displays an Edit Link.' stylesheets={['Epac', 'Components']}>\r\n <EditLink>Edit</EditLink>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Download Link' description='This component displays an Download Link.' stylesheets={['Epac', 'Components']}>\r\n <DownloadLink>Download</DownloadLink>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Upload Link' description='This component displays an Upload Link.' stylesheets={['Epac', 'Components']}>\r\n <UploadLink>Upload</UploadLink>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Message Link' description='This component displays a Message Link.' stylesheets={['Epac', 'Components']}>\r\n <MessageLink>Click or hover over the icon</MessageLink>\r\n </ComponentInfo>\r\n\r\n <ComponentInfo name='Validation' description='Textbox including error message.' stylesheets={['Epac', 'Controls']}>\r\n <InputValidation requiredText=\"Input for this Field is required\">\r\n <Textbox id='txt1' required={true} regex={'[0-9]*'} />\r\n </InputValidation>\r\n </ComponentInfo>\r\n \r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\nexport class ComponentInfo extends Component {\r\n static displayName = ComponentInfo.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n html: null\r\n }; \r\n }\r\n\r\n componentDidMount() {\r\n let html = document.getElementById(this.props.name).innerHTML; \r\n this.setState({\r\n html: html\r\n });\r\n }\r\n\r\n \r\n render() {\r\n return (\r\n <div className={'componentInfo'}>\r\n <h3>{this.props.name}</h3>\r\n <p>{this.props.description}</p>\r\n {this.props.stylesheets &&\r\n <div className='stylesheets'>\r\n <span>Required Stylesheets: </span>\r\n {this.props.stylesheets.map((ss, idx) => {\r\n return (\r\n <a key={idx} target='_blank' href={'/styles/'+ss + '.css'}>{idx === 0 ? ss : ', ' + ss}</a>\r\n )\r\n })}\r\n </div>\r\n }\r\n <div id={this.props.name} className={this.props.noflex ? 'border block' : 'border flex'}>\r\n {this.props.children} \r\n </div>\r\n\r\n <ToggleContainer toggleText='Show Html'>\r\n <div className='html'>\r\n {this.state.html}\r\n </div>\r\n </ToggleContainer>\r\n\r\n </div>\r\n );\r\n }\r\n}","import React, { useState, useEffect, useRef } from 'react';\r\nimport { Card } from '../components/Containers';\r\nimport { Colorbar, ContactPopOver, Breadcrumbs, Header, Title } from '../components/Pages';\r\n\r\nimport './IconsPage.css';\r\n\r\nexport const IconsPage = ({ }) => {\r\n Breadcrumbs.instance.setActiveStep(0);\r\n\r\n return (\r\n <div className='iconsPage'>\r\n <h1>Icons</h1>\r\n\r\n <Card title='Material - Finish Type'>\r\n <IconDescription root='/images/icons/material' name='finish_type_1.png' />\r\n <IconDescription root='/images/icons/material' name='finish_type_2.png' />\r\n <IconDescription root='/images/icons/material' name='finish_type_3.png' />\r\n </Card>\r\n\r\n <Card title='Material - Sustainability'>\r\n <IconDescription root='/images/icons/material' name='sustainability_1.png' />\r\n <IconDescription root='/images/icons/material' name='sustainability_2.png' />\r\n <IconDescription root='/images/icons/material' name='sustainability_3.png' />\r\n <IconDescription root='/images/icons/material' name='sustainability_4.png' />\r\n </Card>\r\n\r\n <Card title='Material - Transparency'>\r\n <IconDescription root='/images/icons/material' name='transparency_1.png' />\r\n <IconDescription root='/images/icons/material' name='transparency_2.png' />\r\n </Card>\r\n\r\n </div>\r\n )\r\n};\r\n\r\n\r\n\r\nexport const IconDescription = ({ root, name }) => {\r\n\r\n return (\r\n <div className='iconDescription'>\r\n <a href={`${root}/${name}`} target='_blank'><img src={`${root}/${name}`} /></a>\r\n <p>{name}</p>\r\n </div>\r\n )\r\n};\r\n\r\n\r\n","import React, { Component } from 'react';\r\n\r\nimport { Breadcrumbs } from '../components/Pages';\r\nimport { Textbox, Dropdown, Checkbox, InputValidation, ValidationOrchestrator } from '../components/Controls';\r\nimport { Column, Row, Card } from '../components/Containers';\r\nimport { SectionTitle, Alert } from '../components/Components';\r\n\r\n\r\nexport class ValidationDemoPage extends Component {\r\n static displayName = ValidationDemoPage.name;\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n hasErrors: false\r\n };\r\n\r\n this.onValidating = this.onValidating.bind(this);\r\n this.onNextClick = this.onNextClick.bind(this);\r\n Breadcrumbs.instance.setActiveStep(2);\r\n this.validationOrchestrator = new ValidationOrchestrator(this.onValidating);\r\n }\r\n\r\n onNextClick() {\r\n var valid = this.validationOrchestrator.validate();\r\n this.setState({ hasErrors: !valid });\r\n if (!valid) {\r\n var id = this.validationOrchestrator.getInvalidFieldName();\r\n var element = document.getElementById(id);\r\n\r\n if (element) { \r\n element.focus();\r\n let y = element.getBoundingClientRect().top + window.pageYOffset - 180;\r\n window.scrollTo({ top: y, behavior: 'smooth' });\r\n }\r\n }\r\n else {\r\n alert('The inputs are valid. Can now navigate to next page');\r\n document.location = '/';\r\n }\r\n }\r\n\r\n onValidating(valid) {\r\n this.setState({ hasErrors: !valid });\r\n }\r\n\r\n render() {\r\n return (\r\n <div>\r\n <h2>Input Validation Demo</h2>\r\n\r\n <Alert type='info'>This screen demonstrates the validation mechanism. For this purpose the used input elements and the layout do not align with the Figma Screens.</Alert>\r\n\r\n <ul>\r\n <li>Red Border: Invalid input fields (css .control.error)</li>\r\n <li>Green Border: Valid input fields (css .control.valid)</li>\r\n <li>Blue Border: The Input field that has the focus (css .control:focus)</li>\r\n <li>On page load all invalid input fields are displayed with a red border</li>\r\n <li>Optional fields are displayed with a green border</li>\r\n <li>By pressing the \"Next\" button error messages (css .error-message) are displayed below all invalid input fields. The view port will be scrolled to the first invalid field of the screen. The input focus will be set to this element. A notification message (css .alert .error) is displayed above the next button</li>\r\n <li>A next button click will only navigate to the next screen when all input fields are valid</li>\r\n <li>Please review the <a href='/overview'>Components Overview</a> for more details on styles</li>\r\n </ul>\r\n\r\n <p>Please click the next button below and complete the form in order to review the input validation.</p>\r\n\r\n <Card title='Shipping Address' subtitle='This section can be edited later'>\r\n <Row>\r\n <Column>\r\n <SectionTitle>Country</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please select a country\">\r\n <Dropdown id='country' required={true}>\r\n <option value={-1}>Select Country</option>\r\n <option value={1}>United Kingdom</option>\r\n <option value={2}>United States</option>\r\n <option value={3}>France</option>\r\n </Dropdown>\r\n </InputValidation>\r\n </Column>\r\n <Column>\r\n <SectionTitle>City</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please enter a city\">\r\n <Textbox id='city' required={true} />\r\n </InputValidation>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>Address Line 1</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please enter an address\">\r\n <Textbox id='address1' required={true} />\r\n </InputValidation>\r\n </Column>\r\n <Column>\r\n <SectionTitle>Postal Code</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please enter a postal code\">\r\n <Textbox id='postalCode' required={true} />\r\n </InputValidation>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>Address Line 2</SectionTitle>\r\n <Textbox id='address2' />\r\n </Column>\r\n <Column>\r\n <SectionTitle>State</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please select a state\">\r\n <Dropdown id='state' required={true}>\r\n <option value={-1}>Select State</option>\r\n <option value={1}>CA</option>\r\n <option value={2}>MS</option>\r\n <option value={3}>Al</option>\r\n </Dropdown>\r\n </InputValidation>\r\n </Column>\r\n </Row>\r\n\r\n <Row>\r\n <Column>\r\n <SectionTitle>Name</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please enter your first and last name\">\r\n <Textbox id='name' required={true} />\r\n </InputValidation>\r\n </Column>\r\n <Column>\r\n <SectionTitle>Some Checkbox</SectionTitle>\r\n <InputValidation validationOrchestrator={this.validationOrchestrator} requiredText=\"Please check the box\">\r\n <Checkbox id='termsandconditions' required={true}>Check to agree to ePac Terms & Conditions</Checkbox>\r\n </InputValidation>\r\n\r\n </Column>\r\n </Row>\r\n\r\n\r\n </Card>\r\n\r\n {this.state.hasErrors &&\r\n <Alert type='error'>There is required info missing.</Alert>\r\n }\r\n <button className='btn btn-secondary pull-right' onClick={this.onNextClick}>Next</button>\r\n\r\n </div>\r\n );\r\n }\r\n}\r\n\r\n\r\n\r\n\r\n","import React, { Component } from 'react';\r\nimport { Route } from 'react-router';\r\nimport { Layout } from './pages/Layout';\r\nimport { ProductSpecsPage } from './pages/ProductSpecsPage';\r\nimport { QuantitiesPage } from './pages/QuantitiesPage';\r\nimport { OrderReviewPage } from './pages/OrderReviewPage';\r\nimport { PaymentPage } from './pages/PaymentPage';\r\nimport { OrderConfirmationPage } from './pages/OrderConfirmationPage';\r\nimport { ArtworkPage } from './pages/ArtworkPage';\r\nimport { Home } from './pages/Home';\r\nimport { Overview } from './pages/Overview';\r\nimport { IconsPage } from './pages/IconsPage';\r\nimport { ValidationDemoPage } from './pages/ValidationDemoPage';\r\n\r\nexport default class App extends Component {\r\n static displayName = App.name;\r\n\r\n render () {\r\n return (\r\n <Layout>\r\n <Route exact path='/' component={Home} />\r\n <Route exact path='/overview' component={Overview} />\r\n <Route exact path='/icons' component={IconsPage} />\r\n <Route exact path='/validation' component={ValidationDemoPage} />\r\n <Route exact path='/checkout' component={ProductSpecsPage} />\r\n <Route exact path='/quantities' component={QuantitiesPage} />\r\n <Route exact path='/review' component={OrderReviewPage} />\r\n <Route exact path='/payment' component={PaymentPage} />\r\n <Route exact path='/confirmation' component={OrderConfirmationPage} />\r\n <Route exact path='/artwork' component={ArtworkPage} /> \r\n </Layout>\r\n );\r\n }\r\n}\r\n","// In production, we register a service worker to serve assets from local cache.\r\n\r\n// This lets the app load faster on subsequent visits in production, and gives\r\n// it offline capabilities. However, it also means that developers (and users)\r\n// will only see deployed updates on the \"N+1\" visit to a page, since previously\r\n// cached resources are updated in the background.\r\n\r\n// To learn more about the benefits of this model, read https://goo.gl/KwvDNy.\r\n// This link also includes instructions on opting out of this behavior.\r\n\r\nconst isLocalhost = Boolean(\r\n window.location.hostname === 'localhost' ||\r\n // [::1] is the IPv6 localhost address.\r\n window.location.hostname === '[::1]' ||\r\n // 127.0.0.1/8 is considered localhost for IPv4.\r\n window.location.hostname.match(\r\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\r\n )\r\n);\r\n\r\nexport default function register () {\r\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\r\n // The URL constructor is available in all browsers that support SW.\r\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location);\r\n if (publicUrl.origin !== window.location.origin) {\r\n // Our service worker won't work if PUBLIC_URL is on a different origin\r\n // from what our page is served on. This might happen if a CDN is used to\r\n // serve assets; see https://github.com/facebookincubator/create-react-app/issues/2374\r\n return;\r\n }\r\n\r\n window.addEventListener('load', () => {\r\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\r\n\r\n if (isLocalhost) {\r\n // This is running on localhost. Lets check if a service worker still exists or not.\r\n checkValidServiceWorker(swUrl);\r\n } else {\r\n // Is not local host. Just register service worker\r\n registerValidSW(swUrl);\r\n }\r\n });\r\n }\r\n}\r\n\r\nfunction registerValidSW (swUrl) {\r\n navigator.serviceWorker\r\n .register(swUrl)\r\n .then(registration => {\r\n registration.onupdatefound = () => {\r\n const installingWorker = registration.installing;\r\n installingWorker.onstatechange = () => {\r\n if (installingWorker.state === 'installed') {\r\n if (navigator.serviceWorker.controller) {\r\n // At this point, the old content will have been purged and\r\n // the fresh content will have been added to the cache.\r\n // It's the perfect time to display a \"New content is\r\n // available; please refresh.\" message in your web app.\r\n console.log('New content is available; please refresh.');\r\n } else {\r\n // At this point, everything has been precached.\r\n // It's the perfect time to display a\r\n // \"Content is cached for offline use.\" message.\r\n console.log('Content is cached for offline use.');\r\n }\r\n }\r\n };\r\n };\r\n })\r\n .catch(error => {\r\n console.error('Error during service worker registration:', error);\r\n });\r\n}\r\n\r\nfunction checkValidServiceWorker (swUrl) {\r\n // Check if the service worker can be found. If it can't reload the page.\r\n fetch(swUrl)\r\n .then(response => {\r\n // Ensure service worker exists, and that we really are getting a JS file.\r\n if (\r\n response.status === 404 ||\r\n response.headers.get('content-type').indexOf('javascript') === -1\r\n ) {\r\n // No service worker found. Probably a different app. Reload the page.\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister().then(() => {\r\n window.location.reload();\r\n });\r\n });\r\n } else {\r\n // Service worker found. Proceed as normal.\r\n registerValidSW(swUrl);\r\n }\r\n })\r\n .catch(() => {\r\n console.log(\r\n 'No internet connection found. App is running in offline mode.'\r\n );\r\n });\r\n}\r\n\r\nexport function unregister () {\r\n if ('serviceWorker' in navigator) {\r\n navigator.serviceWorker.ready.then(registration => {\r\n registration.unregister();\r\n });\r\n }\r\n}\r\n","/*import 'bootstrap/dist/css/bootstrap.css';*/\r\nimport React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport { BrowserRouter } from 'react-router-dom';\r\nimport App from './App';\r\nimport registerServiceWorker from './registerServiceWorker';\r\n\r\nconst baseUrl = document.getElementsByTagName('base')[0].getAttribute('href');\r\nconst rootElement = document.getElementById('root');\r\n\r\nReactDOM.render(\r\n <BrowserRouter basename={baseUrl}>\r\n <App />\r\n </BrowserRouter>,\r\n rootElement);\r\n\r\nregisterServiceWorker();\r\n\r\n"],"sourceRoot":""}