* fix: handle missing solutions correctly Rather than creating an [[]] the parser now creates [] which isEmpty(). This makes the test suite check the next challenge for a solution. In addition, the logic for testing solutions was fixed. * chore: update snapshots * test: build new superblock in node.js-tests CI * test: allow forward slash in superblock slug * fix: borked tests oops * test: ignore duplicated projects * fix: i did not break these shaun did :) * fix: idIndex is index of id not id Co-authored-by: Nicholas Carrigan <nhcarrigan@gmail.com>
		
			
				
	
	
		
			268 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			268 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 619d129a417d0716a94de913
 | |
| title: Step 70
 | |
| challengeType: 0
 | |
| dashedName: step-70
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| Target the `.beak` element with a `class` of `bottom`, and give it a `width` `4%` smaller than `.beak.top`, `5%` further from the top, and `2%` further from the left of its parent than `.beak.top`.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| You should use the `.beak.bottom` selector.
 | |
| 
 | |
| ```js
 | |
| assert.match(code, /\.beak\.bottom\s*\{/);
 | |
| ```
 | |
| 
 | |
| You should give `.beak.bottom` a `width` of `--fcc-expected--`, but found `--fcc-actual--`.
 | |
| 
 | |
| ```js
 | |
| assert.equal(new __helpers.CSSHelp(document).getStyle('.beak.bottom')?.width, '16%');
 | |
| ```
 | |
| 
 | |
| You should give `.beak.bottom` a `top` of `--fcc-expected--`, but found `--fcc-actual--`.
 | |
| 
 | |
| ```js
 | |
| assert.equal(new __helpers.CSSHelp(document).getStyle('.beak.bottom')?.top, '65%');
 | |
| ```
 | |
| 
 | |
| You should give `.beak.bottom` a `left` of `--fcc-expected--`, but found `--fcc-actual--`.
 | |
| 
 | |
| ```js
 | |
| assert.equal(new __helpers.CSSHelp(document).getStyle('.beak.bottom')?.left, '42%');
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```html
 | |
| <!DOCTYPE html>
 | |
| <html>
 | |
|   <head>
 | |
|     <meta charset="UTF-8" />
 | |
|     <link rel="stylesheet" type="text/css" href="./styles.css" />
 | |
|     <title>CSS Penguin</title>
 | |
|     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
 | |
|   </head>
 | |
| 
 | |
|   <body>
 | |
|     <div class="left-mountain"></div>
 | |
|     <div class="back-mountain"></div>
 | |
|     <div class="sun"></div>
 | |
|     <div class="penguin">
 | |
|       <div class="penguin-head">
 | |
|         <div class="face left"></div>
 | |
|         <div class="face right"></div>
 | |
|         <div class="chin"></div>
 | |
|         <div class="eye left">
 | |
|           <div class="eye-lid"></div>
 | |
|         </div>
 | |
|         <div class="eye right">
 | |
|           <div class="eye-lid"></div>
 | |
|         </div>
 | |
|         <div class="blush left"></div>
 | |
|         <div class="blush right"></div>
 | |
|         <div class="beak top"></div>
 | |
|         <div class="beak bottom"></div>
 | |
|       </div>
 | |
|       <div class="penguin-body"></div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="ground"></div>
 | |
|   </body>
 | |
| </html>
 | |
| ```
 | |
| 
 | |
| ```css
 | |
| :root {
 | |
|   --penguin-face: white;
 | |
| }
 | |
| 
 | |
| body {
 | |
|   background: linear-gradient(45deg, rgb(118, 201, 255), rgb(247, 255, 222));
 | |
|   margin: 0;
 | |
|   padding: 0;
 | |
|   width: 100%;
 | |
|   height: 100vh;
 | |
|   overflow: clip;
 | |
| }
 | |
| 
 | |
| .left-mountain {
 | |
|   width: 300px;
 | |
|   height: 300px;
 | |
|   background: linear-gradient(rgb(203, 241, 228), rgb(80, 183, 255));
 | |
|   position: absolute;
 | |
|   transform: skew(0deg, 44deg);
 | |
|   z-index: 2;
 | |
|   margin-top: 100px;
 | |
| }
 | |
| 
 | |
| .back-mountain {
 | |
|   width: 300px;
 | |
|   height: 300px;
 | |
|   background: linear-gradient(rgb(203, 241, 228), rgb(47, 170, 255));
 | |
|   position: absolute;
 | |
|   z-index: 1;
 | |
|   transform: rotate(45deg);
 | |
|   left: 110px;
 | |
|   top: 225px;
 | |
| }
 | |
| 
 | |
| .sun {
 | |
|   width: 200px;
 | |
|   height: 200px;
 | |
|   background-color: yellow;
 | |
|   position: absolute;
 | |
|   border-radius: 50%;
 | |
|   top: -75px;
 | |
|   right: -75px;
 | |
| }
 | |
| 
 | |
| .penguin {
 | |
|   width: 300px;
 | |
|   height: 300px;
 | |
|   margin: auto;
 | |
|   margin-top: 75px;
 | |
|   z-index: 4;
 | |
|   position: relative;
 | |
| }
 | |
| 
 | |
| .penguin * {
 | |
|   position: absolute;
 | |
| }
 | |
| 
 | |
| .penguin-head {
 | |
|   width: 50%;
 | |
| 	height: 45%;
 | |
|   background: linear-gradient(
 | |
|     45deg,
 | |
| 		gray,
 | |
| 		rgb(239, 240, 228)
 | |
| 	);
 | |
| 	border-radius: 70% 70% 65% 65%;
 | |
|   top: 10%;
 | |
|   left: 25%;
 | |
|   z-index: 1;
 | |
| }
 | |
| 
 | |
| .face {
 | |
|   width: 60%;
 | |
|   height: 70%;
 | |
|   background-color: var(--penguin-face);
 | |
|   border-radius: 70% 70% 60% 60%;
 | |
|   top: 15%;
 | |
| }
 | |
| 
 | |
| .face.left {
 | |
|   left: 5%;
 | |
| }
 | |
| 
 | |
| .face.right {
 | |
|   right: 5%;
 | |
| }
 | |
| 
 | |
| .chin {
 | |
|   width: 90%;
 | |
|   height: 70%;
 | |
|   background-color: var(--penguin-face);
 | |
|   top: 25%;
 | |
|   left: 5%;
 | |
|   border-radius: 70% 70% 100% 100%;
 | |
| }
 | |
| 
 | |
| .eye {
 | |
|   width: 15%;
 | |
|   height: 17%;
 | |
|   background-color: black;
 | |
|   top: 45%;
 | |
|   border-radius: 50%;
 | |
| }
 | |
| 
 | |
| .eye.left {
 | |
|   left: 25%;
 | |
| }
 | |
| 
 | |
| .eye.right {
 | |
|   right: 25%;
 | |
| }
 | |
| 
 | |
| .eye-lid {
 | |
|   width: 150%;
 | |
|   height: 100%;
 | |
|   background-color: var(--penguin-face);
 | |
|   top: 25%;
 | |
|   left: -23%;
 | |
|   border-radius: 50%;
 | |
| }
 | |
| 
 | |
| .blush {
 | |
|   width: 15%;
 | |
|   height: 10%;
 | |
|   background-color: pink;
 | |
|   top: 65%;
 | |
|   border-radius: 50%;
 | |
| }
 | |
| 
 | |
| .blush.left {
 | |
|   left: 15%;
 | |
| }
 | |
| 
 | |
| .blush.right {
 | |
|   right: 15%;
 | |
| }
 | |
| 
 | |
| .beak {
 | |
|   height: 10%;
 | |
|   background-color: orange;
 | |
|   border-radius: 50%;
 | |
| }
 | |
| 
 | |
| --fcc-editable-region--
 | |
| .beak.top {
 | |
| 	width: 20%;
 | |
| 	top: 60%;
 | |
| 	left: 40%;
 | |
| }
 | |
| 
 | |
| --fcc-editable-region--
 | |
| 
 | |
| .penguin-body {
 | |
|   width: 53%;
 | |
|   height: 45%;
 | |
|   background: linear-gradient(
 | |
|     45deg,
 | |
| 		rgb(134, 133, 133) 0%,
 | |
| 		rgb(234, 231, 231) 25%,
 | |
| 		white 67%
 | |
| 	);
 | |
|   border-radius: 80% 80% 100% 100%;
 | |
|   top: 40%;
 | |
|   left: 23.5%;
 | |
| }
 | |
| 
 | |
| .penguin-body::before {
 | |
|   content: "";
 | |
|   position: absolute;
 | |
|   width: 50%;
 | |
|   height: 45%;
 | |
|   background-color: gray;
 | |
|   top: 10%;
 | |
|   left: 25%;
 | |
|   border-radius: 0% 0% 100% 100%;
 | |
|   opacity: 70%;
 | |
| }
 | |
| 
 | |
| .ground {
 | |
|   width: 100vw;
 | |
|   height: 400px;
 | |
|   background: linear-gradient(90deg, rgb(88, 175, 236), rgb(182, 255, 255));
 | |
|   z-index: 3;
 | |
|   position: absolute;
 | |
|   margin-top: -58px;
 | |
| }
 | |
| ```
 |