#wrap
-6.times do
.ticket
View Compiled
@font-face {
font-family: "Cooper";
src: url("https://assets.codepen.io/383755/cooper-black-webfont.woff")
format("woff");
}
@font-face {
font-family: "Aharoni";
src: url("https://assets.codepen.io/383755/telefon.woff2") format("woff");
}
@font-face {
font-family: "Bogart";
src: url("https://assets.codepen.io/383755/bogart-semibold.woff2")
format("woff2");
font-weight: normal;
font-style: normal;
}
@font-face {
font-family: "Dot";
src: url("https://assets.codepen.io/383755/Dot-Matrix.ttf.woff") format("woff");
}
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@300;500&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Coustard:wght@900&display=swap");
$noise: url("");
* {
box-sizing: border-box;
}
@mixin flex-center() {
display: flex;
justify-content: center;
align-items: center;
flex-wrap: wrap;
}
@function text-stroke($size: 2, $color: #fff, $correction: 0) {
$radius: $size - $correction;
$stroke: ();
@for $i from -$size through $size {
@for $k from -$size through $size {
$x: $k;
$y: $i;
@if $k > 0 {
$x: $k - 0.5;
}
@elseif $k < 0 {
$x: $k + 0.5;
}
@if $i > 0 {
$y: $i - 0.5;
}
@elseif $i < 0 {
$y: $i + 0.5;
}
@if ($x * $x + $y * $y <= $radius * $radius) {
$stroke: append($stroke, $i * 1px $k * 1px 0 $color, comma);
}
}
}
@return $stroke;
}
@mixin text-stroke($size: 2, $color: #fff, $correction: 0) {
text-shadow: text-stroke($size, $color, $correction);
}
body {
margin: 0px;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
overflow: hidden;
font-family: "Oswald";
cursor: pointer;
--dark: #50303f;
--font1: "Cooper";
--font2: "Oswald";
--font4: "Cooper";
--font5: "Bogart";
--font6: "Oswald";
--font7: "Aharoni";
--font8: "Coustard";
--color1: #fe2fd9;
--color2: #fa6c4b;
--color3: #e5f31b;
--color4: #5030da;
--color5: #ff3641;
--color6: #e5f31b;
--color7: #fe2fd9;
background: repeating-radial-gradient(
circle at center,
transparent 0px,
#fff 0px,
#fff 2px,
transparent 2px,
transparent 10px
),
radial-gradient(circle at center, #fff 25vw, #e5f4d1);
&:before {
content: "click to remix";
position: absolute;
bottom: 5px;
width: 100%;
left: 0;
text-align: center;
color: var(--dark);
}
&.active {
#wrap {
.ticket {
@for $i from 1 through 6 {
&:nth-of-type(#{$i}) {
z-index: #{6 - $i};
.inner {
&:before {
transition-delay: #{0.15 + ($i/10)}s;
opacity: 1;
}
> div {
transition-delay: #{$i/10}s;
&:before,
&:after {
transition-delay: #{0.15 + ($i/10)}s;
box-shadow: inset -100px 0px 100px -200px rgba(0, 0, 0, 0.15),
inset 0 0 3rem -3rem var(--dark), inset 0 0 0 0.5rem var(--color1);
}
&:after {
box-shadow: inset 100px 0px 100px 100px rgba(0, 0, 0, 0.15),
inset 0 0 2rem 0.075rem var(--dark),
inset 0 0 0 0.5rem lighten(#e5f4d1, 5%);
}
}
}
}
}
.inner {
> div {
transform: translateY(0);
}
}
}
}
}
&.loaded {
#wrap {
opacity: 1;
}
}
#wrap {
width: clamp(662.5px, 80vw, 1325px);
min-width: 662.5px;
height: clamp(500px, 60vw, 1000px);
min-height: 500px;
display: grid;
grid-template-columns: repeat(8, 1fr);
grid-template-rows: repeat(6, 1fr);
grid-gap: 0rem;
transition: 0.5s ease-in-out;
transition-delay: 1s;
opacity: 0;
.ticket {
position: relative;
@for $i from 1 through 6 {
&:nth-of-type(#{$i}) {
z-index: #{8 - $i};
.inner {
&:before {
transition: 0.5s cubic-bezier(0.5, 0.15, 0.35, 1);
transition-delay: #{(6 - $i) / 10}s;
opacity: 0;
}
> div {
transition-delay: #{(6 - $i) / 10}s;
&:before,
&:after {
transition-delay: #{0.15 + (6 - $i)/10}s;
}
}
}
}
}
.inner {
position: absolute;
height: 100%;
width: 100%;
left: 0;
top: 0;
padding: 1rem;
clip-path: polygon(-10% -10%, 110% -10%, 110% 110%, -10% 110%);
transform-style: preserve-3d;
perspective: 900px;
&:before {
content: "";
position: absolute;
width: 90%;
height: 90%;
top: 10%;
left: 5%;
background: rgba(0, 0, 0, 0.25);
filter: blur(15px);
}
&.class1 {
.details {
grid-row: 1 / span 1;
}
}
&.class2 {
.seat {
grid-row: 3 / span 1;
}
}
&.class2,
&.class3 {
.band {
background: radial-gradient(
circle at center,
#e5f4d1 35%,
transparent 35%,
var(--color1) 75%
),
radial-gradient(
circle at center,
#e5f4d1 2px,
var(--color1) 1px,
var(--color1) 5px
)
50% 50% / 8px 8px repeat;
}
}
&.class3 {
.band {
text-transform: uppercase;
}
}
&.class5,
&.class6 {
> div {
grid-template-columns: calc(33% - 0.125rem) calc(33% - 0.125rem) calc(
33% - 0.125rem
);
> div {
grid-column: span 3;
&.band {
strong {
span.word {
display: inline-block;
margin: 0 0.15vw;
}
}
}
&.band,
&.location {
grid-column: 1 / span 2;
grid-row: span 6;
position: relative;
strong {
width: 200%;
left: -50%;
height: 50%;
top: 25%;
position: absolute;
padding: 0 1rem;
transform: rotate(90deg);
word-break: break-word;
}
}
&.location {
grid-column: 3 / span 1;
strong {
width: 400%;
height: 12.5%;
top: 45%;
left: -150%;
@include flex-center();
@include text-stroke(1, #e5f4d1);
&:before {
content: "";
position: absolute;
width: 90%;
left: 5%;
top: -5%;
height: 110%;
background: var(--color1);
mask: $noise;
opacity: 0.75;
}
span {
display: block;
width: 100%;
font-size: clamp(10px, 1vw, 1vw);
&:first-of-type {
font-size: clamp(12px, 1.35vw, 1.35vw);
@include text-stroke(1, #e5f4d1);
}
}
}
}
}
}
}
&.class7 {
.band {
background: radial-gradient(
circle at center,
#e5f4d1 35%,
transparent 35%,
var(--color1) 75%
),
repeating-linear-gradient(
var(--rotate),
#e5f4d1 2px,
var(--color1) 2px,
var(--color1) 10px,
#e5f4d1 10px,
#e5f4d1 12px
);
}
}
&.class9 {
.band {
strong {
span.word {
transform: skew(5deg);
}
}
}
}
&.class10,
&.class11 {
.band {
background: radial-gradient(
circle at center,
#e5f4d1 35%,
transparent 35%,
var(--color1) 75%
),
repeating-linear-gradient(
var(--rotate),
#e5f4d1 2px,
var(--color1) 2px,
var(--color1) 10px,
#e5f4d1 10px,
#e5f4d1 12px
);
}
}
> div {
display: grid;
grid-template-columns: calc(100% - 0.25rem);
grid-template-rows: repeat(10, 1fr);
justify-content: center;
height: 100%;
background: var(--dark);
grid-gap: 0.125rem;
padding: 0.125rem 0;
position: relative;
transition: 0.5s cubic-bezier(0.5, 0.15, 0.35, 1);
transform-style: preserve-3d;
transform: rotateY(180deg);
&:before,
&:after {
transform-style: preserve-3d;
content: "";
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
z-index: 2;
box-shadow: inset -200px 0px 100px 100px rgba(0, 0, 0, 0.25),
inset 0 0 3rem -2rem var(--dark), inset 0 0 0 0.5rem var(--color1);
transition: box-shadow 0.5s cubic-bezier(0.5, 0.15, 0.35, 1);
}
&:before {
background: #e5f4d1;
mask: $noise;
opacity: 0.5;
width: calc(100% + 0.5vw);
height: calc(100% + 0.5vw);
left: -0.25vw;
top: -0.25vw;
backface-visibility: hidden;
}
&:after {
transform: rotateY(-180deg) translateZ(0.05px);
background: lighten(#e5f4d1, 5%);
box-shadow: inset 100px 0px 100px -200px rgba(0, 0, 0, 0.15),
inset 0 0 6rem -6rem var(--dark), inset 0 0 0 0.5rem lighten(#e5f4d1, 5%);
}
> div {
box-sizing: border-box;
background: var(--color1);
box-shadow: inherit;
line-height: 1;
grid-row: span 1;
text-align: center;
@include flex-center();
}
}
.date {
text-transform: uppercase;
grid-row: span 2;
@include flex-center();
padding: 0.75vw 0;
background: #e5f4d1;
span {
display: block;
font-size: clamp(10px, 1vw, 1vw);
width: 100%;
}
> span:nth-of-type(2) {
font-size: clamp(16px, 2vw, 2vw);
font-family: var(--font2);
}
}
.band {
grid-row: span 5;
position: relative;
font-family: var(--font1);
overflow: hidden;
background: radial-gradient(
circle at center,
#e5f4d1 37.5%,
transparent 35%,
var(--color1) 90%
),
repeating-radial-gradient(
circle at center,
transparent 0px,
#e5f4d1 0px,
#e5f4d1 2px,
var(--color1) 2px,
var(--color1) 10px
);
strong {
@include flex-center();
position: absolute;
width: 102.5%;
height: 75%;
left: -1.25%;
top: 12.5%;
padding: 0 0.5rem;
transform: rotate(90deg);
font-size: clamp(20px, 2.35vw, 2.35vw);
word-break: break-word;
line-height: 0.95;
--words: var(--word-total);
letter-spacing: 0.15rem;
transform: scale(calc(1 + (var(--word-total) / 20)));
> span.word {
display: inline-block;
}
> span > span.word {
display: block;
@include text-stroke(1, #e5f4d1);
font-size: clamp(
18px,
calc(7vw - (((var(--char-total) * 1) * (var(--words) / 1.5)) * 0.35vw)),
2.75vw
);
}
}
}
.details {
display: flex;
align-items: stretch;
strong {
width: 100%;
display: flex;
span {
width: 50%;
box-shadow: inset 0.05vw 0 0 var(--dark), inset -0.05vw 0 0 var(--dark);
@include flex-center();
}
}
}
.location {
strong span {
font-size: 1vw;
display: block;
font-weight: 200;
line-height: 1.25;
&:first-of-type {
font-size: clamp(8px, 1.25vw, 1.25vw);
font-weight: 900;
}
}
}
.seat {
display: flex;
justify-content: space-between;
background: #e5f4d1;
strong {
font-size: clamp(8px, 1.25vw, 1.25vw);
display: flex;
justify-content: center;
align-items: center;
flex-wrap: wrap;
width: 33.33%;
padding: 0.5rem;
&:nth-of-type(2) {
box-shadow: 0.075rem 0 0 var(--dark), -0.075rem 0 0 var(--dark),
inset 0.075rem 0 0 var(--dark), inset -0.075rem 0 0 var(--dark);
}
> span {
display: block;
margin: 0.25rem 0 0;
width: 100%;
font-size: clamp(16px, 2vw, 2vw);
text-transform: uppercase;
font-family: "Dot", cursive;
font-weight: 100;
color: var(--color2);
}
}
}
}
&:nth-of-type(1) {
grid-area: 3 / 1 / 7 / 3;
.inner {
transform-origin: 0% 0%;
transform: rotate(-90deg);
}
}
&:nth-of-type(2) {
grid-area: 3 / 1 / 7 / 3;
}
&:nth-of-type(3) {
grid-area: 3 / 3 / 7 / 5;
}
&:nth-of-type(4) {
grid-area: 1 / 5 / 5 / 7;
}
&:nth-of-type(5) {
grid-area: 1 / 7 / 5 / 9;
}
&:nth-of-type(6) {
grid-area: 1 / 5 / 5 / 7;
.inner {
transform-origin: 0% 100%;
transform: rotate(90deg);
}
}
}
}
}
View Compiled
const bands = [];
const cities = [];
const venues = [];
const row = "abcdefghijklmnopqrstuvwxyz";
let days = [
"Sunday",
"Monday",
"Tuesday",
"Wednesday",
"Thursday",
"Friday",
"Saturday"
];
let months = [
"January",
"February",
"March",
"April",
"May",
"June",
"July",
"August",
"September",
"October",
"November",
"December"
];
function randomDate(start, end) {
return new Date(
start.getTime() + Math.random() * (end.getTime() - start.getTime())
);
}
$(document).ready(function () {
var lastFM =
"https://ws.audioscrobbler.com/2.0/?api_key=5908c0487c4b5f26281c158dd83b59d6&format=json&method=user.getTopArtists&user=adamkuhn&period=overall&limit=200";
var cityData =
"https://random-data-api.com/api/address/random_address?size=50";
$.getJSON(cityData, function (data) {
$.each(data, function (i, item) {
venues.push(data[i].community + " Theater");
cities.push(data[i].city + ", " + data[i].state);
});
$.getJSON(lastFM, function (data) {
$.each(data.topartists.artist, function (i, item) {
bands.push(data.topartists.artist[i].name);
});
createTicket();
$("body").addClass("loaded");
});
});
});
$(document).click(function () {
createTicket();
});
function createTicket() {
$("body").removeClass("active");
setTimeout(() => {
$(".ticket").each(function () {
$(this).find(".inner").remove();
let randBand = Math.floor(Math.random() * bands.length);
let randCity = Math.floor(Math.random() * cities.length);
let randVenue = Math.floor(Math.random() * venues.length);
let randDate = randomDate(new Date(2021, 0, 1), new Date());
$(this)
.get(0)
.style.setProperty(
"--font1",
"var(--font" + Math.floor(Math.random() * (7 - 1) + 4) + ")"
);
$(this)
.get(0)
.style.setProperty(
"--font2",
"var(--font" + Math.floor(Math.random() * (7 - 1) + 4) + ")"
);
$(this)
.get(0)
.style.setProperty(
"--color1",
"var(--color" + Math.floor(Math.random() * (6 - 1) + 3) + ")"
);
$(this)
.get(0)
.style.setProperty(
"--rotate",
Math.floor(Math.random() * (5 - 1) + 1) * 45 + "deg"
);
$(this).append(
"<div class='inner class" +
Math.floor(Math.random() * (8 - 1) + 1) +
" class" +
Math.floor(Math.random() * (8 - 1) + 7) +
"'><div><div class='date'><span>" +
days[randDate.getDay()] +
"</span><span>" +
months[randDate.getMonth()] +
" " +
randDate.getDate() +
"</span><span>" +
Math.floor(Math.random() * (12 - 1) + 1) +
":00 PM</span></div><div class='band'><strong data-splitting='words'><span>" +
bands[randBand] +
"</span></strong></div><div class='location'><strong><span>" +
venues[randVenue] +
"</span><span>" +
cities[randCity] +
"</span></strong></div><div class='seat'><strong>Section<span>" +
Math.floor(Math.random() * (40 - 1) + 1) +
"</span></strong><strong>Row<span>" +
row[Math.floor(Math.random() * row.length)] +
"</span></strong><strong>Seat<span>" +
Math.floor(Math.random() * (40 - 1) + 1) +
"</span></strong></div><div class='details'><strong><span>$" +
Math.floor(Math.random() * (20 - 5) + 5) +
".00</span><span>All Ages</span></strong></div></div></div>"
);
});
Splitting();
$("span.word").attr("data-splitting", "chars");
Splitting();
}, 1000);
setTimeout(() => {
$("body").addClass("active");
}, 1500);
}
This Pen doesn't use any external CSS resources.