Simple calendar application that allows a user to save events for each hour of the day. This app runs in the browser and features dynamically updated HTML and CSS powered by jQuery.
Built using Javascript, Jquery, HTML and CSS. This daily planner application provides a list of rows with text inputs. These 9 rows map to each hour of a working day (9am-5pm). A user can add an event to each row using the text input and clicking save. If the input content is changed and focus is moved, the save button will alert the user to click it to save changes to localStorage.
Once saved the events will be saved to the application even after the page is refreshed. The row color will change based on the time of the day. Current hour displays as pink, upcoming hours as green. Hours passed are displayed in gray
To get a local copy up and running follow these simple steps. You can also download the source files provided. You will need a text editor such as Visual Studio Code, Xcode or similar to edit the source code.
-
Clone the repo
git clone https://github.com/FAC-73/blue-monday-planner.git
-
Pull the latest
git pull
- HTML, CSS and Javascript (incl. Jquery) files include the source code for running the Day Planner application
- This project demonstrates ways in which javavscript and jquery can be used to manipulate the DOM elements, store and pass data to and from variables, and dynamically update HTML and trigger interactions through the use of Jquery eventListeners and the the moment.js API.
- The planner list includes 9 rows, each row representative of an hour of the work day from 9am to 5pm.
- Each row is color coded. Pink denotes the current hour of the day, Teal represents hours left/upcoming. Gray represents time elapsed/passed.
- The current date is displayed in the header of the page.
- Onload a pre-defined event is included so that the planner doesn't appear empty.
- To add an event to an hour clicking or focus on a row and type the name of the event into the input.
- Clicking save stores the event to localStorage. If focus is lost from the input prior to clicking save, the save button pulses orange until the user actions the button. The event will not be saved to localStorage if this is not actioned, and changes are lost.
A prevent default method is used to stop the default behavior of the input to clear the content on submit.
- If the user leaves the page, refreshes or closes the browser. On subsequent reload the events are stored and shown when the page has loaded.
- To delete an event. Remove the text from the input and click save. Again, if focus is lost after removing text the save button will pulse to alert the user to commit the change. Otherwise it will not be saved in localStorage.
- Index.html - Contains basic layout structure. Main planner content is contained in a div using the container class from bootstrap to leverage the responsive grid, with the ID 'dayEventContainer'. Here javascript and Jquery dynamically appends the divs for displaying the hour, input for events, and the save button. Most div's leverage Bootstrap CSS classes for responsive purposes. Semantic html is used for elements such as header, text elements.
- For improved accessibility additional descriptions for icons has been included.
-
styles.css - Contains layout, styling and media-queries and animations, as well as leveraging bootstrap CSS grid via the CDN.
-
script.js - Contains variables, variable arrays and objects for declaring current time and hour.
- Makes use of the moment.js API for pulling time and date information. Date is displayed in the header of the document. Time is stored in an array and has variables set for determining the 9am - 5pm typical work day
- Functions for creating a row to display the time by hour. As well as add text into the input to create an even and to save it to local storage using JSON stringify method.
- A for loop for iterating through the hours 9am - 5pm (17:00) for creating the event array.
- Two eventListeners one onClick event to store the event into localStorage through clicking the save button. The second an onChange event to determine if the input content has been modified and needs to trigger a changeClass method if changes are not saved.
- A function to change the color of the rows determined on whether the hour is current, upcoming or passed. Using if and else if statements based on the time stored in the variable 'hour
- If, Else statements for validating whether there are saved events in localStorage on load of the document which are appended into the DOM elements. and to pass this data into an array
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/FeatureName
) - Commit your Changes (
git commit -m 'Add some FeatureName
) - Push to the Branch (
git push origin feature/FeatureName
) - Open a Pull Request
Distributed under the MIT License.
See LICENSE for more information.
Kay Davis
Project repo link: https://fac-73.github.io/blue-monday-planner
Project website: https://github.com/FAC-73/blue-monday-planner