* 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>
		
			
				
	
	
		
			198 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 619d05c54dabca0b10058235
 | |
| title: Step 54
 | |
| challengeType: 0
 | |
| dashedName: step-54
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| So far, the `.face` and `.chin` elements have the same `background-color`.
 | |
| 
 | |
| Create a custom CSS property called `--penguin-face`, and set it to `white`.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| You should use the `:root` selector.
 | |
| 
 | |
| ```js
 | |
| assert.match(code, /:root\s*\{/);
 | |
| ```
 | |
| 
 | |
| You should give `:root` a `--penguin-face` property.
 | |
| 
 | |
| ```js
 | |
| assert.notEmpty(new __helpers.CSSHelp(document).getStyle(':root')?.getPropertyValue('--penguin-face'));
 | |
| ```
 | |
| 
 | |
| You should give `:root` a `--penguin-face` of `--fcc-expected--`, but found `--fcc-actual--`.
 | |
| 
 | |
| ```js
 | |
| assert.equal(new __helpers.CSSHelp(document).getStyle(':root')?.getPropVal('--penguin-face', true), 'white');
 | |
| ```
 | |
| 
 | |
| # --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>
 | |
|       <div class="penguin-body"></div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="ground"></div>
 | |
|   </body>
 | |
| </html>
 | |
| ```
 | |
| 
 | |
| ```css
 | |
| --fcc-editable-region--
 | |
| 
 | |
| --fcc-editable-region--
 | |
| 
 | |
| 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: white;
 | |
|   border-radius: 70% 70% 60% 60%;
 | |
|   top: 15%;
 | |
| }
 | |
| 
 | |
| .face.left {
 | |
|   left: 5%;
 | |
| }
 | |
| 
 | |
| .face.right {
 | |
|   right: 5%;
 | |
| }
 | |
| 
 | |
| .chin {
 | |
|   width: 90%;
 | |
|   height: 70%;
 | |
|   background-color: white;
 | |
|   top: 25%;
 | |
|   left: 5%;
 | |
|   border-radius: 70% 70% 100% 100%;
 | |
| }
 | |
| 
 | |
| .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;
 | |
| }
 | |
| ```
 |