πΎ Workshop project β Test JavaScript app
https://marlucz.github.io/warsawjs-workshop-43-online-store/
Project based on:
- https://github.com/piecioshka/boilerplate-babel-webpack
- https://github.com/piecioshka/boilerplate-husky-lint-staged-prettier
- https://github.com/piecioshka/test-jest-typescript
- https://github.com/piecioshka/test-jasmine-babel
- β Tooling: Prettier + Jest + http-server
- β Modules (4: IIFE, AMD, CommonJS, ESM)
- β Classes
- β Tooling: Webpack + webpack-dev-server
- β Promise API
- β Fetch API
- β RegExp
- Prettier
- lint-staged + husky
- https://github.com/piecioshka/boilerplate-husky-lint-staged-prettier
- Jest
- How to start test runner?
- http-server
- Test app in browser
- IIFE, 1999
- CommonJS, 2009
- AMD, 2010
- ECMAScript Module, 2015
- [ES2015]
Object.assign
vsSpread Operator
- Transpile Spread
- Webpack
- webpack-dev-server
- [Functions] Create function which will be a component constructor
- [Class] Convert previous function to a class
- File:
src/components/component.js
- Requirements:
- Component could be render
- Component should have a template
- File:
- [Class][getter]
- Requirements:
- Template should be a field which can be only "get"
- Requirements:
- [Class][static]
- Requirements:
- Product should have image inside
- Requirements:
- [Class][extends] Create component: Product
- File:
src/components/product.js
- Requirements:
- It should have class "product" on top of the DOM
- File:
- [Class][super] Create component: Cart
- File:
src/components/cart.js
- Requirements:
- This module should have a list of products (initial empty)
- File:
- [Loop] Iteration through list of products
- [Promise.resolve]
- Adding product should based on Promise
- [Promise.reject]
- Adding non-product should finish failure
- [Async/await]
- Display Toast when Product will be added to Cart
- Install
node-snackbar
form npm registry - https://www.polonel.com/snackbar/
- Error handling:
try...catch
- [window.fetch]
- new [Response]
- [isomorphic-fetch]
- Dummy
- https://fakes.herokuapp.com/products
- Tasks
- When Product name has "er" string, do not add it to Cart and display Toast with error message
- [RegExp#test]
- Parts:
- [Quantifiers]:
*
,+
,?
,{n}
- [Matchers]:
.
,\w
,\d
,\n
- [Quantifiers]:
- https://regex101.com/
npm run build # generate dist/
npm run watch # generate dist/ & listen for changes
npm run dev # do not generate anything & listen for changes
npm test
npm test -- test/specs/XX # XX => 01...05
npm run coverage
Contributions, issues and feature requests are welcome!
Feel free to check issues page.
Give a βοΈ if this project helped you!
- https://github.com/piecioshka/workshop-angular-youtube
- https://github.com/piecioshka/workshop-javascript-prework-lotto
- https://github.com/piecioshka/workshop-javascript-prework-printer
- https://github.com/piecioshka/workshop-javascript-prework-static-page
- https://github.com/piecioshka/workshop-javascript-prework-counter
- https://github.com/piecioshka/warsawjs-workshop-1-gallery
- https://github.com/piecioshka/warsawjs-workshop-1-carousel
- https://github.com/piecioshka/warsawjs-workshop-2-blog
- https://github.com/piecioshka/warsawjs-workshop-3-online-shop
- https://github.com/piecioshka/warsawjs-workshop-7-webcomponents
- https://github.com/piecioshka/warsawjs-workshop-12-quiz
- https://github.com/piecioshka/warsawjs-workshop-18-topics-manager
- https://github.com/piecioshka/warsawjs-workshop-19-portfolio
- https://github.com/piecioshka/warsawjs-workshop-22-unit-tests
- https://github.com/piecioshka/warsawjs-workshop-24-admin-panel
- https://github.com/piecioshka/warsawjs-workshop-25-myskills
- https://github.com/piecioshka/warsawjs-workshop-26-my-photos
- https://github.com/piecioshka/warsawjs-workshop-27-prime-sum
- https://github.com/piecioshka/warsawjs-workshop-28-pwa
- https://github.com/piecioshka/warsawjs-workshop-31-calendar
- https://github.com/piecioshka/warsawjs-workshop-33-twitter
- https://github.com/piecioshka/warsawjs-workshop-34-trainer-needed
- https://github.com/piecioshka/warsawjs-workshop-35-legacy-code
- https://github.com/piecioshka/warsawjs-workshop-37-shop
- https://github.com/piecioshka/warsawjs-workshop-40-security
- https://github.com/piecioshka/warsawjs-workshop-41-gallery
The MIT License @ 2020