{"version":3,"sources":["components/header/Header.tsx","logo-square-250x250.png","components/appsComponent/AppsComponent.tsx","components/tech/TechComponent.tsx","components/gallery/galleryApi.ts","components/gallery/BeartoonGallery.tsx","App.tsx","reportWebVitals.ts","index.tsx"],"names":["BearwaveHeader","className","src","alt","to","AppsComponent","href","target","rel","TechComponent","fetchSeries","a","axios","get","then","resp","data","fetchBeartoons","map","b","d","Date","created","initialState","loading","loaded","series","Map","currentToonIndex","currentSeries","visitedSeriesIds","visitedUnseriesedToons","previous","randomNumber","max","Math","floor","random","randomNextSeries","numSeries","rand","hasPreviousToon","state","hasNextToon","maxToons","beartoons","length","renderSeriesTitle","size","currentToon","dayjs","format","title","BeartoonComponent","current","image","caption","width","BeartoonGallery","useState","setState","useEffect","Promise","all","res","bs","seriesMap","allSeries","_","chain","s","keyBy","value","forEach","series_id","existingSeries","existingBeartoons","newBeartoons","concat","uniq","orderBy","set","mapSeriesState","first","firstSeries","firstToon","sortedByCreated","latest","head","latestSeries","latestBeartoon","unseriesed","findIndex","t","id","beartoon","getFirstSeriesAndToon","sequence","catch","err","console","error","classNames","disabled","onClick","prevToonState","nextSeries","includes","nextToon","updatedSeriesIds","updatedUnseriesedToons","visitedSeries","nextToonState","App","exact","path","reportWebVitals","onPerfEntry","Function","getCLS","getFID","getFCP","getLCP","getTTFB","ReactDOM","render","StrictMode","document","getElementById"],"mappings":"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","file":"static/js/main.c35fd48c.chunk.js","sourcesContent":["import React from 'react';\nimport { NavLink } from 'react-router-dom';\n\nimport logo from '../../logo-square-250x250.png';\n\nconst BearwaveHeader = () => (\n
\n
\n
\n \"Bearwave\"\n
\n
\n
\n
\n
    \n
  • tech.
  • \n
  • apps.
  • \n
  • toons.
  • \n
\n
\n
\n
 
\n
\n);\n\nexport default BearwaveHeader;","export default \"\"","import React from 'react';\n\nconst AppsComponent = () => {\n return (\n
\n

Apps

\n\n

Submitted for your approval... some random tinkering projects.

\n\n
\n

\n www.bearwavetech.com\n (you're lookin at it)\n

\n

\n The site is meant to be straightforward, and a culmination of techniques and tools I've been using\n over the past few years. It's not much, but I'm fairly proud of this site. The bulk of it was done\n in a single day with extensive use of popular frameworks.\n

\n

Day 1 started at 11am and ended at 5am the following morning.

\n \n

whew~

\n

Day 2 involved compiling a production version of the backend/frontend, setting up a new server, and deploying the initial version.

\n

Day 3 was a few rounds of tweaking the look and feel, adding navigation, additional pages like this one, and repeating.

\n

Et voila, a wild bearwavetech.com appears!!

\n
\n\n
\n

\n Background Tab Search\n Chrome Extension\n

\n

\n If you ever go down a wikipedia/Google rabbit hole, and find every page you come across causes you\n to\n search for another concept in another tab, this extension lets you do your search without switching\n to that new tab and interrupting your reading focus. Works even better if you activate it with a\n keyboard macro.\n

\n

\n Alternatively, you could use your regular URL bar to type your search and hit alt + shift +\n enter.\n

\n
\n
\n );\n};\n\nexport default AppsComponent;","import React from 'react';\n\nconst TechComponent = () => {\n return (\n
\n

Tech (consulting)

\n\n

\n Need some technology made? Let's chat! Whether you're a small start-up looking for guidance on\n building a website/app, an academic institution building out an in-house team, or a large enterprise\n looking\n for hands-on expertise, this is the right place to look.\n

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

Technology consulting services

\n
    \n
  • system architecture & design
  • \n
  • cloud infrastructure architecture & implementation
  • \n
  • system monitoring
  • \n
  • full-stack development
  • \n
  • rapid prototyping
  • \n
  • data analytics collection & analysis
  • \n
\n
\n
\n

Bread and butter (mmm...) tech stacks:

\n
    \n
  • Linux - Ubuntu, Amazon, Debian
  • \n
  • Amazon AWS, Microsoft Azure
  • \n
  • SQL, MongoDB, various no-SQL
  • \n
  • RabbitMQ, MQTT, AWS Kinesis, Azure ServiceBus
  • \n
  • Elastic ELK stack
  • \n
  • NodeJS, React/Redux, Typescript, ExpressJS
  • \n
  • Python, Django, Flask
  • \n
\n
\n
\n
\n );\n};\n\nexport default TechComponent;\n","import axios from 'axios';\n\nexport interface Series {\n id: number;\n created: Date;\n title?: string;\n beartoons: Beartoon[];\n}\n\nexport interface Beartoon {\n id: number;\n created: Date;\n sequence: number;\n caption?: string;\n series?: number;\n image: string;\n}\n\nexport const fetchSeries = async (): Promise =>\n await axios.get('/api/series/').then(resp => resp.data);\n\nexport const fetchBeartoons = async (): Promise =>\n await axios.get('/api/beartoons/').then(resp => {\n return resp.data.map((b: Beartoon) => {\n const d = new Date(b.created);\n return {\n ...b,\n created: new Date(d),\n };\n });\n });\n\n","import React, {useEffect, useState} from 'react';\nimport dayjs from 'dayjs';\nimport _ from 'lodash';\nimport classNames from 'classnames';\n\nimport {Series, Beartoon, fetchBeartoons, fetchSeries} from \"./galleryApi\";\n\ninterface BeartoonGalleryState {\n loading: boolean;\n loaded: boolean;\n series: any;\n currentToonIndex: number,\n currentSeries: number,\n visitedSeriesIds: number[],\n visitedUnseriesedToons: number[],\n previous: any,\n}\n\nconst initialState: BeartoonGalleryState = {\n loading: false,\n loaded: false,\n series: new Map(),\n currentToonIndex: 0,\n currentSeries: 0,\n visitedSeriesIds: [],\n visitedUnseriesedToons: [],\n previous: {},\n}\n\n\nconst mapSeriesState = (series: Series[], beartoons: Beartoon[]) => {\n const allSeries = _.chain(series)\n .map(s => {\n return {\n ...s,\n beartoons: [],\n }\n })\n .keyBy('id')\n .value();\n const map = new Map();\n _.forEach(beartoons, b => {\n const series_id = (!b.series) ? 0 : b.series;\n const existingSeries = map.get(series_id) || allSeries[series_id] || {};\n const existingBeartoons = existingSeries.beartoons || [];\n const newBeartoons = _.chain(existingBeartoons.concat(b)).uniq().orderBy(['sequence'], ['asc']).value();\n map.set(series_id, {\n ...existingSeries,\n beartoons: newBeartoons,\n });\n });\n return map;\n};\n\n\nconst randomNumber = (max: number) =>\n Math.floor(Math.random() * Math.floor(max));\n\nconst randomNextSeries = (numSeries: number) => {\n const rand = randomNumber(numSeries * 6);\n return (rand >= numSeries) ? 0 : rand;\n};\n\n\nconst prevToonState = (state: BeartoonGalleryState) => {\n if (state.currentSeries > 0 && state.currentToonIndex - 1 >= 0) {\n return {\n ...state,\n currentToonIndex: state.currentToonIndex - 1,\n };\n } else {\n return {...state};\n }\n};\n\nconst nextToonState = (state: BeartoonGalleryState) => {\n const currentSeries = state.series.get(state.currentSeries);\n const maxToons = currentSeries.beartoons.length;\n const numSeries = state.series.size - 1; // subtract for \"no series\" at index 0\n\n // prevent infinite loops if all have been cycled\n if (state.visitedSeriesIds.length >= numSeries -1 && state.visitedUnseriesedToons >= state.series.get(0).size) {\n return {\n ...state,\n currentSeries: 0,\n currentToonIndex: 0,\n visitedSeriesIds: [],\n visitedUnseriesedToons: [],\n previous: {\n series: state.currentSeries,\n sequence: state.currentToonIndex,\n },\n }\n }\n\n if (state.currentSeries === 0 || (state.currentSeries > 0 && state.currentToonIndex + 1 >= maxToons)) {\n\n let nextSeries = randomNextSeries(numSeries);\n if (state.visitedSeriesIds.length >= numSeries -1) {\n nextSeries = 0;\n } else {\n while (state.visitedSeriesIds.length < numSeries && _.includes(state.visitedSeriesIds, nextSeries)) {\n nextSeries = randomNextSeries(numSeries);\n }\n }\n\n let nextToon = randomNumber(maxToons);\n if (nextSeries === 0) {\n while (state.visitedUnseriesedToons.length < maxToons && _.includes(state.visitedUnseriesedToons, nextToon)) {\n const unseriesed = state.series.get(0);\n nextToon = randomNumber(unseriesed.beartoons.length);\n }\n } else {\n nextToon = 0;\n }\n\n let updatedSeriesIds = state.visitedSeriesIds;\n let updatedUnseriesedToons = state.visitedUnseriesedToons;\n if (nextSeries === 0) {\n updatedUnseriesedToons = state.visitedUnseriesedToons.concat([state.currentToonIndex]);\n } else {\n updatedSeriesIds = state.visitedSeriesIds.concat([nextSeries]);\n }\n\n return {\n ...state,\n currentSeries: nextSeries,\n currentToonIndex: nextToon,\n visitedSeriesIds: updatedSeriesIds,\n visitedUnseriesedToons: updatedUnseriesedToons,\n previous: {\n series: state.currentSeries,\n sequence: state.currentToonIndex,\n },\n };\n } else if (state.currentToonIndex + 1 < maxToons) {\n return {\n ...state,\n currentToonIndex: state.currentToonIndex + 1,\n previous: {\n series: state.currentSeries,\n sequence: state.currentToonIndex,\n },\n };\n } else {\n const visitedSeries = (state.currentSeries > 0) ? [state.currentSeries] : [];\n\n const numSeries = state.series.size;\n\n let nextSeries = randomNextSeries(numSeries);\n while (state.visitedSeriesIds.length < numSeries && _.includes(state.visitedSeriesIds, nextSeries)) {\n nextSeries = randomNextSeries(numSeries);\n }\n return {\n ...state,\n currentSeries: nextSeries,\n currentToonIndex: 0,\n visitedSeriesIds: state.visitedSeriesIds.concat(visitedSeries),\n previous: {\n series: state.currentSeries,\n sequence: state.currentToonIndex,\n },\n };\n }\n};\n\nconst hasPreviousToon = (state: BeartoonGalleryState) => {\n return (state.currentSeries > 0 && state.currentToonIndex - 1 >= 0);\n};\n\nconst hasNextToon = (state: BeartoonGalleryState) => {\n if (state.currentSeries > 0) {\n const currentSeries = state.series.get(state.currentSeries);\n const maxToons = currentSeries.beartoons.length;\n return (state.currentToonIndex + 1 < maxToons);\n } else {\n return false;\n }\n};\n\nconst renderSeriesTitle = (state: BeartoonGalleryState) => {\n if (!state.series.size) return ();\n const series = state.series.get(state.currentSeries);\n const currentToon = state.series.get(state.currentSeries).beartoons[state.currentToonIndex];\n return state.currentSeries > 0 && series\n ? ({dayjs(series.created).format('MMM DD, \\'YY')} {series.title})\n : ({dayjs(currentToon.created).format('MMM DD, \\'YY')});\n};\n\n// @ts-ignore\nconst BeartoonComponent = ({series, current}) => {\n if (!series) return null;\n return (\n
\n
\n
\n {series.beartoons[current].caption}\n\n
\n
\n
\n {series.beartoons[current].caption}\n
\n
\n );\n}\n\nconst getFirstSeriesAndToon = (seriesMap: Map, beartoons: Beartoon[]): any => {\n if (!seriesMap.size || !beartoons.length) return { firstSeries: -1, firstToon: -1 };\n const sortedByCreated = _.orderBy(beartoons, ['created'], ['desc']);\n const latest = _.head(sortedByCreated);\n\n let latestSeries = 0, latestBeartoon = 0;\n if (latest && latest.series) {\n latestSeries = latest.series;\n } else {\n // @ts-ignore\n const unseriesed = seriesMap.get(0).beartoons;\n // @ts-ignore\n latestBeartoon = _.findIndex(unseriesed, t => t.id === latest.id);\n }\n\n return {\n series: latestSeries,\n beartoon: latestBeartoon,\n }\n}\n\nconst BeartoonGallery = () => {\n let [state, setState] = useState(initialState);\n\n useEffect(() => {\n if (!state.loading) {\n if (!state.loaded) {\n setState({\n ...state,\n loading: true,\n loaded: false,\n })\n\n Promise.all([\n fetchBeartoons(),\n fetchSeries()\n ]).then((res: any[]) => {\n const bs = res[0];\n const ss = res[1];\n\n const seriesMap = mapSeriesState(ss, bs);\n\n const first = getFirstSeriesAndToon(seriesMap, bs);\n\n setState({\n ...state,\n loading: false,\n loaded: true,\n series: seriesMap,\n currentToonIndex: first.beartoon,\n currentSeries: first.series,\n visitedSeriesIds: first.series > 0 ? [first.series] : [],\n visitedUnseriesedToons: [],\n previous: {\n series: first.series,\n sequence: first.beartoon,\n },\n })\n }).catch((err) => {\n console.error('ERROR', err);\n });\n }\n }\n }\n ,\n [state]\n );\n\n return (\n
\n
\n
\n
\n \n
\n
\n \n
\n
\n\n
\n
\n {renderSeriesTitle(state)}\n
\n
 
\n
\n {state.currentSeries > 0 && state.series.get(state.currentSeries) && (\n \n {state.currentToonIndex + 1} /\n {state.series.get(state.currentSeries).beartoons.length}\n \n )}\n
\n\n
\n \n
\n\n
\n );\n}\n\nexport default BeartoonGallery;","import React from 'react';\nimport {\n HashRouter as Router,\n Switch,\n Redirect,\n Route,\n} from 'react-router-dom';\n\nimport BearwaveHeader from \"./components/header/Header\";\nimport AppsComponent from \"./components/appsComponent/AppsComponent\";\nimport TechComponent from \"./components/tech/TechComponent\";\nimport BeartoonGallery from \"./components/gallery/BeartoonGallery\";\n\nimport './App.css';\n\nfunction App() {\n return (\n \n
\n \n \n \n \n \n \n \n
\n
\n );\n}\n\nexport default App;\n","import { ReportHandler } from 'web-vitals';\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\nimport reportWebVitals from './reportWebVitals';\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"sourceRoot":""}