{"version":3,"file":"Dashboard.5c583492.js","sources":["../../../node_modules/react-parallax/lib/index.js","../../../app/frontend/components/Paratwo.jsx","../../../app/frontend/pages/Dashboard.jsx"],"sourcesContent":["!function webpackUniversalModuleDefinition(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t(require(\"react\")):\"function\"==typeof define&&define.amd?define(\"react-parallax\",[\"react\"],t):\"object\"==typeof exports?exports[\"react-parallax\"]=t(require(\"react\")):e[\"react-parallax\"]=t(e.react)}(\"undefined\"!=typeof self?self:this,(function(e){return function(e){var t={};function __webpack_require__(n){if(t[n])return t[n].exports;var r=t[n]={i:n,l:!1,exports:{}};return e[n].call(r.exports,r,r.exports,__webpack_require__),r.l=!0,r.exports}return __webpack_require__.m=e,__webpack_require__.c=t,__webpack_require__.d=function(e,t,n){__webpack_require__.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},__webpack_require__.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})},__webpack_require__.t=function(e,t){if(1&t&&(e=__webpack_require__(e)),8&t)return e;if(4&t&&\"object\"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(__webpack_require__.r(n),Object.defineProperty(n,\"default\",{enumerable:!0,value:e}),2&t&&\"string\"!=typeof e)for(var r in e)__webpack_require__.d(n,r,function(t){return e[t]}.bind(null,r));return n},__webpack_require__.n=function(e){var t=e&&e.__esModule?function getDefault(){return e.default}:function getModuleExports(){return e};return __webpack_require__.d(t,\"a\",t),t},__webpack_require__.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},__webpack_require__.p=\"\",__webpack_require__(__webpack_require__.s=3)}([function(t,n){t.exports=e},function(e,t,n){\"use strict\";function _typeof(e){return(_typeof=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function _typeof(e){return typeof e}:function _typeof(e){return e&&\"function\"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?\"symbol\":typeof e})(e)}function _classCallCheck(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function _inherits(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Super expression must either be null or a function\");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&_setPrototypeOf(e,t)}function _setPrototypeOf(e,t){return(_setPrototypeOf=Object.setPrototypeOf||function _setPrototypeOf(e,t){return e.__proto__=t,e})(e,t)}function _createSuper(e){var t=function _isNativeReflectConstruct(){if(\"undefined\"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if(\"function\"==typeof Proxy)return!0;try{return Date.prototype.toString.call(Reflect.construct(Date,[],(function(){}))),!0}catch(e){return!1}}();return function _createSuperInternal(){var n,r=_getPrototypeOf(e);if(t){var o=_getPrototypeOf(this).constructor;n=Reflect.construct(r,arguments,o)}else n=r.apply(this,arguments);return _possibleConstructorReturn(this,n)}}function _possibleConstructorReturn(e,t){return!t||\"object\"!==_typeof(t)&&\"function\"!=typeof t?function _assertThisInitialized(e){if(void 0===e)throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");return e}(e):t}function _getPrototypeOf(e){return(_getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf:function _getPrototypeOf(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,\"__esModule\",{value:!0}),t.Background=t.Parallax=void 0;var o=r(n(0)),i=function(e){_inherits(Parallax,e);var t=_createSuper(Parallax);function Parallax(){return _classCallCheck(this,Parallax),t.apply(this,arguments)}return Parallax}(o.default.Component);t.Parallax=i;var a=function(e){_inherits(Background,e);var t=_createSuper(Background);function Background(){return _classCallCheck(this,Background),t.apply(this,arguments)}return Background}(o.default.Component);t.Background=a},function(e,t,n){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0}),t.canUseDOM=t.getNodeHeight=t.isScrolledIntoView=t.getWindowHeight=void 0,t.getWindowHeight=function(e){if(!e)return 0;var t=window,n=document,r=n.documentElement,o=n.getElementsByTagName(\"body\")[0];return t.innerHeight||r.clientHeight||o.clientHeight},t.isScrolledIntoView=function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2?arguments[2]:void 0;if(!r)return!1;var o=e.getBoundingClientRect().top-n,i=e.getBoundingClientRect().bottom+n;return o<=t.getWindowHeight(r)&&i>=0},t.getNodeHeight=function(e,n){return e?n&&\"clientHeight\"in n?n.clientHeight:t.getWindowHeight(e):0},t.canUseDOM=function(){return!(\"undefined\"==typeof window||!window.document||!window.document.createElement)}},function(e,t,n){\"use strict\";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,\"__esModule\",{value:!0}),t.Background=t.Parallax=void 0;var o=r(n(4));t.Parallax=o.default;var i=r(n(7));t.Background=i.default},function(e,t,n){\"use strict\";function _typeof(e){return(_typeof=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function _typeof(e){return typeof e}:function _typeof(e){return e&&\"function\"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?\"symbol\":typeof e})(e)}function _defineProperties(e,t){for(var n=0;n=10&&c.isScrolledIntoView(n.node,100,n.canUseDOM)&&(window.requestAnimationFrame(n.updatePosition),n.timestamp=e)}},n.onContentMount=function(e){n.content=e},n.updatePosition=function(){if(n.content){var e=!1;n.contentHeight=n.content.getBoundingClientRect().height,n.contentWidth=n.node.getBoundingClientRect().width,n.img&&n.img.naturalWidth/n.img.naturalHeight0;r&&n.setImagePosition(t,e),o&&n.setBackgroundPosition(t),r||o||n.setState({percentage:t})}},n.state={bgImage:e.bgImage,bgImageSrcSet:e.bgImageSrcSet,bgImageSizes:e.bgImageSizes,imgStyle:s,bgStyle:Object.assign(Object.assign({},s),e.bgStyle),percentage:0,splitChildren:a.getSplitChildren(e)},n.canUseDOM=c.canUseDOM(),n.node=null,n.content=null,n.bgImageLoaded=!1,n.bgImageRef=void 0,n.parent=e.parent,n.parentHeight=c.getNodeHeight(n.canUseDOM,n.parent),n.timestamp=Date.now(),n.isDynamicBlur=a.getHasDynamicBlur(e.blur),n}return function _createClass(e,t,n){return t&&_defineProperties(e.prototype,t),n&&_defineProperties(e,n),e}(Parallax,[{key:\"componentDidMount\",value:function componentDidMount(){var e=this.props.parent,t=this.state,n=t.bgImage,r=t.bgImageSrcSet,o=t.bgImageSizes;this.parent=e||document,this.addListeners(),n?this.loadImage(n,r,o):this.updatePosition()}},{key:\"componentDidUpdate\",value:function componentDidUpdate(e){var t=this.props,n=t.parent,r=t.bgImage,o=t.bgImageSrcSet,i=t.bgImageSizes,a=this.state.bgImage;e.parent!==n&&(this.removeListeners(this.parent),this.parent=n,n&&this.addListeners()),this.parentHeight=c.getNodeHeight(this.canUseDOM,this.parent),a!==r&&this.loadImage(r,o,i)}},{key:\"componentWillUnmount\",value:function componentWillUnmount(){this.removeListeners(this.parent),this.releaseImage()}},{key:\"setBackgroundPosition\",value:function setBackgroundPosition(e){var t=this.props,n=t.disabled,r=t.strength,o=Object.assign({},this.state.bgStyle);if(!n){var i=\"translate3d(-50%, \".concat((r<0?r:0)-r*e,\"px, 0)\");o.WebkitTransform=i,o.transform=i}this.setState({bgStyle:o,percentage:e})}},{key:\"setImagePosition\",value:function setImagePosition(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],n=this.props,r=n.disabled,o=n.strength,i=n.blur,c=t?\"auto\":\"\".concat(this.getImageHeight(),\"px\"),u=t?\"\".concat(this.contentWidth,\"px\"):\"auto\",s=Object.assign(Object.assign({},this.state.imgStyle),{height:c,width:u});if(!r){var l=o<0,f=(l?o:0)-o*e,p=\"translate3d(-50%, \".concat(f,\"px, 0)\"),d=\"none\";i&&(d=\"blur(\".concat(a.getBlurValue(this.isDynamicBlur,i,e),\"px)\")),s.WebkitTransform=p,s.transform=p,s.WebkitFilter=d,s.filter=d}this.setState({imgStyle:s,percentage:e})}},{key:\"getImageHeight\",value:function getImageHeight(){var e=this.props.strength,t=(e<0?2.5:1)*Math.abs(e);return Math.floor(this.contentHeight+t)}},{key:\"loadImage\",value:function loadImage(e,t,n){var r=this;this.releaseImage(),this.bgImageRef=new Image,this.bgImageRef.onload=function(o){r.setState({bgImage:e,bgImageSrcSet:t,bgImageSizes:n},(function(){return r.updatePosition()})),r.props.onLoad&&r.props.onLoad(o)},this.bgImageRef.onerror=this.bgImageRef.onload,this.bgImageRef.src=e,this.bgImageRef.srcset=t||\"\",this.bgImageRef.sizes=n||\"\"}},{key:\"releaseImage\",value:function releaseImage(){this.bgImageRef&&(this.bgImageRef.onload=null,this.bgImageRef.onerror=null,delete this.bgImageRef)}},{key:\"addListeners\",value:function addListeners(){this.canUseDOM&&this.parent&&(this.parent.addEventListener(\"scroll\",this.onScroll,!1),window.addEventListener(\"resize\",this.onWindowResize,!1),window.addEventListener(\"load\",this.onWindowLoad,!1))}},{key:\"removeListeners\",value:function removeListeners(e){this.canUseDOM&&(e&&e.removeEventListener(\"scroll\",this.onScroll,!1),window.removeEventListener(\"resize\",this.onWindowResize,!1),window.removeEventListener(\"load\",this.onWindowLoad,!1))}},{key:\"render\",value:function render(){var e=this,t=this.props,n=t.className,r=t.style,i=t.bgClassName,a=t.contentClassName,c=t.bgImageAlt,s=t.renderLayer,l=t.bgImageStyle,f=t.lazy,p=this.state,d=p.bgImage,g=p.bgImageSrcSet,_=p.bgImageSizes,y=p.percentage,h=p.imgStyle,b=p.bgStyle,m=p.splitChildren;return o.default.createElement(\"div\",{className:\"react-parallax \".concat(n),style:Object.assign({position:\"relative\",overflow:\"hidden\"},r),ref:function ref(t){e.node=t}},d?o.default.createElement(\"img\",{className:i,src:d,srcSet:g,sizes:_,ref:function ref(t){e.img=t},alt:c,style:Object.assign(Object.assign({},h),l),loading:f?\"lazy\":\"eager\"}):null,s?s(-(y-1)):null,m.bgChildren.length>0?o.default.createElement(\"div\",{className:\"react-parallax-background-children\",ref:function ref(t){e.bg=t},style:b},m.bgChildren):null,o.default.createElement(u.default,{onMount:this.onContentMount,className:a},m.children))}}],[{key:\"getDerivedStateFromProps\",value:function getDerivedStateFromProps(e){return{splitChildren:a.getSplitChildren(e)}}}]),Parallax}(i.Parallax);l.defaultProps={bgClassName:\"react-parallax-bgimage\",bgImageAlt:\"\",className:\"\",contentClassName:\"\",disabled:!1,strength:100},t.default=l},function(e,t,n){\"use strict\";function _typeof(e){return(_typeof=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function _typeof(e){return typeof e}:function _typeof(e){return e&&\"function\"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?\"symbol\":typeof e})(e)}Object.defineProperty(t,\"__esModule\",{value:!0}),t.setBlur=t.getBlurValue=t.getHasDynamicBlur=t.getSplitChildren=t.getRelativePosition=t.getPercentage=void 0;var r=n(0),o=n(2);t.getPercentage=function(e,t,n){return(n-e)/(t-e)||0},t.getRelativePosition=function(e,n){if(!n)return 0;var r=e.getBoundingClientRect(),i=r.top,a=r.height,c=o.getNodeHeight(n),u=a>c?a:c,s=Math.round(i>u?u:i);return t.getPercentage(0,u,s)},t.getSplitChildren=function(e){var t=[],n=r.Children.toArray(e.children);return n.forEach((function(e,r){var o=e;o.type&&o.type.isParallaxBackground&&(t=t.concat(n.splice(r,1)))})),{bgChildren:t,children:n}},t.getHasDynamicBlur=function(e){return\"object\"===_typeof(e)&&void 0!==e.min&&void 0!==e.max},t.getBlurValue=function(e,t,n){return e?t.min+(1-n)*t.max:t},t.setBlur=function(e,t){e.style.webkitFilter=\"blur(\".concat(t,\"px)\"),e.style.filter=\"blur(\".concat(t,\"px)\")}},function(e,t,n){\"use strict\";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,\"__esModule\",{value:!0});var o=r(n(0));t.default=function ParallaxChildren(e){var t=e.children,n=e.onMount,r=e.className;return o.default.createElement(\"div\",{ref:function ref(e){return n(e)},className:r||\"react-parallax-content\",style:{position:\"relative\"}},t)}},function(e,t,n){\"use strict\";function _typeof(e){return(_typeof=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function _typeof(e){return typeof e}:function _typeof(e){return e&&\"function\"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?\"symbol\":typeof e})(e)}function _classCallCheck(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function _defineProperties(e,t){for(var n=0;n {\n // const height = setHeightOfTheImageDynamically(1000, 1500)\n // console.log(\"height\", height);\n // console.log('resized to: ', window.innerWidth, 'x', window.innerHeight)\n\n const defaulHeight = 780;\n // }, []);\n\n const setHeightDependingOnTheScreenSize = () => {\n const width = window.innerWidth;\n\n let heighSetter = defaulHeight;\n if (width < 500) {\n heighSetter = 275;\n } else if (width < 700 && width > 500) {\n heighSetter = 300;\n } else if (width < 900 && width > 700) {\n heighSetter = 500;\n } else {\n heighSetter = defaulHeight;\n }\n return heighSetter;\n // console.log(\"sswidth\", width);\n // // wirte a case statement to set the height of the image depending on the screen size\n // switch (width) {\n\n // case width < 500:\n // return 250;\n // /// case between 500 and 800\n // case width > 500 && width < 800:\n // return 350;\n // // case between 800 and 1200\n // case width > 800 && width < 1200:\n // return 450;\n // // case between 1200 and 1500\n // case width > 1200 && width < 1500:\n // return 550;\n // // antyhing above 1500\n // case width > 1500:\n // return 650;\n // default:\n // width =\n // return width > 600 ? 650 : 350;\n\n // }\n };\n\n const [dimensions, setDimensions] = React.useState({\n height: window.innerHeight,\n width: window.innerWidth,\n maxHeight: setHeightDependingOnTheScreenSize(),\n });\n\n React.useEffect(() => {\n function handleResize() {\n let maxHeight = 500;\n if (window.innerWidth < 500) {\n maxHeight = 250;\n } else if (window.innerWidth < 800) {\n maxHeight = 350;\n } else if (window.innerWidth < 1200) {\n maxHeight = 450;\n } else if (window.innerWidth < 1500) {\n maxHeight = 550;\n } else {\n maxHeight = 650;\n }\n\n setDimensions({\n height: window.innerHeight,\n width: window.innerWidth,\n maxHeight: maxHeight,\n });\n }\n\n window.addEventListener(\"resize\", handleResize);\n }, []);\n\n const setHeightOfTheImageDynamically = (imageHeight, imageWidth) => {\n // set height of the image dynamically depending on the screen size\n // aspect ration of the image\n const aspectRatio = imageHeight / imageWidth;\n const width = window.innerWidth;\n const height = width * aspectRatio;\n //console.log(\"height\", height);\n return height;\n };\n\n const createWindowBrakePoints = (width) => {\n // if width is 500 or less - return 250\n //if width is between 501 and 800 - return 450\n // if width is between 801 and 1200 - return 550\n // if width is over 1201 - return 600\n // create a function to get the above return value to a given width\n\n // wite a case statement to set the height of the image depending on the screen size\n switch (width) {\n //f width is 500 or less - return 250\n\n case width < 300:\n return 300;\n case width > 300 && width < 500:\n return 400;\n //if width is between 501 and 800 - return 450\n case width > 500 && width < 800:\n return 550;\n // if width is between 801 and 1200 - return 550\n case width > 800 && width < 1200:\n return 650;\n //if width is over 1201 - return 600\n case width > 1200:\n return 700;\n default:\n return 700;\n }\n };\n\n return (\n
\n \n
\n
\n {\" \"}\n Hello, I am a good.bike and I like you. I am free from fuel costs,\n bad emissions and stress. Please give me a chance and take me with\n you. I guarantee to be good to you. Thank you.\n
\n
\n \n

| | |

\n \n
\n
Good bike wheel testing
\n
\n \n\n

| | |

\n \n
\n
Good bike painting
\n
\n \n
\n );\n}\n","import React, { useState, Fragment } from \"react\";\nimport NavSection from \"../components/NavSection\";\nimport Footer from \"../components/Footer\";\n\nimport Paratwo from \"../components/Paratwo\";\nimport { InertiaLink, Link } from \"@inertiajs/inertia-react\";\nimport { Button, Modal, Dropdown, Drawer } from \"react-daisyui\";\nimport { Parallax } from \"react-parallax\";\n\nexport default function Dashboard({ name }) {\n const [isOpen, setIsOpen] = useState(false);\n\n const [enabled, setEnabled] = useState(false);\n\n function closeModal() {\n setIsOpen(false);\n }\n\n function openModal() {\n setIsOpen(true);\n }\n\n const toggleShowModal = () => {\n setShowModal(!showModal);\n };\n\n const features = [\n {\n name: \"Frame\",\n description:\n \"Custom designed Chromoly 4130 (Cr-Mo) frame and fork Size medium - mountain bicycle size (height of the seatpost tube is 47cm/ 18 inches). Bikes geometry and strong chromoly frame would suite riders who are 5' 2 to 6' 2 tall.\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/city-bike.svg\",\n },\n {\n name: \"Brakes\",\n description:\n \"Shimano Hydraulic disc brakes, yes Shimano and is quite reliable, responsive and durable\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/brake-lever.svg\",\n },\n {\n name: \"Gears\",\n description: \"Shimano 8 speed gear which are very reliable and well made\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/cassette.svg\",\n },\n {\n name: \"Finish\",\n description: \"Matte black\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/step-through-two.svg\",\n },\n {\n name: \"Wheel\",\n description: \"700C alloy double wall wheels and quick release skewers\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/wheel.svg\",\n },\n {\n name: \"Hubs\",\n description: \"Shimano hubs are strong\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/bicycle-hub.svg\",\n },\n {\n name: \"Warranty\",\n description: \"1 year warranty on parts 2 1/2 years warranty on the frame\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/thank-you.svg\",\n },\n {\n name: \"Parts\",\n description: \"Alloy parts: seatpost, handlebar, stem and pedals\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/pedal.svg\",\n },\n {\n name: \"Accessories\",\n description: \"Mudguards, kickstand, bell and reflectors\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/mudguard.svg\",\n },\n {\n name: \"Mounts\",\n description: \"This bicycle comes with 12 mounts.\",\n svgImage: \"https://dv1a0vdyiklze.cloudfront.net/frame-mounts.svg\",\n },\n ];\n\n return (\n <>\n \n\n
\n \n
\n\n
\n
\n

good.bike is the latest bicycle model from i am free bicycles

\n

\n Please tell me that you like a simple friendly good.bike and you like\n to take me everywhere with you :-)\n

\n\n

\n Secret plan is to be at your service to offer very very good quality\n bicycles at very reasonable prices. Out of the workshop in Fitzroy,\n have been offering bicycles since 2015. Bicycles get designed in-house\n as well some components. You are very welcome at the workshop to test\n ride any of these good bikes.\n

\n\n

\n In simple terms firstly, bikes gets designed along with the component\n list. Then, work with the sales and engineering team at the partner\n bike assembly factory to get the right commuter bike. Then place a\n decent order. Factory sends the bicycles to Melbourne. Saying that,\n these are factory direct bicycles. No middle companies. By doing most\n of the planning, designing, assembly in-house and the partner\n factories and by ordering large quantities, mission is to offer a\n good.bike at a fair price. Same time good.bike is very fair to\n suppliers. Thanks to parts suppliers like Shimano Australia, have been\n able to offer quality spare parts for years.\n

\n\n

\n As a growing, independent entity, constantly adapting and testing\n bicycles to make them even better. The mission is to create very, very\n good quality bicycles that make people happy and are a joy to ride. So\n on a good bike mission.\n

\n\n

\n Other than offering a good.bike, here to offer a friendly, caring and\n supportive service.\n

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

\n Technical Specifications\n

\n\n
\n {features.map((feature) => (\n \n
\n
\n \n
\n
\n {feature.name}\n
\n
\n\n
\n {feature.description}\n
\n
\n ))}\n \n
\n
\n \n \n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
\n
\n \n\n
\n
\n
\n \n

\n Good City Bike\n

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

\n Good Step-through Bike\n

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

Warranty

\n

You are very welcome at the workshop in Fitzroy

\n

Frame and fork: Warranty period is 2 1/2 years

\n

\n {\" \"}\n Bicycles comes with warranty for the original purchaser against\n defects in material and workmanship{\" \"}\n

\n

Frame and fork: Warranty period is 2 1/2 years

\n

Shimano components: their international warranty is 2 years

\n

Other non consumable parts one year

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

\n Any questions to clarify?\n

\n

You are very welcome at the workshop in Fitzroy

\n

\n Always very happy to pick up the phone or respond to an email\n and answer your questions.\n

\n

\n If you are looking to buy a bicycle, suggest you visit the\n humble workshop, so you can see the bicycles in person and have\n a test ride.\n

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

Frame

\n\n

\n Frame and the custom-designed fork is built with chromoly steel.\n Chromoly is strong and lightweight.\n

\n

\n Chromoly frames are not as rigid as standard steel or aluminum\n alloy frames, so they absorb vibrations from the road and last\n longer. This means your ride is smoother and more gentle.\n

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

Shimano Parts

\n

\n Shimano Hydraulic disc brakes, Shimano Gears and Shimano hubs.\n So guaranteed come with good bike parts.\n

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