{"id":23053938,"url":"https://github.com/nullthefirst/fcc-25-plus-5-clock","last_synced_at":"2025-10-06T21:04:23.139Z","repository":{"id":47755991,"uuid":"391283288","full_name":"nullthefirst/fcc-25-plus-5-clock","owner":"nullthefirst","description":"freeCodeCamp - Pomodoro (25 + 5) Clock","archived":false,"fork":false,"pushed_at":"2021-08-14T13:11:38.000Z","size":761,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-02-18T11:43:01.028Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"https://null-fcc-25-plus-5-clock.netlify.app/","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/nullthefirst.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2021-07-31T07:19:49.000Z","updated_at":"2021-08-14T13:11:40.000Z","dependencies_parsed_at":"2022-09-23T19:01:39.388Z","dependency_job_id":null,"html_url":"https://github.com/nullthefirst/fcc-25-plus-5-clock","commit_stats":null,"previous_names":["mr-tey/fcc-25-plus-5-clock","nullthefirst/fcc-25-plus-5-clock","pipetauo/fcc-25-plus-5-clock","chieftey/fcc-25-plus-5-clock","usheninte/fcc-25-plus-5-clock"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nullthefirst%2Ffcc-25-plus-5-clock","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nullthefirst%2Ffcc-25-plus-5-clock/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nullthefirst%2Ffcc-25-plus-5-clock/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nullthefirst%2Ffcc-25-plus-5-clock/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/nullthefirst","download_url":"https://codeload.github.com/nullthefirst/fcc-25-plus-5-clock/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":240254166,"owners_count":19772386,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-12-16T00:31:47.201Z","updated_at":"2025-10-06T21:04:18.092Z","avatar_url":"https://github.com/nullthefirst.png","language":"JavaScript","readme":"# 25 + 5 Clock\n\n\u003e User Story # 1\n\nI can see an element with id=\"break-label\" that contains a string (e.g. \"Break Length\").\n\n\u003e User Story # 2\n\nI can see an element with id=\"session-label\" that contains a string (e.g. \"Session Length\").\n\n\u003e User Story # 3\n\nI can see two clickable elements with corresponding IDs: id=\"break-decrement\" and id=\"session-decrement\".\n\n\u003e User Story # 4\n\nI can see two clickable elements with corresponding IDs: id=\"break-increment\" and id=\"session-increment\".\n\n\u003e User Story # 5\n\nI can see an element with a corresponding id=\"break-length\", which by default (on load) displays a value of 5.\n\n\u003e User Story # 6\n\nI can see an element with a corresponding id=\"session-length\", which by default displays a value of 25.\n\n\u003e User Story # 7\n\nI can see an element with a corresponding id=\"timer-label\", that contains a string indicating a session is initialized (e.g. \"Session\").\n\n\u003e User Story # 8\n\nI can see an element with corresponding id=\"time-left\". NOTE: Paused or running, the value in this field should always be displayed in mm:ss format (i.e. 25:00).\n\n\u003e User Story # 9\n\nI can see a clickable element with a corresponding id=\"start_stop\".\n\n\u003e User Story # 10\n\nI can see a clickable element with a corresponding id=\"reset\".\n\n\u003e User Story # 11\n\nWhen I click the element with the id of reset, any running timer should be stopped, the value within id=\"break-length\" should return to 5, the value within id=\"session-length\" should return to 25, and the element with id=\"time-left\" should reset to its default state.\n\n\u003e User Story # 12\n\nWhen I click the element with the id of break-decrement, the value within id=\"break-length\" decrements by a value of 1, and I can see the updated value.\n\n\u003e User Story # 13\n\nWhen I click the element with the id of break-increment, the value within id=\"break-length\" increments by a value of 1, and I can see the updated value.\n\n\u003e User Story # 14\n\nWhen I click the element with the id of session-decrement, the value within id=\"session-length\" decrements by a value of 1, and I can see the updated value.\n\n\u003e User Story # 15\n\nWhen I click the element with the id of session-increment, the value within id=\"session-length\" increments by a value of 1, and I can see the updated value.\n\n\u003e User Story # 16\n\nI should not be able to set a session or break length to \u003c= 0.\n\n\u003e User Story # 17\n\nI should not be able to set a session or break length to \u003e 60.\n\n\u003e User Story # 18\n\nWhen I first click the element with id=\"start_stop\", the timer should begin running from the value currently displayed in id=\"session-length\", even if the value has been incremented or decremented from the original value of 25.\n\n\u003e User Story # 19\n\nIf the timer is running, the element with the id of time-left should display the remaining time in mm:ss format (decrementing by a value of 1 and updating the display every 1000ms).\n\n\u003e User Story # 20\n\nIf the timer is running and I click the element with id=\"start_stop\", the countdown should pause.\n\n\u003e User Story # 21\n\nIf the timer is paused and I click the element with id=\"start_stop\", the countdown should resume running from the point at which it was paused.\n\n\u003e User Story # 22\n\nWhen a session countdown reaches zero (NOTE: timer MUST reach 00:00), and a new countdown begins, the element with the id of timer-label should display a string indicating a break has begun.\n\n\u003e User Story # 23\n\nWhen a session countdown reaches zero (NOTE: timer MUST reach 00:00), a new break countdown should begin, counting down from the value currently displayed in the id=\"break-length\" element.\n\n\u003e User Story # 24\n\nWhen a break countdown reaches zero (NOTE: timer MUST reach 00:00), and a new countdown begins, the element with the id of timer-label should display a string indicating a session has begun.\n\n\u003e User Story # 25\n\nWhen a break countdown reaches zero (NOTE: timer MUST reach 00:00), a new session countdown should begin, counting down from the value currently displayed in the id=\"session-length\" element.\n\n\u003e User Story # 26\n\nWhen a countdown reaches zero (NOTE: timer MUST reach 00:00), a sound indicating that time is up should play. This should utilize an HTML5 audio tag and have a corresponding id=\"beep\".\n\n\u003e User Story # 27\n\nThe audio element with id=\"beep\" must be 1 second or longer.\n\n\u003e User Story # 28\n\nThe audio element with id of beep must stop playing and be rewound to the beginning when the element with the id of reset is clicked.\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnullthefirst%2Ffcc-25-plus-5-clock","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fnullthefirst%2Ffcc-25-plus-5-clock","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnullthefirst%2Ffcc-25-plus-5-clock/lists"}