Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rhyuen/listsofdata

Just a react site that filters data from a JSON file.
https://github.com/rhyuen/listsofdata

babel chartjs reactjs static styled-components typescript webpack

Last synced: about 2 months ago
JSON representation

Just a react site that filters data from a JSON file.

Awesome Lists containing this project

README

        

[![CircleCI](https://circleci.com/gh/rhyuen/listsofdata.svg?style=svg)](https://circleci.com/gh/rhyuen/listsofdata)

# ABOUT

Just some react stuff with data in it.

A project that I ended up sticking with despite, initially, having written it in a manner that suggested the opposite.

**JUNE 22, 2020**
Added Test for Submit form.

**MR 10, 2020**
Added a disclaimer to the 'Explore' Tab so people know what I'm counting: pushups. Yes, it's conceited and kind of silly.

**FEBRUARY 20, 2020**

Updated favicon to pixel art letter instead of an MSPaint image.

Attempting to add a CircleCI badge to the README.md

**JANUARY 7, 2020**

Added a footer with scroll to top on click.

**JANUARY 1, 2020**

---

I was looking to implement an abstraction for external services I wanted to hit and implmenting them in the following directory `./src/services/externalService.ts`.

Code is as follows:

```javascript
export const getExternalService = async () => {
return axios.get("externalServiceURL");
};

React.useEffect(() => {
getExternalService()
.then()
.catch();
});
```

I ended up getting this error called `regeneratorRuntime is not defined` or something to that effect. I found the solution [here]("https://stackoverflow.com/a/58432338")

I was tripped up on this in the past (probably more than once) and found a way around it by not using the solution provided.

The solution provided is fairly simple. There's only two steps!

1. \$ npm install @babel/polyfill
2. import "@babel/polyfill"; at the Root of your React App.

**OCTOBER 7, 2019**:

---

_TS2339: Type error when trying to call Object.values(targetObject)._

> I got an error when trying to pull the values into an array out of object. MDN says you can [here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_objects/Object/values). However, it turns out it wasn't added until es2017 and if your `tsconfig.json` was not configured to account for that then typescript will flag that method call as a type error. It can be resolved by appending "es2017" to the "compilerOptions"."lib" array as denoted below:

```json
"compilerOptions": {
"lib": ["es2017"]
}
```

The solution was found [here](https://stackoverflow.com/a/42967397).

**OCTOBER 4, 2019**:

---

_TS2362: Error when doing arithmetic operations on dates._

> I got an error whilst doing math using `Date` objects. I used [this](https://github.com/microsoft/TypeScript/issues/5710) as a reference. I ended up using the `+` operator in front of the new `Date` objects ( +new Date()). It made the type errors go away.

**JULY 10, 2019**:

---

_Things I've learned from trying Typescript:_

1. Sometimes `export default ComponentName` doesn't work. You need named exports.

2. Unfortunately, `React.lazy(() => import("./MyComponent"))` doesn't work well without default exports so you're forced to resort to weird looking things as follows: `javascript const Home = React.lazy(() => import("./Home").then(({ Home }) => ({ default: Home })));`

3. You can't or shouldn't use file extentions (.tsx|.ts) when importing relative files at the top of your components because when the code is transformed by babel or what not the extensions don't change with it and the code can't find itself.

4. Set "resolveJsonModule": true in `tsconfig.json` if you want to read in data from a JSON file.

5. Add "es2018.promise" to "lib": [] in the `tsconfig.json` if you want to use `.finally(()=>{})`. [Source](https://stackoverflow.com/questions/52079031/property-finally-does-not-exist-on-type-promisevoid)

6. There was some issue with Styled Components and Typescript such that there was an error with compilation. I resolved the issue by following the directions provided [here](https://stackoverflow.com/questions/52079031/property-finally-does-not-exist-on-type-promisevoid). I think edited `tsconfig.json` to have "types": []. With "node" contained within that array. Another solution was to set a field "skipLibCheck": true in `tsconfig.json` but the sentiment I got from reading the comments suggested that was subideal.

**JULY 3, 2019: Adding Typescript.**

**JUNE 28, 2019**:

Currently wondering if it is a bad idea to integrate typescript into this because technology fads/trends.