Skip to content

Commit

Permalink
Merge dev to main for site-ui-4-static Release
Browse files Browse the repository at this point in the history
  • Loading branch information
drbgfc authored Apr 4, 2024
2 parents d62a345 + 46c10bb commit 3ccf7a4
Show file tree
Hide file tree
Showing 192 changed files with 13,992 additions and 444 deletions.
6 changes: 5 additions & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
{
"extends": "next/core-web-vitals"
"plugins": ["@typescript-eslint"],
"extends": ["plugin:@typescript-eslint/recommended", "next/core-web-vitals", "prettier"],
"rules": {
"@typescript-eslint/no-unused-vars": 1
}
}
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -34,3 +34,6 @@ yarn-error.log*
# typescript
*.tsbuildinfo
next-env.d.ts

#node
.node-version
21 changes: 21 additions & 0 deletions .prettierrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{
"arrowParens": "always",
"bracketSameLine": false,
"bracketSpacing": true,
"semi": false,
"experimentalTernaries": false,
"singleQuote": true,
"jsxSingleQuote": false,
"quoteProps": "as-needed",
"trailingComma": "es5",
"singleAttributePerLine": false,
"htmlWhitespaceSensitivity": "css",
"vueIndentScriptAndStyle": false,
"proseWrap": "preserve",
"insertPragma": false,
"printWidth": 120,
"requirePragma": false,
"tabWidth": 2,
"useTabs": false,
"embeddedLanguageFormatting": "auto"
}
8 changes: 8 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll.eslint": "explicit"
},
"prettier.requireConfig": true
}
157 changes: 85 additions & 72 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,98 +1,111 @@
# SITE UI 4.0

## Project Overview
* SITE and ETT are being combined into one streamlined website which will be known as SITE 4.0. The functionality will remain similar, however, the user experience will be greatly improved. In addition, the frontend (and to some extent the backend) tech stack will be updated and unified, offering security, maintainability, and performance enhancements
* The Standards Implementation & Testing Environment (SITE) is a centralized collection of testing tools and resources designed to assist health IT developers and health IT users fully evaluate specific technical standards and maximize the potential of their health IT implementations

- SITE and ETT are being combined into one streamlined website which will be known as SITE 4.0. The functionality will remain similar, however, the user experience will be greatly improved. In addition, the frontend (and to some extent the backend) tech stack will be updated and unified, offering security, maintainability, and performance enhancements
- The Standards Implementation & Testing Environment (SITE) is a centralized collection of testing tools and resources designed to assist health IT developers and health IT users fully evaluate specific technical standards and maximize the potential of their health IT implementations

## Readme
* This document is designed to help get a general understanding of the app, some of our processes, understand how to set it up and run it, and effectively develop the application as a cohesive team
* Whether major or minor (including typos), please edit this document as you see fit for the benefit of the team

- This document is designed to help get a general understanding of the app, some of our processes, understand how to set it up and run it, and effectively develop the application as a cohesive team
- Whether major or minor (including typos), please edit this document as you see fit for the benefit of the team

## Development Process
* Please review the [Process document](https://github.com/onc-healthit/site-ett-docs/blob/main/site-ui-4-process.md)

- Please review the [Process document](https://github.com/onc-healthit/site-ett-docs/blob/main/site-ui-4-process.md)

## Stack
* Next.js 14
* React 18
* Typescript 5
* MUI 5
* CSS 3 (but mostly using React Styled Components)
* HTML 5
* Node.js 20

- Next.js 14
- React 18
- Typescript 5
- MUI 5
- CSS 3 (but mostly using React Styled Components)
- HTML 5
- Node.js 20

## Setup Requirements
* Install Node.js 20+ (latest LTS should work at this time)
* Suggest installing and managing versions with FNM (Fast Node Manager)
* Install yarn (latest)
* Suggest installing by running the following with admin privileges
* ```npm install yarn -g```

- Install Node.js 20+ (latest LTS should work at this time)
- Suggest installing and managing versions with FNM (Fast Node Manager)

## Installation
* Clone the repo
* Open in Visual Studio Code (preferred) or software of your choice
* Run yarn to install dependencies
* ```yarn```
* Run yarn dev to run the development server
* ```yarn dev```
* Open [http://localhost:3000](http://localhost:3000) with your browser to view the application

- Clone the repo
- Open in Visual Studio Code (preferred) or software of your choice
- Use npm to install dependencies
- `npm install`
- Use npm to run the development server
- `npm run dev`
- Open [http://localhost:3000](http://localhost:3000) with your browser to view the application

## Branches
* main
* This is the main branch on the project from which releases are made. Do not ever commit directly to this branch. The only time code should make its way to this branch is via a PR from dev
* dev
* This is the main development branch. We should strive to merge as often as possible to this branch (and pull as often as possible locally) to ensure minimal major merge conflicts
* In general we should create a PR to this branch but direct commits are also not out of the question. Especially if it's something minor, that way, we meet the first point
* Due to the small size of the team, forks are not required. Instead, we will make feature branches, or, alternate dev branches, on this remote repo. This will make it easier for us to share and work together simultaneously on code that is in progress. When you are ready to work, please create a branch off of dev, and label it like this
* Feature Branches
* firstName-branchDerivedFrom-feature
* e.g.
* dan-dev-nav
* Alternate dev Branches
* firstName-branchDerivedFrom
* e.g.
* dan-dev
* Note
* In rare situations, branching off of something other than dev may be helpful, hence the option, but, I can't imagine any reason why we should ever branch off of main for this project until it goes to true production

- main
- This is the main branch on the project from which releases are made. Do not ever commit directly to this branch. The only time code should make its way to this branch is via a PR from dev
- dev
- This is the main development branch. We should strive to merge as often as possible to this branch (and pull as often as possible locally) to ensure minimal major merge conflicts
- In general we should create a PR to this branch but direct commits are also not out of the question. Especially if it's something minor, that way, we meet the first point
- Due to the small size of the team, forks are not required. Instead, we will make feature branches, or, alternate dev branches, on this remote repo. This will make it easier for us to share and work together simultaneously on code that is in progress. When you are ready to work, please create a branch off of dev, and label it like this
- Feature Branches
- firstName-branchDerivedFrom-feature
- e.g.
- dan-dev-nav
- Alternate dev Branches
- firstName-branchDerivedFrom
- e.g.
- dan-dev
- Note
- In rare situations, branching off of something other than dev may be helpful, hence the option, but, I can't imagine any reason why we should ever branch off of main for this project until it goes to true production

## Environment Vars and Environment Management
* TODO

- TODO

## Coding Style
* TODO: Edit linter and create a VS Code config or otherwise so that style is automatically applied on save so that difs are only related to code and we have a consistent condebase
* For now:
* Do
* Keep line widths reasonable
* In general 2 files should be able to be read vertically on one (hi-res) monitor. Obviously this is vague, we will implement this via an automated style guide pushed to this repo
* Use types most of the time
* Use camelCase most of the time
* Use ```const``` when possible
* Use functional React components
* Use Next.js app routing
* Make function names highly descriptive of what they do
* Extract reusable code into functions as much as possible
* If code becomes too long, for clarity, extract it into separate functions, even if not reusable
* Be consistent
* Avoid
* Semicolons unless required for the code to work as intended
* ```var``` unless for some reason you need that level of scope, use ```let``` instead
* Class based React components
* Next.js pages routing

- Setup prettier, eslint for code formatting in VS Code(only works with VS Code). ( \*\*Note: The config setup has been completed, steps can be referenced from here https://www.franciscomoretti.com/blog/how-to-set-up-prettier-and-eslint-in-vs-code-for-next-js)
- Install ESLint VS Code Extension on VS Code
- Install Prettier VS Code Extension on VS Code
- Note: .prettierrc config file needs to exist in the repo for the formatting to work.
- For now:

- Do

- Keep line widths reasonable
- In general 2 files should be able to be read vertically on one (hi-res) monitor. Obviously this is vague, we will implement this via an automated style guide pushed to this repo
- Use types most of the time
- Use camelCase most of the time
- Use `const` when possible
- Use functional React components
- Use Next.js app routing
- Make function names highly descriptive of what they do
- Extract reusable code into functions as much as possible
- If code becomes too long, for clarity, extract it into separate functions, even if not reusable
- Be consistent

- Avoid
- Semicolons unless required for the code to work as intended
- `var` unless for some reason you need that level of scope, use `let` instead
- Class based React components
- Next.js pages routing

## Commits
* Commits should
* Start with a capital letter
* Be brief yet descriptive of the update
* Be written in present-tense
* Examples taken from the first few commits to this repo:
* Reduce page and globals to basics
* Add create-next-app@latest default
* Update readme to default Next.js
* See the [Commits section in our process](https://github.com/onc-healthit/site-ett-docs/blob/main/site-ui-4-process.md#commits
) for more info

- Commits should
- Start with a capital letter
- Be brief yet descriptive of the update
- Be written in present-tense
- Examples taken from the first few commits to this repo:
- Reduce page and globals to basics
- Add create-next-app@latest default
- Update readme to default Next.js
- See the [Commits section in our process](https://github.com/onc-healthit/site-ett-docs/blob/main/site-ui-4-process.md#commits) for more info

## Troubleshooting
* TODO


- TODO

---

## Next.js Default Info
Expand Down
Loading

0 comments on commit 3ccf7a4

Please sign in to comment.