From f14c55558943826511eb92aa8df655ca6191dc0f Mon Sep 17 00:00:00 2001 From: John Darragh Date: Mon, 18 May 2020 21:56:18 -0700 Subject: [PATCH 1/3] Add contributing.md --- README.md | 52 +--- .../Verification/VerificationAdmin.js | 2 +- contributing.md | 276 ++++++++++++++++++ 3 files changed, 281 insertions(+), 49 deletions(-) create mode 100644 contributing.md diff --git a/README.md b/README.md index 54dfdbaa0..56a9624cd 100644 --- a/README.md +++ b/README.md @@ -7,54 +7,10 @@ Postgres database, node/express Web API server, and React client. 1. Git for working with Github source code 2. Node and npm for running the web app -3. - -## Static Analysis (eslint) - -This project uses Husky and Lint-Staged to automatically perform static analysis tasks on all added / modified files. Each time you try to commit it will run the `lint-staged` command and report any issues. Be warned, all "errors" reported by eslint will not allow the commit until they are resolved. Developers can opt to pass `--no-verify` flag to git commit to bypass these rules but it is not advised. If for whatever reason you want to ignore certain rules in a specific situation you can use comments like this: `//eslint-disable-next-line` or `//eslint-disable-line`. - -1. Run `npm install` on root -2. Configure your IDE to use the `.eslintrc.js` and `.prettierc` file on root. (For VSCode editor, the .vscode/.settings.json file from the repo will set up Prettier as your default formatter, enable format on save, and disable format on paste.) - -## Full-Stack React/Node Application Installation - -1. Clone this repo to your local drive. - -
details

- - 1. Start a terminal app, such as Terminal on OSX or the Git Bash shell on Windows. - 1. Create a src directory in the user's home directory and go in it - ``` - cd && mkdir src && cd src - ``` - 1. Clone the repository - ``` - git clone https://github.com/hackforla/food-oasis - ``` -

- -1. Change to the food-oasis directory: - ``` - cd food-oasis - ``` -1. Install the node server npm depedencies: - ``` - npm install - ``` -1. Obtain the `.env` file from the project tech team and place it in this directory. It contains private info (i.e., the production database connection string) that we cannot put in this public GitHub repo. -1. Change to the client directory: - ``` - cd client - ``` -1. Install the client (React) dependencies: - ``` - npm install - ``` - -## To Run the React/Node Application - -1. Run `npm start` from the food-oasis directory to start the node server. -1. Open a separate command shell and set the directory to the /client subdirectory, then `npm start` again to start the client application and open a browser pointing to it. + +## Contributing + +[Contributing to Food Oasis](/contributing.md) ## Features diff --git a/client/src/components/Verification/VerificationAdmin.js b/client/src/components/Verification/VerificationAdmin.js index b400a42c6..12a281bd3 100644 --- a/client/src/components/Verification/VerificationAdmin.js +++ b/client/src/components/Verification/VerificationAdmin.js @@ -139,12 +139,12 @@ function VerificationAdmin(props) { useEffect(() => { const criteriaString = localStorage.getItem(CRITERIA_TOKEN); let initialCriteria = JSON.parse(criteriaString); - initialCriteria.verificationStatusId = 0; if (!initialCriteria) { initialCriteria = { ...defaultCriteria, latitude: userCoordinates.latitude, longitude: userCoordinates.longitude, + verificationStatusId: 0, }; } setCriteria(initialCriteria); diff --git a/contributing.md b/contributing.md new file mode 100644 index 000000000..c62c77126 --- /dev/null +++ b/contributing.md @@ -0,0 +1,276 @@ +# Contributing to the Food Oasis Project + +If you are not going to do hands-on development, you can simply experiment +with the test version of the application at https://food-oasis-dev.herokuapp.com. + +The production version is deployed to https://food-oasis.herokuapp.com. + +If you wish to study or contribute to the code base, follow these Installation +Instructions to install a development environment on your machine: + +## Installation Instructions + +### Prerequisites + +1. Git for working with Github source code +2. Node and npm for running the web app + +### Full-Stack React/Node Application Installation + +1. Start a terminal app, such as a Git bash shell on Windows or Terminal on Mac OS +1. Create a source directory (e.g. hackforla) in the user's home directory and go in it (or use the folder where you normally put local git repositories) + ``` + mkdir hackforla + cd hackforla + ``` +1. Clone the Food Oasis repository + + ``` + git clone https://github.com/hackforla/food-oasis + ``` + +1. Change to the food-oasis directory: + ``` + cd food-oasis + ``` +1. Install the node server npm depedencies: + ``` + npm install + ``` +1. Obtain the `.env` file from the Food-Oasis/Developers G-Drive folder and place it in this directory. It contains private info (i.e., the production database connection string) that we cannot put in this public GitHub repo. +1. Change to the client directory: + ``` + cd client + ``` +1. Install the client (React) dependencies: + ``` + npm install + ``` + +### To Run the React/Node Application + +1. In one terminal window, navigate back to the /food-oasis directory and start the node server: + +``` +cd .. +npm start +``` + +1. In a separate terminal window, navigate to the /food-oasis/client directory, start the react app, and open the browser : + +``` +cd client +npm start +``` + +Note: Node server (backend) should start before the React server (frontend/client) + +## Static Analysis (eslint) + +This project uses Husky and Lint-Staged to automatically perform static analysis tasks on all added / modified files. Each time you try to commit it will run the `lint-staged` command and report any issues. Be warned, all "errors" reported by eslint will not allow the commit until they are resolved. Developers can opt to pass `--no-verify` flag to git commit to bypass these rules but it is not advised. If for whatever reason you want to ignore certain rules in a specific situation you can use comments like this: `//eslint-disable-next-line` or `//eslint-disable-line`. + +1. Run `npm install` on root +2. Configure your IDE to use the `.eslintrc.js` and `.prettierc` file on root. (For VSCode editor, the .vscode/.settings.json file from the repo will set up Prettier as your default formatter, enable format on save, and disable format on paste.) + +## To Contribute Code + +### Claiming an Issue + +Before modifying any code, an issue should exist for the task in the GitHub repo. You should make sure that no one else is assigned to the issue and then assign it to yourself, so we avoid stepping on each others' toes. If there is not an issue for the work you want to do, you should talk to the lead developer and/or project manager to get an issue created and prioritized on the kanban board and then have them create the issue from there for you to work on. + +We use the "Git Flow" workflow to manage source code. See [Vincent Driessen's seminal article](https://nvie.com/posts/a-successful-git-branching-model/) for an overview, though a few of the detailed procedures below have additional steps. We have modified a few steps here, so your changes are merged into _develop_ on GitHub (rather than locally). This allows others to easily view your changes, and is a smaller departure from the previous workflow to learn. + +1. After cloning the repository, create a feature branch with a name containing your name and a feature name, separated by dashes, for example. + +``` +git checkout -b 379-hours-validation +``` + +Note that your feature branch is based on the _develop_ branch, which is where feature changes will be integrated for eventual release to production. + +2. Claim an issue (see instructions down below) and start coding. + +3. Regularly add, commit, and push your code to your branch. + +``` +git add -A +git commit -m "Implement client-side validation of business hours" +git push origin HEAD +``` + +4. When an issue is completed and is ready for a pull request, first add and commit your latest changes as in Step 3 above, then make sure your code has the latest code from the _develop_ branch by pulling from the develop branch. This is to ensure merge conflicts are in your local envinronment, which is easier to clean up, than in GitHub: + +``` +git pull origin develop +``` + +5. Resolve any merge conflicts and _run the application_ (client and server) to be sure that the application builds correctly before proceeding. Then push your changes to your feature branch on the github repo: + +``` +git push origin HEAD +``` + +6. Go to the [GitHub repository for Food Oasis](https://github.com/hackforla/food-oasis). There are three options: + +- Click on "Compare & pull request" button underneath the "commits branches releases environment contributors" box. +- Click on the "New Pull Request" button underneath the "commits branches releases environment contributors" box and underneath "Your recently pushed branches" section. +- Click on the "Pull Request" tab and press "New Pull Request" + +7. In "Comparing Changes", switch the "compare" (right button) to your branch name. Make sure the "base" (left button) is on the _develop_ branch. Double check the changes you've made down below, and click "Create pull request". Make sure the description of your changes is reflected in the Pull Request, e.g. + "Start to incorporate Storybook and LADOT theme (colors, logos and headers)". + +8. Click on "Create Pull Request" and wait for someone to review to merge your changes! + +9. Once your PR has been reviewed, accepted and merged to the develop branch, it will automatically be published to https://food-oasis-dev.herokuapp.com. Please be sure to run the application here and make sure your changes are reflected in this deployed version of the develop branch. + +## Creating a Release + +Creating a release should only be done by the release manager! +Release branches are created from the _develop_ branch. Decide on a release number for the next release, using [semver](https://semver.org/) conventions. For example, if the current release is 1.0.0 and the changes in this release are minor, the new release number would be 1.0.1. + +- Make sure your local machine has an up-to-date version of the _develop_ branch: + +``` +git checkout develop +git pull origin develop +``` + +- Create a new release branch from _develop_ with the name release-: + +``` +git checkout -b release-0.1.0 develop +``` + +- Update the release number in the application. This typically entails updating the package.json file version properties, and perhaps other locations where the release number might appear. + +- Commit the version number change: + +``` +git add -A +git commit -m "Bumped version number to 0.1.0" +``` + +- Run the application (locally and/or in a deployment environment) and make any fixes necessary. These should be very minor changes - significant changes should be made by creating a feature release based on the _develop_ branch as described above. When the application is ready for release... +- Merge the release branch into _master_: + +``` +git checkout master +git pull origin master +git merge --no-ff release-1.0.0 +git tag -a 0.1.0 -m "Release version 0.1.0" +git push origin HEAD +git push origin 0.1.0 +``` + +At present, Heroku is configured to detect the commit to _master_ and automatically deploy the application to production. You should navigate to https://food-oasis.herokuapp.com after giving Heroku time to deploy and verify that the application runs, and any visible release # has been incremented. + +The release is now done and tagged for future reference. + +- Merge the release branch into _develop_: + +``` +git checkout develop +git merge --no-ff release-0.1.0 +``` + +(Resolve any merge conflicts) + +``` +git push origin HEAD +``` + +It will automatically be published to https://food-oasis-dev.herokuapp.com. Please be sure to run the application here and make sure your changes are reflected in this deployed version of the develop branch. + +- We are now done with this release and can delete the release branch: + +``` +git branch -d release-0.1.0 +``` + +### Generating release notes + +We are using [`gren`](https://github.com/github-tools/github-release-notes) with .grenrc.json config file and generating the log from Github Issues. See [this page](https://github-tools.github.io/github-release-notes/concept.html) on the recommended convention for writing issue titles. We use the `enhancement` and `bug` labels to categorize issues for release notes. + +1. Follow instructions on the [`gren` setup section](https://github.com/github-tools/github-release-notes#setup) to generate and install your `Github token`. + +1. Be in the project root directory + +1. Run the script to update the notes + +``` +npm run release-notes +``` + +## Creating a HotFix + +Creating a HotFix should only be done by the release manager! A HotFix should only +include very minor patches to the application, and is always based on the _master_ branch. +The new release number will be the same as the master branch number with the patch +number incremented by one. For example a patch to release 34.67.22 should be 34.67.23. + +- Make sure your local machine has an up-to-date version of the _master_ branch: + +``` +git checkout master +git pull origin master +``` + +- Create a new release branch from _master_ with the name hotfix-: + +``` +git checkout -b hotfix-34.67.23 master +``` + +- Update the release number in the application. This typically entails updating the package.json file version properties, and perhaps other locations where the release number might appear (For now, I just added it to the About.js component, though we should probably put it in a site footer or some inconspicuous place, so it can be viewed from the UI.) + +- Commit the version number change: + +``` +git add -A +git commit -m "Bumped version number to 0.1.1" +``` + +- Run the application (locally and/or in a deployment environment) and modify the code to implement the fixe(s). These should be very minor changes - significant changes should be made by creating a feature release based on the _develop_ branch as described above. When the hotfix is ready for release... +- Merge the hotfix branch into _master_: + +``` +git checkout master +git pull origin master +git merge --no-ff hotfix-0.1.1 +git tag -a 0.1.1 -m "Release version 0.1.1" +git push origin HEAD +``` + +At present, Heroku is configured to detect the commit to _master_ and automatically deploy the application to production. You should navigate to https://food-oasis.herokuapp.com after giving Heroku time to deploy and verify that the application runs, and any visible release # has been incremented. + +The hotfix is now done and tagged for future reference. + +- Merge the hotfix branch into _develop_: + +``` +git checkout develop +git merge --no-ff hotfix-0.1.1 +``` + +(Resolve any merge conflicts) + +``` +git push origin HEAD +``` + +It will automatically be published to https://food-oasis-dev.herokuapp.com. Please be sure to run the application here and make sure your changes are reflected in this deployed version of the develop branch. + +- We are now done with this release and can delete the release branch: + +``` +git branch -d hotfix-0.1.1 +``` + +## Resources from our very own Hack For LA member! + +- [Intro to Git CLI exercises](https://github.com/ndanielsen/intro-cli-git-github) Nathan Danielsen +- [Intermediate Git CLI exercises](https://github.com/ndanielsen/intermediate-cli-git-github) Nathan Danielsen + +### Testing + +TBD From 210dc41175742e8a4dc35fd308d1c2c7466a0bdb Mon Sep 17 00:00:00 2001 From: Tim Malstead Date: Tue, 19 May 2020 17:30:18 -0700 Subject: [PATCH 2/3] fixes address bar mobile width issue --- client/src/components/Search.js | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/client/src/components/Search.js b/client/src/components/Search.js index a99296c65..939bc7c5c 100644 --- a/client/src/components/Search.js +++ b/client/src/components/Search.js @@ -1,4 +1,4 @@ -import React, { useState } from "react"; +import React, { useState, useEffect } from "react"; import PropTypes from "prop-types"; import Downshift from "downshift"; import { MenuItem, TextField, Paper } from "@material-ui/core"; @@ -19,7 +19,6 @@ const useStyles = makeStyles(() => ({ width: "100%", }, address: { - width: "31em", backgroundColor: "#fff", borderRadius: "4px 0 0 4px", height: 41, @@ -46,6 +45,20 @@ export default function Search(props) { const { mapboxResults, fetchMapboxResults } = useMapboxGeocoder(); + const initialWidth = window.innerWidth > 600 ? true : false; + const [isWindowSixHundredOrLess, switchAddressWidth] = useState(initialWidth); + useEffect(() => { + const changeAddressWidth = () => { + window.innerWidth > 600 + ? switchAddressWidth(true) + : switchAddressWidth(false); + }; + + window.addEventListener("resize", changeAddressWidth); + + return () => window.removeEventListener("resize", changeAddressWidth); + }); + const handleInputChange = (event) => { setSelectedPlace(event.target.value); if (!event.target.value) { @@ -92,6 +105,7 @@ export default function Search(props) { }, ...InputProps, }} + style={{ width: isWindowSixHundredOrLess ? "31em" : "82vw" }} /> ); }; From 63998009145961ae2ad3bba5fd18c8c579f56547 Mon Sep 17 00:00:00 2001 From: John Darragh Date: Thu, 21 May 2020 09:47:29 -0700 Subject: [PATCH 3/3] Fix bug in stakeholder query filtering by category --- app/controllers/stakeholder-controller.js | 10 +++++----- app/services/stakeholder-service.js | 6 ++++-- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/app/controllers/stakeholder-controller.js b/app/controllers/stakeholder-controller.js index a712a68ab..902e3942f 100644 --- a/app/controllers/stakeholder-controller.js +++ b/app/controllers/stakeholder-controller.js @@ -2,11 +2,11 @@ const stakeholderService = require("../services/stakeholder-service"); const search = (req, res) => { let categoryIds = req.query.categoryIds; - if (!categoryIds) { - categoryIds = ["1", "2", "3", "4", "5", "6"]; - } else if (typeof categoryIds == "string") { - categoryIds = [categoryIds]; - } + // if (!categoryIds) { + // categoryIds = ["1", "2", "3", "4", "5", "6"]; + // } else if (typeof categoryIds == "string") { + // categoryIds = [categoryIds]; + // } const params = { ...req.query, categoryIds }; stakeholderService .search(params) diff --git a/app/services/stakeholder-service.js b/app/services/stakeholder-service.js index a655eaca8..1fc89afff 100644 --- a/app/services/stakeholder-service.js +++ b/app/services/stakeholder-service.js @@ -38,9 +38,11 @@ const search = async ({ claimedLoginId, verificationStatusId, }) => { - const categoryClause = `(select sc.stakeholder_id + const categoryClause = categoryIds + ? `(select sc.stakeholder_id from stakeholder_category sc - where sc.category_id in (${categoryIds.join(",")}))`; + where sc.category_id in (${categoryIds.join(",")}))` + : ""; const nameClause = "'%" + name.replace(/'/g, "''") + "%'"; const sql = ` select s.id, s.name, s.address_1, s.address_2, s.city, s.state, s.zip,