Display a calendar in the middle of the screen (both horizontally and vertically). Use SCSS and follow BEM. Don't use JS.
- Write styles in
src/styles/main.scss
instead ofsrc/style.css
. - Create a markup for the calendar block with 31 days inside
- DON'T add numbers in HTML (you will do it using CSS)
- Each day is a grey (
#eee
)100px
square (including 1px black border)- Add a number (
Arial 30px
) in the center of each day using::before
and @for
- Add a number (
- Use flex with
1px
gap and limit its width to exactly 7 columns +10px
paddings- Don't use hardcoded
px
values if they are used several times - Use properly named variables to make all the calculations more clear.
- Don't use hardcoded
- Implement
start-day
modifier for thecalendar
withmon
,tue
,wed
,thu
,fri
,sat
andsun
values- Use @each to create all the modifiers
- The month should start at the correct column (Monday is the 1st, Friday is the 5th)
- You can just add correct
margin-left
for the first day - Set calendar to start from Sunday by default
- Add a modifier
month-length
for thecalendar
with values 28, 29, 30 and 31 (use@for
)- It sets the last day to show (use nth-child)
- Set 31 days by default
On hovering over a cell:
- cursor should become pointer
- The hovered cell has to become pink (use
#FFBFCB
) - Move the hovered cell up by
20px
(usetransform
) - All changes should be animated with the duration of 0.5s
Here are the Layout Tasks Instruction
Note: In this task, you can directly link *.scss
files in HTML <link>
tags. This is possible because we use the Parcel library to bundle the source code.
❗️ Replace <your_account>
with your Github username and copy the links to Pull Request
description:
❗️ Copy this Checklist
to the Pull Request
description after links, and put - [x]
before each point after you checked it.
- Changing 'month-lengh' and 'start-day' modifier in the code element reflects in changing calendar layout
- Each day has no modifiers, only class (eg. calendar__day)
- All
Typical Mistakes
fromBEM
lesson theory are checked. - Code follows all the Code Style Rules ❗️