Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mwarman/ionic8-playground
A playground application for Ionic 8 with React.
https://github.com/mwarman/ionic8-playground
ionic react typescript
Last synced: 3 months ago
JSON representation
A playground application for Ionic 8 with React.
- Host: GitHub
- URL: https://github.com/mwarman/ionic8-playground
- Owner: mwarman
- License: mit
- Created: 2024-06-25T16:50:26.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-09-25T15:30:59.000Z (4 months ago)
- Last Synced: 2024-09-25T15:36:18.048Z (4 months ago)
- Topics: ionic, react, typescript
- Language: TypeScript
- Homepage:
- Size: 1.31 MB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Ionic 8 Playground
A playground project for Ionic 8 with React.
[![CI](https://github.com/mwarman/ionic8-playground/actions/workflows/ci.yml/badge.svg)](https://github.com/mwarman/ionic8-playground/actions/workflows/ci.yml)
## Helpful Hints
### Data
This project's API integration uses the simulated REST endpoints made available by [JSON Placeholder](https://jsonplaceholder.typicode.com/).
### Authentication
When running the application, you may sign in with any of the JSON Placeholder [Users](https://jsonplaceholder.typicode.com/users). Simply enter the _Username_ value from any user in the API and use any value for the _Password_. For example, try username `Bret` and password `abc123`.
### Diagnostics
Many applications, particularly mobile applications, have a hidden page which displays content useful for troubleshooting and support. To access the diagnostics page, go to the _Account_ page. Locate the _About_ section and click or tap the _Version_ item 7 times.
## About
This project was bootstrapped with the [Ionic CLI](https://ionicframework.com/docs/cli/commands/start).
```
ionic start ionic8-playground blank --type=react
```The technology stack includes:
- Ionic - the foundation
- Vite - React development environment
- React - SPA framework
- React Router Dom - routing
- TanStack React Query - data manipulation and caching
- Axios - http client
- Formik - form management
- Yup - validation
- Lodash - utility functions
- DayJS - date utility functions
- Testing Library React - tests
- Vitest - tests
- MSW - API mocking
- TypeScript### Repository
This repository uses [trunk-based development](https://www.atlassian.com/continuous-delivery/continuous-integration/trunk-based-development). The latest code is located on the `main` branch. The `main` branch is always ready for deployment.
Features are developed on branches named `feature/NNNNN` which are created from the `main` branch. The feature name used in the branch contains an issue identifier or a short name, e.g. `feature/123-do-something`.
Releases are created on branches named `release/MM.mm.pp` which are created from the `main` branch. The release name follows the [semantic versioning](https://semver.org/) specification.
Hotfixes are created on branches named `release/MM.mm.pp` which are created from the appropriate `release/MM.mm.pp` branch.
A pull request must be opened requesting merge from any branch back to `main`. GitHub actions perform continuous integration, CI, checks against the PR source branch. At least one code review approval is required to complete the pull request.
See also: [Feature flags](https://www.atlassian.com/continuous-delivery/principles/feature-flags)
### Issue Management
This project uses [GitHub Issues](https://github.com/mwarman/ionic8-playground/issues).
### Code Formatting
The project includes a configuration file for the [Prettier](https://prettier.io/docs/en/configuration.html) code formatter. This allows all project contributors to share the same code formatting rules.
Adjust the Prettier configuration as desired.
## Installation
### Prerequistes
It is strongly recommended that you install Node Version Manager, [`nvm`][nvm]. Node Version Manager simplifies working on multiple projects with different versions of Node.js.
### Clone the Repository
Open the [repository][repo] in a browser. Follow the instructions to clone the repository to your local machine.
### Install Node
Open a terminal window and navigate to the project base directory. Issue the following command to install the version of Node and NPM used by the application:
```bash
# If you already have this version of Node, simply switch to it...
nvm use# If you do NOT have this version of Node, install it...
nvm install
```Node Version Manager inspects the `.nvmrc` file in the project base directory and uses or installs the specified version of Node and the Node Package Manager, npm.
### Install the Dependencies
To install the project dependencies, issue the following commands at a terminal prompt in the project base directory:
```bash
# Switch to the project node version...
nvm use# Install project dependencies
npm install
```### After Installation
The installation is now complete! You may open the project in your favorite source code editor (we recommend [Visual Studio Code](https://code.visualstudio.com/)).
We recommend the following VS Code extensions:
- Prettier - Code formatter (required)
- ESLint - Source code analysis (strongly recommended)
- Ionic (optional)
- Indent Rainbow (optional)
- GitLens (optional)
- Dotenv Official +Vault (optional)
- GitHub Actions (optional)Install the _Prettier_ extension to ensure that all project participants' contributions are formatted using the same rules. The extension leverages project-specific rules found in the `.prettierrc` file in the project base directory.
## Configuration
The application is configured using Environment Variables. Because single-page applications are static, environment variable values are injected into the application during the build. The environment variables may be sourced from the environment or `.env` files as described in the [Vite documentation](https://vitejs.dev/guide/env-and-mode.html).
> **NOTE:** Ionic Config provides a way to change the properties of Ionic components globally. This is different from application configuration. See the [Ionic Config](https://ionicframework.com/docs/developing/config) docs for more details.
### `.env` files
> **NOTE:** Because they may contain sensitive information, `.env` files are not committed to the repository.
> **TIP:** When configuration values are modified, notify your DevOps team to modify the values in automation pipelines accordingly.
After project installation and before running the application locally, create the following `.env` files in the project base directory. Learn more in the official [Vite guide for environment variables and modes](https://vitejs.dev/guide/env-and-mode.html).
#### `.env.local`
The `.env.local` configuration file provides the configuration values when the application is started on a developer's local machine.
```
# Provided by Pipeline (Simulated)
VITE_BUILD_DATE=1970-01-01
VITE_BUILD_TIME=00:00:00
VITE_BUILD_TS=1970-01-01T00:00:00+0000
VITE_BUILD_COMMIT_SHA=local
VITE_BUILD_ENV_CODE=local
VITE_BUILD_WORKFLOW_NAME=local
VITE_BUILD_WORKFLOW_RUN_NUMBER=1
VITE_BUILD_WORKFLOW_RUN_ATTEMPT=1# API Configuration
VITE_BASE_URL_API=https://jsonplaceholder.typicode.com# Toasts Configuration
VITE_TOAST_AUTO_DISMISS_MILLIS=5000
```#### `.env.test.local`
The `.env.test.local` configuration file provides configuration values used when tests are executed on a developer's local machine.
> **NOTE:** Use the same values when running tests in a CI/CD pipeline.
```
# Provided by Pipeline (Simulated)
VITE_BUILD_DATE=1970-01-01
VITE_BUILD_TIME=00:00:00
VITE_BUILD_TS=1970-01-01T00:00:00+0000
VITE_BUILD_COMMIT_SHA=test
VITE_BUILD_ENV_CODE=test
VITE_BUILD_WORKFLOW_NAME=test
VITE_BUILD_WORKFLOW_RUN_NUMBER=1
VITE_BUILD_WORKFLOW_RUN_ATTEMPT=1# API Configuration
VITE_BASE_URL_API=https://jsonplaceholder.typicode.com# Toasts Configuration
VITE_TOAST_AUTO_DISMISS_MILLIS=1500
```# Available Scripts
Many of the scripts leverage the [Ionic CLI](https://ionicframework.com/docs/cli), the [Vite CLI](https://vitejs.dev/guide/cli.html), or the [Vitest CLI](https://vitest.dev/guide/cli.html). Read more about them in their respective official guides.
In the project base directory, the following commands are available to run.
### `npm run dev`
Runs the app in the development mode.
Open [http://localhost:5173](http://localhost:5173) to view it in the browser.The page will reload if you make edits.
### `npm test`
Launches the test runner in the interactive watch mode.
See the section about [running tests](https://vitest.dev/guide/cli.html) for more information.### `npm run test:coverage`
Runs the test suites once and produces a coverage report. A detailed test coverage report is created in the `./coverage` directory.
### `npm run test:ci`
Executes the test runner in `CI` mode and produces a coverage report. With `CI` mode enabled, the test runner executes all tests one time and prints a summary report to the console. A code coverage report is printed to the console immediately following the test summary.
A detailed test coverage report is created in the `./coverage` directory.
> **NOTE:** This is the command which should be utilized by CI/CD platforms.
### `npm run test:e2e`
Runs all end-to-end (e2e) tests using the Cypress framework. See the [Cypress CLI](https://docs.cypress.io/guides/guides/command-line) documentation for more information.
### `npm run build`
Builds the app for production to the `dist` folder.
It correctly bundles in production mode and optimizes the build for the best performance.See the official guide for more information about [building for production](https://vitejs.dev/guide/build.html) and [deploying a static site](https://vitejs.dev/guide/static-deploy.html).
### `npm run lint`
Runs the [ESLint][eslint] static code analysis and prints the results to the console.
## DevOps
### Cloud Resources
The AWS resources for this application component are provisioned via AWS CloudFormation. The `template.yml` file is the CloudFormation template.
The resources provisioned are:
| Resource | Description |
| ----------------------- | ----------------------------------------------------------------------------- |
| S3 Bucket | Contains the published application. |
| S3 Bucket Policy | Provides access to the S3 Bucket from AWS CloudFront. |
| CloudFront Distribution | A CloudFront distribution to serve the SPA application. |
| CloudFront Distribution | A CloudFront distribution to serve the full-stack application (UI, API, etc). |
| Route53 RecordSet | An `A` record for the application distribution. |
| Route53 RecordSet | An `AAAA` record for the application distribution. |### CI/CD Pipelines
This project uses GitHub Actions to perform DevOps automation activities such as Continuous Integration and Continous Deployment. See all project [GitHub Actions workflow runs](https://github.com/mwarman/ionic8-playground/actions).
| Workflow | Trigger | Description |
| --------------------- | ------------------------------ | ------------------------------------------------------------------------------------ |
| CI | Pull Request for `main` branch | Builds, lints, and tests the application. Validates the AWS CloudFormation template. |
| Deploy to Development | Push to `main` branch | Deploys AWS CloudFormation stack. Builds and deploys the application. |
| Deploy to QA | Push to `release/*` branch | Deploys AWS CloudFormation stack. Builds and deploys the application. |
| Deploy to Production | Publish a Release | Deploys AWS CloudFormation stack. Builds and deploys the application. |## Related Information
- [Ionic][ionic]
- [Vite][vite]
- [React][react]
- [TanStack][tanstack]
- [Axios][axios]
- [Formik][formik]
- [Yup][yup]
- [Testing Library][testing-library]
- [Vitest][vitest]
- [Cypress][cypress]
- [ESLint][eslint]
- [GitHub Actions][ghactions][repo]: https://github.com/mwarman/ionic8-playground 'GitHub Repository'
[nvm]: https://github.com/nvm-sh/nvm 'Node Version Manager'
[ionic]: https://ionicframework.com/docs/react 'Ionic with React'
[vite]: https://vitejs.dev/ 'Vite'
[react]: https://react.dev/ 'React'
[axios]: https://axios-http.com/ 'Axios'
[formik]: https://formik.org/ 'Formik'
[yup]: https://github.com/jquense/yup 'Yup'
[tanstack]: https://tanstack.com/ 'TanStack'
[testing-library]: https://testing-library.com/ 'Testing Library'
[vitest]: https://vitest.dev/ 'Vitest Testing Framework'
[ghactions]: https://docs.github.com/en/actions 'GitHub Actions'
[eslint]: https://eslint.org/docs/latest/ 'ESLint'
[cypress]: https://docs.cypress.io/guides/overview/why-cypress 'Cypress Testing Framework'