GithubHelp home page GithubHelp logo

garden-planner's Introduction

Ava's Garden

Description:

My project is a straightforward garden log that keeps track of which plant grew in which plot in my garden. On the index page, you can click on a button that represents exactly which 12x12 inch plot you're interested in knowing the history of, as well as add plants and notes to the history data yourself. Since the shape of my boxes weren't particularly ordinary, I chose to demonstrate the overall garden as a drawn picture, and then organize each plot underneath (after consulting with another developer). This was a much better solution than my previous attempt, which was to try (and fail) to create an L - shaped table with buttons that would lead to each seperate plothistory page. If I were to continue that approach, I would have to look into HTML canvas in the future.

While the log in and register pages are strictly speaking unnecessary, I still included them so I could take from previous homework and enjoy the feeling of logging in to my own webpage. Any profile will be able to edit the data, which will effect what other profiles will see.

The main workhorses of this program are the SQL database, plothistory, and the add pages. I was able to create a separate program called sql.py that created and logged each plot of my garden into a SQL database. The main tables are the plants, history, and plot tables. Each logged plant may have a url associated with it that will be later accessed if the user wishes to read up more on it. The plot table logs every plot in my garden and assigns them an id. The history table is set up to coincide with both the plant and plot tables, and includes more information about each history instance such as date, seed source, and notes.

The index gives the user a list of options to click through, and saves which button value was clicked to the session - which is correlated to the plot data - so that it can redirect them to a plothistory page. This is how the plot data is saved from one route to another. This can then give the illusion of a separate plot history page for each plot. I modified sql.py into a jinja format in index.html in order to create each plot button.

Every time a user is directed to the plothistory page, the history of the button clicked is looked up in the database given the button and plot's value. In this page, the user has the option to add notes about a specific plant, or learn more about a logged plant depending on whether a link is provided in the database or not. If so, the plant name is linked to an outside resource (most likely to growinginthegarden.com, a particularly helpful website in my area).

If a user wishes to add notes to a particular plant, they may do so by entering data into a textbox in the notes section. The html page has two inputs for each note, one being hidden whos value is the history id. This is so that data entered into one section won't get put into an unrelated one. The page is then redirected back to itself so the user does not need to manually refresh the page.

In order to add a plant to a plot, a user must navigate to the dedicated page. Here they have the option to log in more information about the plant being entered. The plot coordinates are related to the bed number and its x and y values. The beds are numbered from top-down left to right, for example: the North West L - shaped bed is also known as bed number 1. It is then checked to see if the user enered in a valid plot number by checking to see if there is an id associated with a plot with the given values.

I was also able to look in flask's docs in order to create a personalized 404 error page with the errorhandler method. This makes it so any route in the project will be redirected if an unfound error happens to occur.

One focus I had during the development of this website was to solidify my git and github skills. As such, I was able to get comfortable creating and merging branches when working on different aspects of the code, as well as pushing and pulling to and from github. For every new route I added, I would create a different branch and merge it back into main when the feature was finished.

garden-planner's People

Contributors

ava-fox avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.