mirror of https://github.com/mitchell/mjfs.us.git
Renamed screens/ to containers/; changed from standard to prettier; modified quick bio; version bump; changed from yarn back to npm
This commit is contained in:
parent
e800ba76b6
commit
63362a9c8d
|
@ -0,0 +1 @@
|
||||||
|
semi: false
|
|
@ -1,5 +1,5 @@
|
||||||
# Personal Website
|
# Personal Website
|
||||||
[data:image/s3,"s3://crabby-images/432d6/432d695915e1b608030587a7ba48baa6280c643d" alt="JavaScript Style Guide"](https://standardjs.com)
|
[data:image/s3,"s3://crabby-images/44996/44996f69b3325fc91c8d31413a898043035baa48" alt="code style: prettier"](https://github.com/prettier/prettier)
|
||||||
|
|
||||||
This is my personal website built using React.js. It is hosted in multiple
|
This is my personal website built using React.js. It is hosted in multiple
|
||||||
locations around the US, Canada, and Europe thanks to AWS CloudFront and S3.
|
locations around the US, Canada, and Europe thanks to AWS CloudFront and S3.
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "react-website",
|
"name": "react-website",
|
||||||
"version": "0.2.11",
|
"version": "0.2.12",
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@fortawesome/fontawesome": "^1.1.8",
|
"@fortawesome/fontawesome": "^1.1.8",
|
||||||
|
@ -21,6 +21,6 @@
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"csslint": "^1.0.5",
|
"csslint": "^1.0.5",
|
||||||
"standard": "^11.0.1"
|
"prettier": "^1.13.7"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,26 +1,26 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
import { Route, Switch } from 'react-router-dom'
|
import { Route, Switch } from "react-router-dom"
|
||||||
|
|
||||||
import Header from './components/Header'
|
import Header from "./components/Header"
|
||||||
import Navbar from './components/Navbar'
|
import Navbar from "./components/Navbar"
|
||||||
import Home from './screens/Home'
|
import Home from "./containers/Home"
|
||||||
import Projects from './screens/Projects'
|
import Projects from "./containers/Projects"
|
||||||
import Experience from './screens/Experience'
|
import Experience from "./containers/Experience"
|
||||||
import Contact from './screens/Contact'
|
import Contact from "./containers/Contact"
|
||||||
|
|
||||||
import './Website.css'
|
import "./Website.css"
|
||||||
|
|
||||||
class Website extends React.Component {
|
class Website extends React.Component {
|
||||||
render () {
|
render() {
|
||||||
return (
|
return (
|
||||||
<div className='website'>
|
<div className="website">
|
||||||
<div className='main-container'>
|
<div className="main-container">
|
||||||
<Header />
|
<Header />
|
||||||
<Switch>
|
<Switch>
|
||||||
<Route exact path='/' component={Home} />
|
<Route exact path="/" component={Home} />
|
||||||
<Route path='/projects' component={Projects} />
|
<Route path="/projects" component={Projects} />
|
||||||
<Route path='/experience' component={Experience} />
|
<Route path="/experience" component={Experience} />
|
||||||
<Route path='/contact' component={Contact} />
|
<Route path="/contact" component={Contact} />
|
||||||
</Switch>
|
</Switch>
|
||||||
<Navbar />
|
<Navbar />
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
import ReactDOM from 'react-dom'
|
import ReactDOM from "react-dom"
|
||||||
import Website from './Website.js'
|
import Website from "./Website.js"
|
||||||
|
|
||||||
it('renders without crashing', () => {
|
it("renders without crashing", () => {
|
||||||
const div = document.createElement('div')
|
const div = document.createElement("div")
|
||||||
ReactDOM.render(<Website />, div)
|
ReactDOM.render(<Website />, div)
|
||||||
ReactDOM.unmountComponentAtNode(div)
|
ReactDOM.unmountComponentAtNode(div)
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
import PropTypes from 'prop-types'
|
import PropTypes from "prop-types"
|
||||||
|
|
||||||
import './index.css'
|
import "./index.css"
|
||||||
|
|
||||||
class ClearButton extends React.PureComponent {
|
class ClearButton extends React.PureComponent {
|
||||||
render () {
|
render() {
|
||||||
return (
|
return (
|
||||||
<a className='clear-button' href={this.props.href}>{this.props.children}</a>
|
<a className="clear-button" href={this.props.href}>
|
||||||
|
{this.props.children}
|
||||||
|
</a>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
|
|
||||||
import SmallText from '../SmallText'
|
import SmallText from "../SmallText"
|
||||||
|
|
||||||
import './index.css'
|
import "./index.css"
|
||||||
|
|
||||||
class Header extends React.PureComponent {
|
class Header extends React.PureComponent {
|
||||||
render () {
|
render() {
|
||||||
return (
|
return (
|
||||||
<div className='header-container'>
|
<div className="header-container">
|
||||||
<h2>Mitchell J. F. Simon</h2>
|
<h2>Mitchell J. F. Simon</h2>
|
||||||
<SmallText>Lead Backend Engineer, Hypremium.</SmallText>
|
<SmallText>Lead Backend Engineer, Hypremium.</SmallText>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,26 +1,42 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
import ResponsiveMenu from 'react-responsive-navbar'
|
import ResponsiveMenu from "react-responsive-navbar"
|
||||||
import { NavLink } from 'react-router-dom'
|
import { NavLink } from "react-router-dom"
|
||||||
import FontAwesomeIcon from '@fortawesome/react-fontawesome'
|
import FontAwesomeIcon from "@fortawesome/react-fontawesome"
|
||||||
import faBars from '@fortawesome/fontawesome-free-solid/faBars'
|
import faBars from "@fortawesome/fontawesome-free-solid/faBars"
|
||||||
|
|
||||||
import './index.css'
|
import "./index.css"
|
||||||
|
|
||||||
class Navbar extends React.Component {
|
class Navbar extends React.Component {
|
||||||
render () {
|
render() {
|
||||||
return (
|
return (
|
||||||
<ResponsiveMenu
|
<ResponsiveMenu
|
||||||
menuOpenButton={<div className='navbar-button'><FontAwesomeIcon icon={faBars} /></div>}
|
menuOpenButton={
|
||||||
menuCloseButton={<div className='navbar-button navbar-button-close'><FontAwesomeIcon icon={faBars} /></div>}
|
<div className="navbar-button">
|
||||||
changeMenuOn='500px'
|
<FontAwesomeIcon icon={faBars} />
|
||||||
largeMenuClassName='navbar'
|
</div>
|
||||||
smallMenuClassName='navbar'
|
}
|
||||||
|
menuCloseButton={
|
||||||
|
<div className="navbar-button navbar-button-close">
|
||||||
|
<FontAwesomeIcon icon={faBars} />
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
changeMenuOn="500px"
|
||||||
|
largeMenuClassName="navbar"
|
||||||
|
smallMenuClassName="navbar"
|
||||||
menu={
|
menu={
|
||||||
<div className='navbar-menu'>
|
<div className="navbar-menu">
|
||||||
<NavLink activeClassName='active-button' exact to='/'><div>Home</div></NavLink>
|
<NavLink activeClassName="active-button" exact to="/">
|
||||||
<NavLink activeClassName='active-button' to='/projects'><div>Projects</div></NavLink>
|
<div>Home</div>
|
||||||
<NavLink activeClassName='active-button' to='/experience'><div>Experience</div></NavLink>
|
</NavLink>
|
||||||
<NavLink activeClassName='active-button' to='/contact'><div>Contact</div></NavLink>
|
<NavLink activeClassName="active-button" to="/projects">
|
||||||
|
<div>Projects</div>
|
||||||
|
</NavLink>
|
||||||
|
<NavLink activeClassName="active-button" to="/experience">
|
||||||
|
<div>Experience</div>
|
||||||
|
</NavLink>
|
||||||
|
<NavLink activeClassName="active-button" to="/contact">
|
||||||
|
<div>Contact</div>
|
||||||
|
</NavLink>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -1,13 +1,11 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
import PropTypes from 'prop-types'
|
import PropTypes from "prop-types"
|
||||||
|
|
||||||
import './index.css'
|
import "./index.css"
|
||||||
|
|
||||||
class SmallText extends React.PureComponent {
|
class SmallText extends React.PureComponent {
|
||||||
render () {
|
render() {
|
||||||
return (
|
return <div className="small-text">{this.props.children}</div>
|
||||||
<div className='small-text'>{this.props.children}</div>
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,19 @@
|
||||||
|
import React from "react"
|
||||||
|
|
||||||
|
import "./index.css"
|
||||||
|
import linkedIn from "../../images/In-2C-128px-TM.png"
|
||||||
|
|
||||||
|
class Contact extends React.PureComponent {
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<div className="contact-container">
|
||||||
|
<p>m@mjfs.us</p>
|
||||||
|
<a href="https://www.linkedin.com/in/mitchelljfsimon/">
|
||||||
|
<img src={linkedIn} alt="LinkedIn" />
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Contact
|
|
@ -0,0 +1,104 @@
|
||||||
|
import React from "react"
|
||||||
|
|
||||||
|
import SmallText from "../../components/SmallText"
|
||||||
|
import "./index.css"
|
||||||
|
|
||||||
|
class Experience extends React.PureComponent {
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<div className="experience-container">
|
||||||
|
<div>
|
||||||
|
<div className="experience-title">Lead Backend Engineer</div>
|
||||||
|
<div className="experience-company">Hypremium.</div>
|
||||||
|
<SmallText className="experience-smalltext">
|
||||||
|
May 2018 - Present
|
||||||
|
</SmallText>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
Architect all new backend microservices using Serverless, AWS API
|
||||||
|
Gateway/Lambda/more, and Golang.
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Lead backend development team in an Agile (scrumban) environment.
|
||||||
|
</li>
|
||||||
|
<li>Monitor and maintain all stages of hosted microservices.</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div className="experience-title">DevOps Engineer</div>
|
||||||
|
<div className="experience-company">Hypremium.</div>
|
||||||
|
<SmallText className="experience-smalltext">
|
||||||
|
January 2018 - May 2018, 5 Months
|
||||||
|
</SmallText>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
Maintain & migrate Ruby on Rails API and backend application.
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Oversee and assist with continuous integration for backend
|
||||||
|
development.
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div className="experience-title">Sales Associate</div>
|
||||||
|
<div className="experience-company">J. Crew</div>
|
||||||
|
<SmallText className="experience-smalltext">
|
||||||
|
October 2015 - January 2017, 1 Year 5 Months
|
||||||
|
</SmallText>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
Knowing the products and what products best suit the customers’
|
||||||
|
needs.
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Helping the customer with any manner of purchase, exchange, or
|
||||||
|
return.
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div className="experience-title">Intern</div>
|
||||||
|
<div className="experience-company">Zumasys</div>
|
||||||
|
<SmallText className="experience-smalltext">
|
||||||
|
June 2015 - August 2015, 3 Months
|
||||||
|
</SmallText>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
Main goal was to learn as much about the business and their
|
||||||
|
technology as possible
|
||||||
|
</li>
|
||||||
|
<li>Management and organization of customer correspondence.</li>
|
||||||
|
<li>Auditing of server space.</li>
|
||||||
|
<li>
|
||||||
|
Dispatching and filtering ticketing system and office computer
|
||||||
|
assistance.
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div className="experience-title">User Support Technician</div>
|
||||||
|
<div className="experience-company">
|
||||||
|
Point Loma Nazarene University, ITS Deptarment
|
||||||
|
</div>
|
||||||
|
<SmallText className="experience-smalltext">
|
||||||
|
Jan 2015 - May 2015, 5 Months
|
||||||
|
</SmallText>
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
First in contact for email hotline, second in contact for phones.
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Work with customers via email, phone, remote control, and in
|
||||||
|
person.
|
||||||
|
</li>
|
||||||
|
<li>Computer diagnosis, repair, and preparation for customer.</li>
|
||||||
|
<li>Special projects.</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Experience
|
|
@ -16,7 +16,7 @@
|
||||||
margin-right: 3%;
|
margin-right: 3%;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and ( max-width: 500px ) {
|
@media screen and (max-width: 500px) {
|
||||||
.home-container img {
|
.home-container img {
|
||||||
margin: 5%;
|
margin: 5%;
|
||||||
width: 90%;
|
width: 90%;
|
|
@ -0,0 +1,34 @@
|
||||||
|
import React from "react"
|
||||||
|
|
||||||
|
import "./index.css"
|
||||||
|
import profile from "../../images/profile.jpg"
|
||||||
|
|
||||||
|
class Home extends React.PureComponent {
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<div className="home-container">
|
||||||
|
<img src={profile} alt="Profile" />
|
||||||
|
<p>Hello and welcome,</p>
|
||||||
|
<p>
|
||||||
|
My name is Mitchell Simon. I am the Lead Backend Engineer at
|
||||||
|
Hypremium, where I lead the architecture of and maintain our
|
||||||
|
serverless, Golang backend. I also offer my skills as a consulting web
|
||||||
|
& cloud developer.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
My professional interests include web development (with an emphasis on
|
||||||
|
backend), system administration, network architecture, software
|
||||||
|
engineering, cybersecurity, and business administration. My personal
|
||||||
|
interests include music performance, skiing, and politics.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Thank you for reading my quick bio. If you would like to contact me
|
||||||
|
visit the contact page for all of your options.
|
||||||
|
</p>
|
||||||
|
<p className="signature">- Mitchell J. F. Simon, III</p>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Home
|
|
@ -0,0 +1,67 @@
|
||||||
|
import React from "react"
|
||||||
|
|
||||||
|
import ClearButton from "../../components/ClearButton"
|
||||||
|
|
||||||
|
import "./index.css"
|
||||||
|
|
||||||
|
class Projects extends React.PureComponent {
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<div className="projects-container">
|
||||||
|
<div>
|
||||||
|
<h4>mjfs.us</h4>
|
||||||
|
<p>
|
||||||
|
This website has taken many forms over the years, as my frontend and
|
||||||
|
design skills increase. It has been simple HTML, CSS, and JS, and a
|
||||||
|
Ruby Sinatra web app. Currently it takes the form of a React.js app.
|
||||||
|
I enjoy React.js (and similar frontend frameworks) as they can be
|
||||||
|
used to make even the simplest projects modular and extensible.
|
||||||
|
</p>
|
||||||
|
<ClearButton href="https://github.com/mitchelljfs/react-website">
|
||||||
|
Repository
|
||||||
|
</ClearButton>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h4>destinate</h4>
|
||||||
|
<p>
|
||||||
|
destinate is a react-native, iOS (and Android) app. Its main
|
||||||
|
objective is to suggest places or activities to the user based on
|
||||||
|
their past choices. It utilizes a serverless backend, written in Go
|
||||||
|
and hosted on AWS API Gateway/Lambda. It is still under development,
|
||||||
|
as a side project of Arash Lari and I.
|
||||||
|
</p>
|
||||||
|
<ClearButton href="https://github.com/mitchelljfs/destinate">
|
||||||
|
Repository
|
||||||
|
</ClearButton>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h4>memebank API</h4>
|
||||||
|
<p>
|
||||||
|
This is a RESTful API using the Rails framework to support the front
|
||||||
|
end application of memebank. It uses JWT authentication for
|
||||||
|
stateless account authentication, and bcrypt for password
|
||||||
|
encryption. It communicates with the front-end using basic HTTP
|
||||||
|
requests and JSON objects.
|
||||||
|
</p>
|
||||||
|
<ClearButton href="https://github.com/aherco/memebank-api">
|
||||||
|
Repository
|
||||||
|
</ClearButton>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h4>reddit Neo4J Database</h4>
|
||||||
|
<p>
|
||||||
|
A learning Neo4j database project of a sample of comments on the
|
||||||
|
popular social media platform Reddit. It can show the relationships
|
||||||
|
between users, their comments, and subreddits. With this information
|
||||||
|
we can infer demographic information about reddit's users.
|
||||||
|
</p>
|
||||||
|
<ClearButton href="https://github.com/mitchelljfs/comment_context_analysis">
|
||||||
|
Repository
|
||||||
|
</ClearButton>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Projects
|
18
src/index.js
18
src/index.js
|
@ -1,15 +1,15 @@
|
||||||
import React from 'react'
|
import React from "react"
|
||||||
import ReactDOM from 'react-dom'
|
import ReactDOM from "react-dom"
|
||||||
import { BrowserRouter } from 'react-router-dom'
|
import { BrowserRouter } from "react-router-dom"
|
||||||
|
|
||||||
import './index.css'
|
import "./index.css"
|
||||||
import Website from './Website'
|
import Website from "./Website"
|
||||||
import registerServiceWorker from './registerServiceWorker'
|
import registerServiceWorker from "./registerServiceWorker"
|
||||||
|
|
||||||
ReactDOM.render((
|
ReactDOM.render(
|
||||||
<BrowserRouter>
|
<BrowserRouter>
|
||||||
<Website />
|
<Website />
|
||||||
</BrowserRouter>
|
</BrowserRouter>,
|
||||||
), document.getElementById('root')
|
document.getElementById("root")
|
||||||
)
|
)
|
||||||
registerServiceWorker()
|
registerServiceWorker()
|
||||||
|
|
|
@ -9,17 +9,17 @@
|
||||||
// This link also includes instructions on opting out of this behavior.
|
// This link also includes instructions on opting out of this behavior.
|
||||||
|
|
||||||
const isLocalhost = Boolean(
|
const isLocalhost = Boolean(
|
||||||
window.location.hostname === 'localhost' ||
|
window.location.hostname === "localhost" ||
|
||||||
// [::1] is the IPv6 localhost address.
|
// [::1] is the IPv6 localhost address.
|
||||||
window.location.hostname === '[::1]' ||
|
window.location.hostname === "[::1]" ||
|
||||||
// 127.0.0.1/8 is considered localhost for IPv4.
|
// 127.0.0.1/8 is considered localhost for IPv4.
|
||||||
window.location.hostname.match(
|
window.location.hostname.match(
|
||||||
/^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
|
/^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
export default function register () {
|
export default function register() {
|
||||||
if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {
|
if (process.env.NODE_ENV === "production" && "serviceWorker" in navigator) {
|
||||||
// The URL constructor is available in all browsers that support SW.
|
// The URL constructor is available in all browsers that support SW.
|
||||||
const publicUrl = new URL(process.env.PUBLIC_URL, window.location) // eslint-disable-line no-undef
|
const publicUrl = new URL(process.env.PUBLIC_URL, window.location) // eslint-disable-line no-undef
|
||||||
if (publicUrl.origin !== window.location.origin) {
|
if (publicUrl.origin !== window.location.origin) {
|
||||||
|
@ -29,7 +29,7 @@ export default function register () {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
window.addEventListener('load', () => {
|
window.addEventListener("load", () => {
|
||||||
const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`
|
const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`
|
||||||
|
|
||||||
if (isLocalhost) {
|
if (isLocalhost) {
|
||||||
|
@ -40,8 +40,8 @@ export default function register () {
|
||||||
// service worker/PWA documentation.
|
// service worker/PWA documentation.
|
||||||
navigator.serviceWorker.ready.then(() => {
|
navigator.serviceWorker.ready.then(() => {
|
||||||
console.log(
|
console.log(
|
||||||
'This web app is being served cache-first by a service ' +
|
"This web app is being served cache-first by a service " +
|
||||||
'worker. To learn more, visit https://goo.gl/SC7cgQ'
|
"worker. To learn more, visit https://goo.gl/SC7cgQ"
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
|
@ -52,43 +52,43 @@ export default function register () {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function registerValidSW (swUrl) {
|
function registerValidSW(swUrl) {
|
||||||
navigator.serviceWorker
|
navigator.serviceWorker
|
||||||
.register(swUrl)
|
.register(swUrl)
|
||||||
.then(registration => {
|
.then(registration => {
|
||||||
registration.onupdatefound = () => {
|
registration.onupdatefound = () => {
|
||||||
const installingWorker = registration.installing
|
const installingWorker = registration.installing
|
||||||
installingWorker.onstatechange = () => {
|
installingWorker.onstatechange = () => {
|
||||||
if (installingWorker.state === 'installed') {
|
if (installingWorker.state === "installed") {
|
||||||
if (navigator.serviceWorker.controller) {
|
if (navigator.serviceWorker.controller) {
|
||||||
// At this point, the old content will have been purged and
|
// At this point, the old content will have been purged and
|
||||||
// the fresh content will have been added to the cache.
|
// the fresh content will have been added to the cache.
|
||||||
// It's the perfect time to display a "New content is
|
// It's the perfect time to display a "New content is
|
||||||
// available; please refresh." message in your web app.
|
// available; please refresh." message in your web app.
|
||||||
console.log('New content is available; please refresh.')
|
console.log("New content is available; please refresh.")
|
||||||
} else {
|
} else {
|
||||||
// At this point, everything has been precached.
|
// At this point, everything has been precached.
|
||||||
// It's the perfect time to display a
|
// It's the perfect time to display a
|
||||||
// "Content is cached for offline use." message.
|
// "Content is cached for offline use." message.
|
||||||
console.log('Content is cached for offline use.')
|
console.log("Content is cached for offline use.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch(error => {
|
||||||
console.error('Error during service worker registration:', error)
|
console.error("Error during service worker registration:", error)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
function checkValidServiceWorker (swUrl) {
|
function checkValidServiceWorker(swUrl) {
|
||||||
// Check if the service worker can be found. If it can't reload the page.
|
// Check if the service worker can be found. If it can't reload the page.
|
||||||
fetch(swUrl) // eslint-disable-line no-undef
|
fetch(swUrl) // eslint-disable-line no-undef
|
||||||
.then(response => {
|
.then(response => {
|
||||||
// Ensure service worker exists, and that we really are getting a JS file.
|
// Ensure service worker exists, and that we really are getting a JS file.
|
||||||
if (
|
if (
|
||||||
response.status === 404 ||
|
response.status === 404 ||
|
||||||
response.headers.get('content-type').indexOf('javascript') === -1
|
response.headers.get("content-type").indexOf("javascript") === -1
|
||||||
) {
|
) {
|
||||||
// No service worker found. Probably a different app. Reload the page.
|
// No service worker found. Probably a different app. Reload the page.
|
||||||
navigator.serviceWorker.ready.then(registration => {
|
navigator.serviceWorker.ready.then(registration => {
|
||||||
|
@ -103,13 +103,13 @@ function checkValidServiceWorker (swUrl) {
|
||||||
})
|
})
|
||||||
.catch(() => {
|
.catch(() => {
|
||||||
console.log(
|
console.log(
|
||||||
'No internet connection found. App is running in offline mode.'
|
"No internet connection found. App is running in offline mode."
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
export function unregister () {
|
export function unregister() {
|
||||||
if ('serviceWorker' in navigator) {
|
if ("serviceWorker" in navigator) {
|
||||||
navigator.serviceWorker.ready.then(registration => {
|
navigator.serviceWorker.ready.then(registration => {
|
||||||
registration.unregister()
|
registration.unregister()
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
import React from 'react'
|
|
||||||
|
|
||||||
import './index.css'
|
|
||||||
import linkedIn from '../../images/In-2C-128px-TM.png'
|
|
||||||
|
|
||||||
class Contact extends React.PureComponent {
|
|
||||||
render () {
|
|
||||||
return (
|
|
||||||
<div className='contact-container'>
|
|
||||||
<p>m@mjfs.us</p>
|
|
||||||
<a href='https://www.linkedin.com/in/mitchelljfsimon/'>
|
|
||||||
<img src={linkedIn} alt='LinkedIn' />
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Contact
|
|
|
@ -1,65 +0,0 @@
|
||||||
import React from 'react'
|
|
||||||
|
|
||||||
import SmallText from '../../components/SmallText'
|
|
||||||
import './index.css'
|
|
||||||
|
|
||||||
class Experience extends React.PureComponent {
|
|
||||||
render () {
|
|
||||||
return (
|
|
||||||
<div className='experience-container'>
|
|
||||||
<div>
|
|
||||||
<div className='experience-title'>Lead Backend Engineer</div>
|
|
||||||
<div className='experience-company'>Hypremium.</div>
|
|
||||||
<SmallText className='experience-smalltext'>May 2018 - Present</SmallText>
|
|
||||||
<ul>
|
|
||||||
<li>Architect all new backend microservices using Serverless, AWS API Gateway/Lambda/more, and Golang.</li>
|
|
||||||
<li>Lead backend development team in an Agile (scrumban) environment.</li>
|
|
||||||
<li>Monitor and maintain all stages of hosted microservices.</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<div className='experience-title'>DevOps Engineer</div>
|
|
||||||
<div className='experience-company'>Hypremium.</div>
|
|
||||||
<SmallText className='experience-smalltext'>January 2018 - May 2018, 5 Months</SmallText>
|
|
||||||
<ul>
|
|
||||||
<li>Maintain & migrate Ruby on Rails API and backend application.</li>
|
|
||||||
<li>Oversee and assist with continuous integration for backend development.</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<div className='experience-title'>Sales Associate</div>
|
|
||||||
<div className='experience-company'>J. Crew</div>
|
|
||||||
<SmallText className='experience-smalltext'>October 2015 - January 2017, 1 Year 5 Months</SmallText>
|
|
||||||
<ul>
|
|
||||||
<li>Knowing the products and what products best suit the customers’ needs.</li>
|
|
||||||
<li>Helping the customer with any manner of purchase, exchange, or return.</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<div className='experience-title'>Intern</div>
|
|
||||||
<div className='experience-company'>Zumasys</div>
|
|
||||||
<SmallText className='experience-smalltext'>June 2015 - August 2015, 3 Months</SmallText>
|
|
||||||
<ul>
|
|
||||||
<li>Main goal was to learn as much about the business and their technology as possible</li>
|
|
||||||
<li>Management and organization of customer correspondence.</li>
|
|
||||||
<li>Auditing of server space.</li>
|
|
||||||
<li>Dispatching and filtering ticketing system and office computer assistance.</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<div className='experience-title'>User Support Technician</div>
|
|
||||||
<div className='experience-company'>Point Loma Nazarene University, ITS Deptarment</div>
|
|
||||||
<SmallText className='experience-smalltext'>Jan 2015 - May 2015, 5 Months</SmallText>
|
|
||||||
<ul>
|
|
||||||
<li>First in contact for email hotline, second in contact for phones.</li>
|
|
||||||
<li>Work with customers via email, phone, remote control, and in person.</li>
|
|
||||||
<li>Computer diagnosis, repair, and preparation for customer.</li>
|
|
||||||
<li>Special projects.</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Experience
|
|
|
@ -1,34 +0,0 @@
|
||||||
import React from 'react'
|
|
||||||
|
|
||||||
import './index.css'
|
|
||||||
import profile from '../../images/profile.jpg'
|
|
||||||
|
|
||||||
class Home extends React.PureComponent {
|
|
||||||
render () {
|
|
||||||
return (
|
|
||||||
<div className='home-container'>
|
|
||||||
<img src={profile} alt='Profile' />
|
|
||||||
<p>Hello and welcome,</p>
|
|
||||||
<p>
|
|
||||||
My name is Mitchell Simon. I am the Lead Backend Engineer at
|
|
||||||
Hypremium, where I lead the architecture of and maintain our serverless,
|
|
||||||
Golang backend. I also offer my skills as a consulting/independent
|
|
||||||
web & cloud developer.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
My professional interests include web development (with an
|
|
||||||
emphasis on backend), system administration, network architecture,
|
|
||||||
software engineering, cybersecurity, and business administration. My
|
|
||||||
personal interests include music performance, skiing, and politics.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
Thank you for reading my quick bio. If you would like to contact me
|
|
||||||
visit the contact page for all of your options.
|
|
||||||
</p>
|
|
||||||
<p className='signature'>- Mitchell J. F. Simon, III</p>
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Home
|
|
|
@ -1,60 +0,0 @@
|
||||||
import React from 'react'
|
|
||||||
|
|
||||||
import ClearButton from '../../components/ClearButton'
|
|
||||||
|
|
||||||
import './index.css'
|
|
||||||
|
|
||||||
class Projects extends React.PureComponent {
|
|
||||||
render () {
|
|
||||||
return (
|
|
||||||
<div className='projects-container'>
|
|
||||||
<div>
|
|
||||||
<h4>mjfs.us</h4>
|
|
||||||
<p>
|
|
||||||
This website has taken many forms over the years, as my frontend
|
|
||||||
and design skills increase. It has been simple HTML, CSS, and JS,
|
|
||||||
and a Ruby Sinatra web app. Currently it takes the form of a
|
|
||||||
React.js app. I enjoy React.js (and similar frontend frameworks)
|
|
||||||
as they can be used to make even the simplest projects modular and
|
|
||||||
extensible.
|
|
||||||
</p>
|
|
||||||
<ClearButton href='https://github.com/mitchelljfs/react-website'>Repository</ClearButton>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<h4>destinate</h4>
|
|
||||||
<p>
|
|
||||||
destinate is a react-native, iOS (and Android) app. Its main objective
|
|
||||||
is to suggest places or activities to the user based on their past
|
|
||||||
choices. It utilizes a serverless backend, written in Go and hosted
|
|
||||||
on AWS API Gateway/Lambda. It is still under development, as a side
|
|
||||||
project of Arash Lari and I.
|
|
||||||
</p>
|
|
||||||
<ClearButton href='https://github.com/mitchelljfs/destinate'>Repository</ClearButton>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<h4>memebank API</h4>
|
|
||||||
<p>
|
|
||||||
This is a RESTful API using the Rails framework to support the
|
|
||||||
front end application of memebank. It uses JWT authentication for
|
|
||||||
stateless account authentication, and bcrypt for password
|
|
||||||
encryption. It communicates with the front-end using basic HTTP
|
|
||||||
requests and JSON objects.
|
|
||||||
</p>
|
|
||||||
<ClearButton href='https://github.com/aherco/memebank-api'>Repository</ClearButton>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<h4>reddit Neo4J Database</h4>
|
|
||||||
<p>
|
|
||||||
A learning Neo4j database project of a sample of comments on the
|
|
||||||
popular social media platform Reddit. It can show the relationships between
|
|
||||||
users, their comments, and subreddits. With this information we can
|
|
||||||
infer demographic information about reddit's users.
|
|
||||||
</p>
|
|
||||||
<ClearButton href='https://github.com/mitchelljfs/comment_context_analysis'>Repository</ClearButton>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Projects
|
|
Loading…
Reference in New Issue