Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/jdvlpr/temperature-blanket-web-app

๐ŸŒค๏ธ Weather Data + ๐Ÿงถ Art! Get historical weather data, choose yarn colors, and visualize your crochet or knitting project.
https://github.com/jdvlpr/temperature-blanket-web-app

blanket crafting crochet fiber-arts knitting temperature-blanket weather weather-data yarn

Last synced: 3 months ago
JSON representation

๐ŸŒค๏ธ Weather Data + ๐Ÿงถ Art! Get historical weather data, choose yarn colors, and visualize your crochet or knitting project.

Awesome Lists containing this project

README

        

Temperature Blanket Website Logo

### ๐ŸŒค๏ธ Weather Data + ๐Ÿงถ Art!

Website: **[temperature-blanket.com](https://temperature-blanket.com)**

Visualize your city's historical climate data, create color gauges, and preview your pattern for your crochet or knitting temperature project. Save your project in your browser and as a URL, and download project information in PDF, CSV, and PNG files.

Built with:

- [Sveltekit](https://github.com/sveltejs/kit)
- [Tailwind](https://github.com/tailwindlabs/tailwindcss)
- [Skeleton](https://github.com/skeletonlabs/skeleton)
- And [more...](package.json)

> ๐Ÿšง Note: Some of the codebase lacks documentation. I plan to update and refactor code as needed.

## ๐Ÿš€ Getting Started

To run this site locally on your computer for development, [clone this repository](https://docs.github.com/en/repositories/creating-and-managing-repositories/cloning-a-repository) and create a `.env` file. Additionally, in order for certain features to work you'll need to register for some free API services.

> ๐Ÿ’ก [Node.js](https://nodejs.org/en/download/package-manager) must be installed on your machine.

1. Copy the [.env.example](.env.example) file to a new file named `.env` in the root directory of your project.

2. For the location search features to work, [register for a free GeoNames username](http://www.geonames.org/login). You will then receive an email with a confirmation link and after you have confirmed the email you can enable your account for the webservice on [your account page](http://www.geonames.org/manageaccount). In your `.env` file, set `SECRET_GEONAMES_USERNAME` to your GeoNames username. The free plan gets 10,000 credits per month.

3. For the Meteostat weather data features to work, [sign up for the free Meteostat Base plan through RapidAPI](https://rapidapi.com/meteostat/api/meteostat/pricing). In your `.env` file, set `SECRET_METEOSTAT_API_KEY` to your key from RapidAPI. The free Base plan gets 500 requests per month.

## ๐Ÿ› ๏ธ Developing

Install dependencies:

```bash
npm install
```

Start a development server:

```bash
npm run dev
```

### โœ… Testing

First build the app (to generate cloudflare \_routes.json file)

```bash
npm run build
```

Test frontend pages and functions

```bash
npm run test
```

Test internal api routes (for the Yarn Colorways API)

```bash
npm run test:api
```

## ๐Ÿ™Œ Acknowledgments

Thanks for the support and feedback from users like you!

Temperature-blanket.com gets data from several APIs:

- **[GeoNames](https://www.geonames.org/)** for location data

- **[Open-Meteo](https://open-meteo.com)** for weather data

- **[Meteostat](https://meteostat.net)** for weather data

# ๐Ÿ“š Documentation & Notes

### ๐Ÿ—„๏ธ Database

Temperature-blanket.com uses a backend database in the form of a headless Wordpress site on a separate domain to store user-created gallery pages.

View Details

> โ„น๏ธ The information below is intended for documentation only. You can test and develop this project locally without setting up your own backend database.

Here are the steps for setting up the headless Wordpress site:

- Install Wordpress on a separate domain.
- I use the following plugins
- [EWWW Image Optimizer](https://wordpress.org/plugins/ewww-image-optimizer/) - To compress and optimize project preview images
- [Redirection](https://wordpress.org/plugins/redirection/) - To redirect the headless Wordpress home page to the temperature-blanket.com site, and to redirect project pages to their corresponding gallery pages on temperature-blanket.com.
- Temperature Blanket Custom Plugin - I created a Wordpress plugin which handles the necessary setup and allows for creation of project gallery pages through a custom REST endpoint.
- [Wordfence](https://wordpress.org/plugins/wordfence/) - For general site security
- [Wordpress Popular Posts](https://wordpress.org/plugins/wordpress-popular-posts/) - For tracking popular projects
- [WP-GraphQL](https://wordpress.org/plugins/wp-graphql/) - For interacting with the Wordpress backend
- Add the following line to `wp-config.php`:

```
define('PROJECT_CREATION_AUTH_KEY', 'auth_key');
```

- In this project's `.env` file, `SECRET_WORDPRESS_PROJECT_CREATION_AUTH_KEY` should be the same `'auth_key'` value. Without the correct auth key, the Wordpress site won't accept POST requests for new project gallery pages.

> ๐Ÿ’ก When developing locally, POST requests to create new temperature blanket project gallery pages will be rejected. This is normal, because you don't have the necessary authentication key.

### ๐Ÿ’พ Local Storage

Various site settings and data are stored in the browser.

View Details

| Key Name | Description | Default Value | Possible Values | Version Added\* |
| ----------------------- | --------------------------------------------------------------------------- | ------------- | ------------------------------------------------------------------------------------------------------- | --------------- |
| skeletonTheme | The theme for the site | `"classic"` | `"classic"` or one of the presets in plugins.themes.presets in [tailwind.config.js](tailwind.config.js) | < 3.28.3 |
| theme | Whether to use the light or dark version of the theme, or follow the system | `"light"` | `"light"`, `"dark"`, `"system"` | < 3.28.3 |
| layout | How to display groups of items | `list` | `list`, `grid` | < 3.28.3 |
| projects | Projects the user has saved | `[]` | array of [`SavedProject`](src/lib/types/project-types.d.ts) objects | < 3.28.3 |
| disable_toast_analytics | Weather to always hide the notification about analytics | `false` | `true`, `false` | 3.28.3 |
| [/weather]units | Units for the weather forecast page | `imperial` | `imperial`, `metric` | < 3.28.3 |
| [/weather]hour_format | Time format for the weather forecast page | `12` | `12`, `24` | < 3.28.3 |
| [/weather]locations | Locations the user has added for the weather forecast page | `[]` | array of [`Location`](src/lib/types/location-types.d.ts) objects | < 3.28.3 |

_\*Items with a < before the version means sometime before that version, I'm not sure exactly when because I wasn't keeping track before version 3.28.3._