Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/0xabdulkhaliq/advice-generator
This is a solution to the "Advice generator" challenge on Frontend Mentor
https://github.com/0xabdulkhaliq/advice-generator
css3 es6-modules html5 javascript pagespeed-insights vercel webpack
Last synced: about 2 months ago
JSON representation
This is a solution to the "Advice generator" challenge on Frontend Mentor
- Host: GitHub
- URL: https://github.com/0xabdulkhaliq/advice-generator
- Owner: 0xabdulkhaliq
- License: mit
- Created: 2023-09-23T11:39:07.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-15T04:03:41.000Z (over 1 year ago)
- Last Synced: 2024-11-08T11:23:33.571Z (3 months ago)
- Topics: css3, es6-modules, html5, javascript, pagespeed-insights, vercel, webpack
- Language: CSS
- Homepage: https://advice-generator-0xabdulkhalid.vercel.app/
- Size: 206 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Preview
![]()
## Links
- |||
| :----- | :----- |
| Solution URL: | [ADVICE GENERATOR 🎯 [ ASYNC/AWAIT - ES6 MODULES - WEBPACK - 3D DICE ]](https://www.frontendmentor.io/solutions/advice-generator-asyncawait-es6-modules-webpack-3d-dice-kW5sm9EPZa) |
| Live Site URL: | [https://advice-generator-0xabdulkhalid.vercel.app/](https://advice-generator-0xabdulkhalid.vercel.app/) |
|||
## Pagespeed Insights Score
- ||
| :-----: |
| Overall Score 99.3%, Average of Mobile and Desktop
[ Mobile devices score is only shown below ] |
| |
||
| |
| Check out [**Pagespeed Insights**](https://pagespeed.web.dev/analysis/https-advice-generator-0xabdulkhalid-vercel-app/ne163fkmse?form_factor=mobile) to get live score |
||
## The Challenge
- Users should be able to:
- View the optimal layout for the app depending on their device's screen size
- See hover states for all interactive elements on the page
- Generate a new piece of advice by clicking the dice icon
## Installation
To set up the Advice Generator Application locally, follow these steps:
1. Clone the GitHub repository to your local machine:
```bash
git clone https://github.com/0xabdulkhalid/advice-generator.git
```2. Navigate to the project's directory:
```bash
cd advice-generator
```3. Install the project's dependencies using npm:
```bash
npm install
```4. Build the project to bundle JavaScript, minify HTML and CSS, and move images:
```bash
npm run build
```
5. The build files can be found on `dist` (distribution) directory.
## Tags
ES6 Modules | Webpack Bundling | API Integration | Cross-Browser Compatibility | Responsive Design | Code Formatting Guidelines | Automated Deployment with Vercel
## Learnings / Notes
- Finded a manual way for trigger/invoke click event for button element by creating a new `MouseEvent` object of type `"click"` and dispatch it on the button element using the `dispatchEvent` method.
- This will simulate a click on the button, and any event listeners attached to it will be triggered as if the button were clicked by the user.
- I have implemented this feature for initializing advice feed once the user visits/open the app.- Learned to create a 3D Dice by using multiple `div` elements for Dice face along with `preserve-3d`.
- Each one uses the transform property to rotate or translate the face in 3D space, giving the illusion of a 3D object.
- It also applies the dice-spin animation, which presumably spins the dice, the overall result is wonderfull!
## Built With
data:image/s3,"s3://crabby-images/f421b/f421bc75622181f3e81e7d7220d7a745e106bf2d" alt="HTML5" data:image/s3,"s3://crabby-images/a8228/a822824c643ee209b7c820ef84a89b676b54fe9d" alt="CSS3" data:image/s3,"s3://crabby-images/b842a/b842aa76e4ab96cbb76c769791d98a16bd206e25" alt="JavaScript" data:image/s3,"s3://crabby-images/f5978/f5978d98c8063b01c5415119f8b4998370088b99" alt="Webpack" data:image/s3,"s3://crabby-images/7e130/7e130800678b1de7301d43003138522e35099422" alt="html-minifier" data:image/s3,"s3://crabby-images/e3ff6/e3ff69c6229cad8e9c6f9901278d0239a566bf7a" alt="CSS3"
## Tools Used
data:image/s3,"s3://crabby-images/b6508/b6508860fc674f839cce9a2a56f71a0ad15d72b4" alt="NPM" data:image/s3,"s3://crabby-images/921aa/921aa290a16be40f91f64012a4656f8d438551e2" alt="Google" data:image/s3,"s3://crabby-images/354a9/354a98c782c1ffeed329fba79932c4a6266e747f" alt="Prettier" data:image/s3,"s3://crabby-images/7abc7/7abc752908762d591196abaa207a5909679f5960" alt="Eslint" data:image/s3,"s3://crabby-images/254b2/254b23feeb32fa3f101ddd417916e2ca74cedbd3" alt="Visual Studio Code" data:image/s3,"s3://crabby-images/b5541/b5541e836a0013e605381a79353fe8b58cb5adf8" alt="Git"
## Acknowledgment
- Challenge was provided by [Frontend Mentor](https://www.frontendmentor.io)
## Let's Connect 👋