javascript icon indicating copy to clipboard operation
javascript copied to clipboard

Implement new Concept Exercise: Dates

Open junedev opened this issue 4 years ago • 13 comments

Note: The concept was already created, only the exercise is missing now.

Getting Started

If you have not yet contributed to concept exercises before, this task requires some upfront reading to acquire the necessary background knowledge.

Here you can read about what Concept Exercises are and how they are structured:

If you have not done so yet, it is probably also helpful to do a couple of "Learning Exercises" (this is how they are called on the site) yourself. You can also look at the code of an existing concept exercise like bird-watcher (concept for-loops) for reference.

See the documentation above (general documentation), as well as How to implement a Concept Exercise in JavaScript.

Also be aware of these general guidelines.

Goal

The goal here is to create a new concept exercise that teaches working with dates via Date.

The concept needs to be written from scratch, the exercise can be ported from another track (see details below).

Concepts

The following concept needs to be created. You can use the introduction.md file of the concept also as introduction.md file of the exercise. No need to create different content at this point. Additionally, if you want to save some time it is ok to not have an extensive about.md for now. It can also be mainly the introduction.md content, maybe with some additions you would like to make.

  • dates (maybe use "Date and Time" as display name in the config)

Learning Objectives

In the concepts the student should learn about the following topics and then practice them in the concept exercise.

  • how dates/timestamps are represented internally, see e.g. MDN link
  • how to create dates with new Date, incl. some of the commonly used variants
  • Date.parse
  • Date.now
  • getting and setting the date components (getMonth/setMonth etc.)
  • how to calculate a time difference
  • how to compare dates

The about.md file could additionally mention ...

  • how out of range inputs are handled, see https://javascript.info/date#autocorrection
  • Temporal as work-in-progress to address shortcoming of working with dates in JavaScript

Out of Scope

Prerequisites

  • classes

Other prerequisites should be added as needed to solve the specific exercise.

Exercise Idea

There are two options for exercises from other languages that could be used as a template.

If you port one of these exercises, make sure only to include tasks that actually make sense in JavaScript and add value for the student. Feel free to remove/replace/add tasks as needed.

Resources

Here some links that might be helpful as a starting point and/or for the links section of the concept:

  • https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date
  • https://javascript.info/date

How to proceed

  1. First accept this issue by saying "I'd like to work on this" (no need to wait for a response, just go ahead).
  2. Use this issue to discuss any questions you have, what should be included in the content and what not and to collect more reference material.
  3. Create a PR and set "exercism/javascript" as reviewers. Additionally you can write in #maintaining-javascript on Slack that your PR is ready for review. Once you incorporated any critical feedback that the reviewer might give you and the PR is approved, it will be merged by a maintainer.

junedev avatar Nov 17 '21 20:11 junedev

I'd like to work on this!!

JaPrad avatar Nov 30 '21 05:11 JaPrad

Hey @junedev! Just wanted to ask if we can merge the concept first and then exercise? Or both together?

I think this will be different from the freelancer rate improvement issue as in that case we already had a corresponding exercise.

JaPrad avatar Dec 06 '21 17:12 JaPrad

Yes, you can create a separate PR for the concept first if you like.

junedev avatar Dec 06 '21 19:12 junedev

Hey @junedev, @SleeplessByte, an issue here I ran the command npx babel-node scripts/format from my Windows PowerShell terminal. It gives this output

npx: installed 1 in 12.205s
command not found: babel-node

What to do?

JaPrad avatar Dec 23 '21 16:12 JaPrad

I think it's because there is no PS1 variant in the scripts folder.

Do you happen to have git bash? That's what I use on my windows to run these. Alternatively, it should work in CMD.exe.

If all else fails:

npm install prettier --write .

Or add a comment to the PR with a slash followed by format.

SleeplessByte avatar Dec 23 '21 16:12 SleeplessByte

Hey @junedev ! The display on my laptop doesn't work and would take few days to fix. Hence temporarily won't be able to work on this issue and the linked PR. Hope that doesn't cause any trouble?

I'll work on it asap

JaPrad avatar Jan 10 '22 05:01 JaPrad

No problem. Good luck with the repair/replacement.

junedev avatar Jan 10 '22 05:01 junedev

@JaPatGitHub Now that the concept part is merged, please let me know whether you intend to also work on the exercise.

junedev avatar Apr 26 '22 20:04 junedev

Yes @junedev , I am ready work on the exercises too :)

JaPrad avatar Apr 27 '22 03:04 JaPrad

Great! Then I leave the assignment as is.

junedev avatar Apr 27 '22 05:04 junedev

@junedev @SleeplessByte, I am unable to find time to work on this further owing to my heavy courseload as this is my final year at high school.

I apologize for the inconvenience caused and for informing this late...I try to scrape out time to just complete this assignment but fail to make sufficient progress.

JaPrad avatar Sep 10 '22 16:09 JaPrad

👍 No problem, I will unassign you.

junedev avatar Sep 10 '22 17:09 junedev

I'd like to work on this.

sahamdot avatar Oct 02 '22 06:10 sahamdot