Glassmorphism New Year Card Design with Confetti using HTML, CSS & JavaScript

Glassmorphism New Year Card Design with Confetti using HTML, CSS & JavaScript
Hello developers, today in this blog you will learn to create a Glassmorphism New Year Card Design with Confetti using HTML, CSS & JavaScript.

This card is made for wishing for the New Year. The glass effect had been used in this New Year card for wishing. The Glassmorphism is used to emphasize light or dark objects, placed on top of colorful backgrounds. Confetti means small pieces of colored paper traditionally thrown over a bride and bridegroom for function.

In this blog (Glassmorphism New Year Card Design with Confetti), there is a card at the center of the page with glassmorphism. A card contains, an image at the center of the card, when you hover over the card, the image will expand and occupy the whole card at the top of the card, and the text pop down the image. To celebrate the function of a new year we used confetti, where multiple color papers fall.

The source code of this Glassmorphism New Year Card Design with Confetti is given below, if you want the source code of this program, you can copy it. You can use this Glassmorphism New Year Card Design with Confetti code with your creativity and can take this product card to the next level.

Glassmorphism New Year Card Design with Confetti [Source Code]

To make this website (Glassmorphism New Year Card Design with Confetti), you need to create three files: an HTML file, a CSS file & a JavaScript file. First, create an HTML file with the name of index.html and remember, you have to create a file with a .html extension.

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Glassmorphism New Year Card Design with Confetti || Learningrobo</title> <link rel="stylesheet" href="style.css"> </head> <body> <div class="container"> <div class="card"> <div class="content"> <div class="image"> <img src="https://cdn.pixabay.com/photo/2021/10/24/21/23/new-year-6739337__340.jpg" /> </div> <div class="user-content"> <h3>Happy New Year</h3> </div> </div> </div> <div class="credit">Made with <span style="color:tomato">❤</span> by <a href="https://www.learningrobo.com/">Learning Robo</a></div> </div> <script src="script.js"></script> </body> </html>
CSS provides style to an HTML page. To make the page attractive create a CSS file with the name style.css and remember that you have to create a file with a .css extension.


@import url('https://fonts.googleapis.com/css2?family=Roboto+Slab:wght@100&display=swap');

body {
  background: #333;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Roboto Slab', serif;
  overflow: hidden;
}
.card {
    height: 300px;
    width: 330px;
    padding: 6px;
    background: rgba(255, 255, 255, 0.25);
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    position: relative;
    overflow: hidden
}

.card .content .image {
    width: 150px;
    height: 150px;
    top: 0;
    left: 0;
    transition: 1s
}

.card .content .image img {
    width: 100%;
    height: 100%;
    transition: all 3s;
    border-radius: 50%;
    transition: all 0.5s;
    object-fit: cover
}

.card:hover .content .image img {
    border-radius: 0%
}

.card:hover .image {
    width: 100%;
    height: 240px;
    position: absolute;
    transition: all 1s;
    animation: image 2s
}

@keyframes image {
    from {
        top: 60px;
        left: 30%
    }
    to {
        top: 0px
    }
}
.user-content {
    margin-top: 10px
}

.user-content h3 {
	margin-top: -20px;
    text-align: center;
    transition: all 1s;
    transition-delay: 2s;
    font-size: 22px;
    letter-spacing: 3px;
    position: absolute;
    left: 50%;
    transform: translate(-50%, 50%);
    z-index: -10;
   font-family: 'Roboto Slab', serif;
}

.card:hover .user-content h3 {
    margin-top: 60px
}
.credit{
    text-align: center;
    color: #fff;
    margin-top: 30px;
    font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
}
.credit a{
    text-decoration: none;
    color: #00C9A7;
    font-weight: bold;
} 
JavaScript makes the page work functionally and the confetti is made by using JavaScript. At last, create a JavaScript file with the name of script.js, and remember that you've got to make a file with a .js extension.


class Progress {
  constructor(param = {}) {
    this.timestamp        = null;
    this.duration         = param.duration || Progress.CONST.DURATION;
    this.progress         = 0;
    this.delta            = 0;
    this.progress         = 0;
    this.isLoop           = !!param.isLoop;

    this.reset();
  }

  static get CONST() {
    return {
      DURATION : 1000
    };
  }

  reset() {
    this.timestamp = null;
  }

  start(now) {
    this.timestamp = now;
  }

  tick(now) {
    if (this.timestamp) {
      this.delta    = now - this.timestamp;
      this.progress = Math.min(this.delta / this.duration, 1);

      if (this.progress >= 1 && this.isLoop) {
        this.start(now);
      }

      return this.progress;
    } else {
      return 0;
    }
  }
}

class Confetti {
  constructor(param) {
    this.parent         = param.elm || document.body;
    this.canvas         = document.createElement("canvas");
    this.ctx            = this.canvas.getContext("2d");
    this.width          = param.width  || this.parent.offsetWidth;
    this.height         = param.height || this.parent.offsetHeight;
    this.length         = param.length || Confetti.CONST.PAPER_LENGTH;
    this.yRange         = param.yRange || this.height * 2;
    this.progress       = new Progress({
      duration : param.duration,
      isLoop   : true
    });
    this.rotationRange  = typeof param.rotationLength === "number" ? param.rotationRange
                                                                   : 10;
    this.speedRange     = typeof param.speedRange     === "number" ? param.speedRange
                                                                   : 10;
    this.sprites        = [];

    this.canvas.style.cssText = [
      "display: block",
      "position: absolute",
      "top: 0",
      "left: 0",
      "pointer-events: none"
    ].join(";");

    this.render = this.render.bind(this);

    this.build();

    this.parent.appendChild(this.canvas);
    this.progress.start(performance.now());

    requestAnimationFrame(this.render);
  }

  static get CONST() {
    return {
        SPRITE_WIDTH  : 9,
        SPRITE_HEIGHT : 10,
        PAPER_LENGTH  : 100,
        DURATION      : 8000,
        ROTATION_RATE : 50,
        COLORS        : [
          "#FD0E35",
          "#FD0E35",
          "#ccff02",
          "#ccff02",
          "#87FF2A",
          "#87FF2A",
          "#87FF2A",
          "#87FF2A",
          "#0066FF",
          "#0066FF",
          "#0066FF",
          "#0066FF",
          "#FF3399",
          "#FF3399",
          "#FF3399",
          "#FF3399",
          "#A0E6FF",
          "#A0E6FF",
          "#FF1818",
          "#FF1818"
        ]
    };
  }

  build() {
    for (let i = 0; i < this.length; ++i) {
      let canvas = document.createElement("canvas"),
          ctx    = canvas.getContext("2d");

      canvas.width  = Confetti.CONST.SPRITE_WIDTH;
      canvas.height = Confetti.CONST.SPRITE_HEIGHT;

      canvas.position = {
        initX : Math.random() * this.width,
        initY : -canvas.height - Math.random() * this.yRange
      };

      canvas.rotation = (this.rotationRange / 2) - Math.random() * this.rotationRange;
      canvas.speed    = (this.speedRange / 2) + Math.random() * (this.speedRange / 2);

      ctx.save();
        ctx.fillStyle = Confetti.CONST.COLORS[(Math.random() * Confetti.CONST.COLORS.length) | 0];
        ctx.fillRect(0, 0, canvas.width, canvas.height);
      ctx.restore();

      this.sprites.push(canvas);
    }
  }

  render(now) {
    let progress = this.progress.tick(now);

    this.canvas.width  = this.width;
    this.canvas.height = this.height;

    for (let i = 0; i < this.length; ++i) {
      this.ctx.save();
        this.ctx.translate(
          this.sprites[i].position.initX + this.sprites[i].rotation * Confetti.CONST.ROTATION_RATE * progress,
          this.sprites[i].position.initY + progress * (this.height + this.yRange)
        );
        this.ctx.rotate(this.sprites[i].rotation);
        this.ctx.drawImage(
          this.sprites[i],
          -Confetti.CONST.SPRITE_WIDTH * Math.abs(Math.sin(progress * Math.PI * 2 * this.sprites[i].speed)) / 2,
          -Confetti.CONST.SPRITE_HEIGHT / 2,
          Confetti.CONST.SPRITE_WIDTH * Math.abs(Math.sin(progress * Math.PI * 2 * this.sprites[i].speed)),
          Confetti.CONST.SPRITE_HEIGHT
        );
      this.ctx.restore();
    }

    requestAnimationFrame(this.render);
  }
}

(() => {
  const DURATION = 9000,
        LENGTH   = 120;

  new Confetti({
    width    : window.innerWidth,
    height   : window.innerHeight,
    length   : LENGTH,
    duration : DURATION
  });

  setTimeout(() => {
    new Confetti({
      width    : window.innerWidth,
      height   : window.innerHeight,
      length   : LENGTH,
      duration : DURATION
    });
  }, DURATION / 2);
})();
We hope you would like this Glassmorphism New Year Card Design with Confetti using HTML, CSS & JavaScript. "Let this year brings you more surprises and makes you more strengthen. Learning Robo wishes you a Very Happy New Year of 2022".

Thank you for reading our blog. If you face any problem in creating this Glassmorphism New Year Card Design with Confetti using HTML, CSS & JavaScript, then contact us or comment us. We’ll try to provide a solution to your problem as soon as possible.

Thank you
Learning robo team

Post a Comment

Thank you
Learning robo team

Post a Comment (0)

Previous Post Next Post
Learning Robo says...
code copied
Welcome