├── LICENSE ├── README.md ├── css ├── main.css └── start-here.css ├── gulpfile.js ├── index.html ├── package-lock.json ├── package.json └── scss └── main.scss /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 Kevin Powell 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Fun with transforms and transform-origin 2 | Files that go along with my YT video taking a look at transform and transform-origin 3 | 4 | ## Follow along 5 | If you want to follow along with my tutorial or try things out on your own before watching, you can switch the linked CSS file to `start-here.css` and you'll be good to go. 6 | 7 | ## Using gulp 8 | Included is a gulpfile which includes browserSync and a Sass compiler. If you'd like to use it, you must first have node and npm installed. Go to [nodejs](https://nodejs.org/en/) and install it, then follow these steps: 9 | 10 | 1) In your terminal, navigate to the project folder on your computer 11 | 2) type `npm install` 12 | 3) Once that is finished, type `gulp watch` 13 | -------------------------------------------------------------------------------- /css/main.css: -------------------------------------------------------------------------------- 1 | *, 2 | *::before, 3 | *::after { 4 | box-sizing: border-box; 5 | } 6 | 7 | .fancy-link { 8 | text-decoration: none; 9 | color: #ee6352; 10 | position: relative; 11 | } 12 | 13 | .fancy-link::after { 14 | content: ""; 15 | position: absolute; 16 | left: 0; 17 | bottom: 0; 18 | width: 100%; 19 | height: 2px; 20 | background: currentColor; 21 | -webkit-transform: scaleX(0); 22 | transform: scaleX(0); 23 | -webkit-transform-origin: right; 24 | transform-origin: right; 25 | transition: -webkit-transform 250ms ease-in; 26 | transition: transform 250ms ease-in; 27 | transition: transform 250ms ease-in, -webkit-transform 250ms ease-in; 28 | } 29 | 30 | .fancy-link:hover::after { 31 | -webkit-transform: scaleX(1); 32 | transform: scaleX(1); 33 | -webkit-transform-origin: left; 34 | transform-origin: left; 35 | } 36 | 37 | .button { 38 | cursor: pointer; 39 | border: 0; 40 | background: #ee6352; 41 | color: white; 42 | padding: 1em 1.5em; 43 | position: relative; 44 | z-index: 1; 45 | } 46 | 47 | .button + .button { 48 | margin-left: 1em; 49 | } 50 | 51 | .button::after { 52 | content: ""; 53 | position: absolute; 54 | top: 0; 55 | left: 0; 56 | width: 100%; 57 | height: 100%; 58 | background: rgba(0, 0, 0, 0.5); 59 | z-index: -1; 60 | transition: -webkit-transform 200ms ease-in; 61 | transition: transform 200ms ease-in; 62 | transition: transform 200ms ease-in, -webkit-transform 200ms ease-in; 63 | } 64 | 65 | .button-one::after { 66 | -webkit-transform: scaleX(0); 67 | transform: scaleX(0); 68 | -webkit-transform-origin: right; 69 | transform-origin: right; 70 | } 71 | 72 | .button-one:hover::after { 73 | -webkit-transform: scaleX(1); 74 | transform: scaleX(1); 75 | -webkit-transform-origin: left; 76 | transform-origin: left; 77 | } 78 | 79 | .button-two::after { 80 | -webkit-transform: scaleY(0); 81 | transform: scaleY(0); 82 | -webkit-transform-origin: bottom; 83 | transform-origin: bottom; 84 | } 85 | 86 | .button-two:hover::after { 87 | -webkit-transform: scaleY(1); 88 | transform: scaleY(1); 89 | -webkit-transform-origin: top; 90 | transform-origin: top; 91 | } 92 | 93 | .button-three::after { 94 | -webkit-transform: scale(0); 95 | transform: scale(0); 96 | -webkit-transform-origin: bottom right; 97 | transform-origin: bottom right; 98 | } 99 | 100 | .button-three:hover::after { 101 | -webkit-transform: scale(1); 102 | transform: scale(1); 103 | -webkit-transform-origin: top left; 104 | transform-origin: top left; 105 | } 106 | 107 | .card { 108 | padding: 2rem; 109 | background-image: url(https://unsplash.it/600); 110 | /* placeholder image */ 111 | backgrond-size: cover; 112 | background-color: #444; 113 | background-blend-mode: multiply; 114 | color: white; 115 | text-align: left; 116 | } 117 | 118 | .card__title { 119 | position: relative; 120 | z-index: 1; 121 | display: inline-block; 122 | margin-bottom: 1rem; 123 | } 124 | 125 | .card__title::after { 126 | content: ""; 127 | position: absolute; 128 | top: -0.25rem; 129 | left: -2rem; 130 | bottom: -0.25rem; 131 | width: calc(100% + 4rem); 132 | background: #ee6352; 133 | z-index: -1; 134 | -webkit-transform: scaleX(0.075); 135 | transform: scaleX(0.075); 136 | -webkit-transform-origin: left; 137 | transform-origin: left; 138 | transition: -webkit-transform 250ms ease-in; 139 | transition: transform 250ms ease-in; 140 | transition: transform 250ms ease-in, -webkit-transform 250ms ease-in; 141 | } 142 | 143 | .card:hover .card__title::after { 144 | -webkit-transform: scaleX(1); 145 | transform: scaleX(1); 146 | } 147 | 148 | .card__body { 149 | position: relative; 150 | z-index: 1; 151 | color: transparent; 152 | margin: 0; 153 | transition: color 150ms 350ms; 154 | } 155 | 156 | .card__body::after { 157 | content: ""; 158 | position: absolute; 159 | top: -0.75rem; 160 | bottom: -0.75rem; 161 | left: -0.75em; 162 | right: -0.75em; 163 | background: white; 164 | z-index: -1; 165 | -webkit-transform: scaleY(0); 166 | transform: scaleY(0); 167 | transition: -webkit-transform 250ms ease-in 250ms; 168 | transition: transform 250ms ease-in 250ms; 169 | transition: transform 250ms ease-in 250ms, -webkit-transform 250ms ease-in 250ms; 170 | -webkit-transform-origin: top; 171 | transform-origin: top; 172 | } 173 | 174 | .card:hover .card__body { 175 | color: #333; 176 | } 177 | 178 | .card:hover .card__body::after { 179 | -webkit-transform: scaleY(1); 180 | transform: scaleY(1); 181 | } 182 | 183 | body { 184 | font-family: basic-sans, sans-serif; 185 | min-height: 100vh; 186 | display: flex; 187 | flex-direction: column; 188 | justify-content: center; 189 | align-items: center; 190 | font-size: 1.125em; 191 | line-height: 1.6; 192 | color: #333; 193 | background: #ddd; 194 | } 195 | 196 | .content { 197 | background: white; 198 | width: 70vw; 199 | padding: 3em; 200 | box-shadow: 0 0 3em rgba(0, 0, 0, 0.15); 201 | text-align: center; 202 | margin-bottom: 1em; 203 | } 204 | 205 | .title { 206 | margin: 0 0 0.5em; 207 | text-transform: uppercase; 208 | font-weight: 900; 209 | font-style: italic; 210 | font-size: 3rem; 211 | color: #ee6352; 212 | line-height: 0.8; 213 | } 214 | 215 | /*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"main.css","sources":["main.scss"],"sourcesContent":["*,\r\n*::before,\r\n*::after {\r\n  box-sizing: border-box;\r\n}\r\n\r\n.fancy-link {\r\n  text-decoration: none;\r\n  color: #ee6352;\r\n  position: relative;\r\n}\r\n\r\n.fancy-link::after {\r\n  content: \"\";\r\n  position: absolute;\r\n  left: 0;\r\n  bottom: 0;\r\n  width: 100%;\r\n  height: 2px;\r\n  background: currentColor;\r\n\r\n  transform: scaleX(0);\r\n  transform-origin: right;\r\n  transition: transform 250ms ease-in;\r\n}\r\n\r\n.fancy-link:hover::after {\r\n  transform: scaleX(1);\r\n  transform-origin: left;\r\n}\r\n\r\n.button {\r\n  cursor: pointer;\r\n  border: 0;\r\n  background: #ee6352;\r\n  color: white;\r\n  padding: 1em 1.5em;\r\n  position: relative;\r\n  z-index: 1;\r\n}\r\n\r\n.button + .button {\r\n  margin-left: 1em;\r\n}\r\n\r\n.button::after {\r\n  content: \"\";\r\n  position: absolute;\r\n  top: 0;\r\n  left: 0;\r\n  width: 100%;\r\n  height: 100%;\r\n  background: rgba(0, 0, 0, 0.5);\r\n  z-index: -1;\r\n  transition: transform 200ms ease-in;\r\n}\r\n\r\n.button-one::after {\r\n  transform: scaleX(0);\r\n  transform-origin: right;\r\n}\r\n\r\n.button-one:hover::after {\r\n  transform: scaleX(1);\r\n  transform-origin: left;\r\n}\r\n\r\n.button-two::after {\r\n  transform: scaleY(0);\r\n  transform-origin: bottom;\r\n}\r\n\r\n.button-two:hover::after {\r\n  transform: scaleY(1);\r\n  transform-origin: top;\r\n}\r\n\r\n.button-three::after {\r\n  transform: scale(0);\r\n  transform-origin: bottom right;\r\n}\r\n\r\n.button-three:hover::after {\r\n  transform: scale(1);\r\n  transform-origin: top left;\r\n}\r\n\r\n.card {\r\n  padding: 2rem;\r\n  background-image: url(https://unsplash.it/600); /* placeholder image */\r\n  backgrond-size: cover;\r\n  background-color: #444;\r\n  background-blend-mode: multiply;\r\n  color: white;\r\n  text-align: left;\r\n}\r\n\r\n.card__title {\r\n  position: relative;\r\n  z-index: 1;\r\n  display: inline-block;\r\n  margin-bottom: 1rem;\r\n}\r\n\r\n.card__title::after {\r\n  content: \"\";\r\n  position: absolute;\r\n  top: -0.25rem;\r\n  left: -2rem;\r\n  bottom: -0.25rem;\r\n  width: calc(100% + 4rem);\r\n  background: #ee6352;\r\n  z-index: -1;\r\n\r\n  transform: scaleX(0.075);\r\n  transform-origin: left;\r\n  transition: transform 250ms ease-in;\r\n}\r\n\r\n.card:hover .card__title::after {\r\n  transform: scaleX(1);\r\n}\r\n\r\n.card__body {\r\n  position: relative;\r\n  z-index: 1;\r\n  color: transparent;\r\n  margin: 0;\r\n  transition: color 150ms 350ms;\r\n}\r\n\r\n.card__body::after {\r\n  content: \"\";\r\n  position: absolute;\r\n  top: -0.75rem;\r\n  bottom: -0.75rem;\r\n  left: -0.75em;\r\n  right: -0.75em;\r\n  background: white;\r\n  z-index: -1;\r\n  transform: scaleY(0);\r\n  transition: transform 250ms ease-in 250ms;\r\n  transform-origin: top;\r\n}\r\n\r\n.card:hover .card__body {\r\n  color: #333;\r\n}\r\n\r\n.card:hover .card__body::after {\r\n  transform: scaleY(1);\r\n}\r\n\r\nbody {\r\n  font-family: basic-sans, sans-serif;\r\n  min-height: 100vh;\r\n  display: flex;\r\n  flex-direction: column;\r\n  justify-content: center;\r\n  align-items: center;\r\n  font-size: 1.125em;\r\n  line-height: 1.6;\r\n  color: #333;\r\n  background: #ddd;\r\n}\r\n\r\n.content {\r\n  background: white;\r\n  width: 70vw;\r\n  padding: 3em;\r\n  box-shadow: 0 0 3em rgba(0, 0, 0, 0.15);\r\n  text-align: center;\r\n  margin-bottom: 1em;\r\n}\r\n\r\n.title {\r\n  margin: 0 0 0.5em;\r\n  text-transform: uppercase;\r\n  font-weight: 900;\r\n  font-style: italic;\r\n  font-size: 3rem;\r\n  color: #ee6352;\r\n  line-height: 0.8;\r\n}\r\n"],"names":[],"mappings":"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"} */ 216 | -------------------------------------------------------------------------------- /css/start-here.css: -------------------------------------------------------------------------------- 1 | *, 2 | *::before, 3 | *::after { 4 | box-sizing: border-box; 5 | } 6 | 7 | .fancy-link { 8 | text-decoration: none; 9 | color: #ee6352; 10 | } 11 | 12 | .button { 13 | cursor: pointer; 14 | border: 0; 15 | background: #ee6352; 16 | color: white; 17 | padding: 1em 1.5em; 18 | } 19 | 20 | .button + .button { 21 | margin-left: 1em; 22 | } 23 | 24 | .card { 25 | padding: 2rem; 26 | background-image: url(https://unsplash.it/600); 27 | /* placeholder image */ 28 | backgrond-size: cover; 29 | background-color: #444; 30 | background-blend-mode: multiply; 31 | color: white; 32 | text-align: left; 33 | } 34 | 35 | body { 36 | font-family: basic-sans, sans-serif; 37 | min-height: 100vh; 38 | display: flex; 39 | flex-direction: column; 40 | justify-content: center; 41 | align-items: center; 42 | font-size: 1.125em; 43 | line-height: 1.6; 44 | color: #333; 45 | background: #ddd; 46 | } 47 | 48 | .content { 49 | background: white; 50 | width: 70vw; 51 | padding: 3em; 52 | box-shadow: 0 0 3em rgba(0, 0, 0, 0.15); 53 | text-align: center; 54 | margin-bottom: 1em; 55 | } 56 | 57 | .title { 58 | margin: 0 0 0.5em; 59 | text-transform: uppercase; 60 | font-weight: 900; 61 | font-style: italic; 62 | font-size: 3rem; 63 | color: #ee6352; 64 | line-height: 0.8; 65 | } 66 | 67 | /*# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFpbi5jc3MiLCJzb3VyY2VzIjpbIm1haW4uc2NzcyJdLCJzb3VyY2VzQ29udGVudCI6WyIqLFxyXG4qOjpiZWZvcmUsXHJcbio6OmFmdGVyIHtcclxuICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xyXG59XHJcblxyXG4uZmFuY3ktbGluayB7XHJcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xyXG4gIGNvbG9yOiAjZWU2MzUyO1xyXG59XHJcblxyXG4uYnV0dG9uIHtcclxuICBjdXJzb3I6IHBvaW50ZXI7XHJcbiAgYm9yZGVyOiAwO1xyXG4gIGJhY2tncm91bmQ6ICNlZTYzNTI7XHJcbiAgY29sb3I6IHdoaXRlO1xyXG4gIHBhZGRpbmc6IDFlbSAxLjVlbTtcclxufVxyXG5cclxuLmJ1dHRvbiArIC5idXR0b24ge1xyXG4gIG1hcmdpbi1sZWZ0OiAxZW07XHJcbn1cclxuXHJcbi5jYXJkIHtcclxuICBwYWRkaW5nOiAycmVtO1xyXG4gIGJhY2tncm91bmQtaW1hZ2U6IHVybChodHRwczovL3Vuc3BsYXNoLml0LzYwMCk7IC8qIHBsYWNlaG9sZGVyIGltYWdlICovXHJcbiAgYmFja2dyb25kLXNpemU6IGNvdmVyO1xyXG4gIGJhY2tncm91bmQtY29sb3I6ICM0NDQ7XHJcbiAgYmFja2dyb3VuZC1ibGVuZC1tb2RlOiBtdWx0aXBseTtcclxuICBjb2xvcjogd2hpdGU7XHJcbiAgdGV4dC1hbGlnbjogbGVmdDtcclxufVxyXG5cclxuLmNhcmRfX3RpdGxlIHtcclxufVxyXG5cclxuYm9keSB7XHJcbiAgZm9udC1mYW1pbHk6IGJhc2ljLXNhbnMsIHNhbnMtc2VyaWY7XHJcbiAgbWluLWhlaWdodDogMTAwdmg7XHJcbiAgZGlzcGxheTogZmxleDtcclxuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xyXG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xyXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgZm9udC1zaXplOiAxLjEyNWVtO1xyXG4gIGxpbmUtaGVpZ2h0OiAxLjY7XHJcbiAgY29sb3I6ICMzMzM7XHJcbiAgYmFja2dyb3VuZDogI2RkZDtcclxufVxyXG5cclxuLmNvbnRlbnQge1xyXG4gIGJhY2tncm91bmQ6IHdoaXRlO1xyXG4gIHdpZHRoOiA3MHZ3O1xyXG4gIHBhZGRpbmc6IDNlbTtcclxuICBib3gtc2hhZG93OiAwIDAgM2VtIHJnYmEoMCwgMCwgMCwgMC4xNSk7XHJcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xyXG4gIG1hcmdpbi1ib3R0b206IDFlbTtcclxufVxyXG5cclxuLnRpdGxlIHtcclxuICBtYXJnaW46IDAgMCAwLjVlbTtcclxuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xyXG4gIGZvbnQtd2VpZ2h0OiA5MDA7XHJcbiAgZm9udC1zdHlsZTogaXRhbGljO1xyXG4gIGZvbnQtc2l6ZTogM3JlbTtcclxuICBjb2xvcjogI2VlNjM1MjtcclxuICBsaW5lLWhlaWdodDogMC44O1xyXG59XHJcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxBQUFBLENBQUM7QUFDRCxDQUFDLEFBQUEsUUFBUTtBQUNULENBQUMsQUFBQSxPQUFPLENBQUM7RUFDUCxVQUFVLEVBQUUsVUFBVTtDQUN2Qjs7QUFFRCxBQUFBLFdBQVcsQ0FBQztFQUNWLGVBQWUsRUFBRSxJQUFJO0VBQ3JCLEtBQUssRUFBRSxPQUFPO0NBQ2Y7O0FBRUQsQUFBQSxPQUFPLENBQUM7RUFDTixNQUFNLEVBQUUsT0FBTztFQUNmLE1BQU0sRUFBRSxDQUFDO0VBQ1QsVUFBVSxFQUFFLE9BQU87RUFDbkIsS0FBSyxFQUFFLEtBQUs7RUFDWixPQUFPLEVBQUUsU0FBUztDQUNuQjs7QUFFRCxBQUFBLE9BQU8sR0FBRyxPQUFPLENBQUM7RUFDaEIsV0FBVyxFQUFFLEdBQUc7Q0FDakI7O0FBRUQsQUFBQSxLQUFLLENBQUM7RUFDSixPQUFPLEVBQUUsSUFBSTtFQUNiLGdCQUFnQixFQUFFLDRCQUE0QjtFQUFFLHVCQUF1QjtFQUN2RSxjQUFjLEVBQUUsS0FBSztFQUNyQixnQkFBZ0IsRUFBRSxJQUFJO0VBQ3RCLHFCQUFxQixFQUFFLFFBQVE7RUFDL0IsS0FBSyxFQUFFLEtBQUs7RUFDWixVQUFVLEVBQUUsSUFBSTtDQUNqQjs7QUFLRCxBQUFBLElBQUksQ0FBQztFQUNILFdBQVcsRUFBRSxzQkFBc0I7RUFDbkMsVUFBVSxFQUFFLEtBQUs7RUFDakIsT0FBTyxFQUFFLElBQUk7RUFDYixjQUFjLEVBQUUsTUFBTTtFQUN0QixlQUFlLEVBQUUsTUFBTTtFQUN2QixXQUFXLEVBQUUsTUFBTTtFQUNuQixTQUFTLEVBQUUsT0FBTztFQUNsQixXQUFXLEVBQUUsR0FBRztFQUNoQixLQUFLLEVBQUUsSUFBSTtFQUNYLFVBQVUsRUFBRSxJQUFJO0NBQ2pCOztBQUVELEFBQUEsUUFBUSxDQUFDO0VBQ1AsVUFBVSxFQUFFLEtBQUs7RUFDakIsS0FBSyxFQUFFLElBQUk7RUFDWCxPQUFPLEVBQUUsR0FBRztFQUNaLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7RUFDdkMsVUFBVSxFQUFFLE1BQU07RUFDbEIsYUFBYSxFQUFFLEdBQUc7Q0FDbkI7O0FBRUQsQUFBQSxNQUFNLENBQUM7RUFDTCxNQUFNLEVBQUUsU0FBUztFQUNqQixjQUFjLEVBQUUsU0FBUztFQUN6QixXQUFXLEVBQUUsR0FBRztFQUNoQixVQUFVLEVBQUUsTUFBTTtFQUNsQixTQUFTLEVBQUUsSUFBSTtFQUNmLEtBQUssRUFBRSxPQUFPO0VBQ2QsV0FBVyxFQUFFLEdBQUc7Q0FDakIifQ== */ 68 | -------------------------------------------------------------------------------- /gulpfile.js: -------------------------------------------------------------------------------- 1 | const gulp = require("gulp"); 2 | const sass = require("gulp-sass"); 3 | const sourcemaps = require("gulp-sourcemaps"); 4 | const autoprefixer = require("gulp-autoprefixer"); 5 | const browserSync = require("browser-sync").create(); 6 | 7 | const sassOptions = { 8 | outputStyle: "expanded" 9 | }; 10 | 11 | // compile scss into css 12 | 13 | function style() { 14 | return gulp 15 | .src("./scss/**/*.scss") 16 | .pipe(sourcemaps.init()) 17 | .pipe(sass(sassOptions).on("error", sass.logError)) 18 | .pipe(sourcemaps.write()) 19 | .pipe(autoprefixer()) 20 | .pipe(gulp.dest("./css")) 21 | .pipe(browserSync.stream()); 22 | } 23 | 24 | function watch() { 25 | browserSync.init({ 26 | server: "." 27 | }); 28 | gulp.watch("./scss/**/*.scss", style); 29 | gulp.watch("./*.html").on("change", browserSync.reload); 30 | gulp.watch("./js/**/*.js", browserSync.reload); 31 | } 32 | 33 | exports.style = style; 34 | exports.watch = watch; 35 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 |
4 | 5 | 6 | 7 |Lorem ipsum dolor sit amet.
29 |