Complete Code For Creating Animated Popup Chat Window Using CSS
<html>
<head>
<meta charset="UTF-8">
<title>How To Create Animated Popup Chat Window Using CSS</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<script src='http://code.jquery.com/jquery-1.11.3.min.js'></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
</head>
<style>
.fabs {
bottom: 0;
position: fixed;
margin: 1em;
right: 0;
z-index: 998;
}
.fab {
display: block;
width: 56px;
height: 56px;
border-radius: 50%;
text-align: center;
color: #f0f0f0;
margin: 25px auto 0;
box-shadow: 0 0 4px rgba(0, 0, 0, .14), 0 4px 8px rgba(0, 0, 0, .28);
cursor: pointer;
-webkit-transition: all .1s ease-out;
transition: all .1s ease-out;
position: relative;
z-index: 998;
overflow: hidden;
background: yellowgreen;
}
/*Chatbox*/
.chat {
position: fixed;
right: 85px;
bottom: 20px;
width: 400px;
font-size: 12px;
line-height: 22px;
font-family: 'Roboto';
font-weight: 500;
-webkit-font-smoothing: antialiased;
font-smoothing: antialiased;
opacity: 0;
box-shadow: 1px 1px 100px 2px rgba(0, 0, 0, 0.22);
border-radius: 10px;
-webkit-transition: all .2s ease-out;
-webkit-transition: all .2s ease-in-out;
transition: all .2s ease-in-out;
}
.chat_header {
/* margin: 10px; */
font-size: 13px;
font-family: 'Roboto';
font-weight: 500;
color: #f3f3f3;
height: 100px;
background: yellowgreen;
border-top-left-radius: 10px;
border-top-right-radius: 10px;
padding-top: 8px;
}
.chat_header2 {
/* margin: 10px; */
border-top-left-radius: 0px;
border-top-right-radius: 0px;
}
.chat_header .span {
float: right;
}
.chat_fullscreen_loader {
display: none;
float: right;
cursor: pointer;
/* margin: 10px; */
font-size: 20px;
opacity: 0.5;
/* padding: 20px; */
margin: -10px 10px;
}
.chat.is-visible {
opacity: 1;
-webkit-animation: zoomIn .2s cubic-bezier(.42, 0, .58, 1);
animation: zoomIn .2s cubic-bezier(.42, 0, .58, 1);
}
.is-hide {
opacity: 0
}
.chat_option {
text-align: center;
}
.chat_option img {
border-radius: 50%;
width: 55px;
float: left;
/* padding: 0px 20px 0px 20px; */
margin: -36px 105px 10px 105px;
border: 4px solid rgba(0, 0, 0, 0.21);
text-align: center;
}
.change_img img {
width: 35px;
margin: 0px 20px 0px 20px;
}
.chat_option .agent {
font-size: 12px;
font-weight: 300;
}
.chat_option .online {
opacity: 0.4;
font-size: 11px;
font-weight: 300;
}
.chat_body {
background: #fff;
width: 100%;
display: inline-block;
text-align: center;
overflow-y: auto;
}
.chat_login p, .chat_body li, p, a {
-webkit-animation: zoomIn .5s cubic-bezier(.42, 0, .58, 1);
animation: zoomIn .5s cubic-bezier(.42, 0, .58, 1);
}
.chat_body p {
padding: 20px;
color: #888
}
.chat_body a {
width: 10%;
text-align: center;
border: none;
box-shadow: none;
line-height: 40px;
font-size: 15px;
}
.chat_field {
position: relative;
margin: 5px 0 5px 0;
width: 50%;
font-family: 'Roboto';
font-size: 12px;
line-height: 30px;
font-weight: 500;
color: #4b4b4b;
-webkit-font-smoothing: antialiased;
font-smoothing: antialiased;
border: none;
outline: none;
display: inline-block;
}
.chat_field.chat_message {
height: 30px;
resize: none;
font-size: 13px;
font-weight: 400;
}
.chat_category ul li {
width: 80%;
height: 30px;
background: #fff;
padding: 10px;
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
margin-bottom: 10px;
border-radius: 3px;
border: 1px solid #e0e0e0;
font-size: 13px;
cursor: pointer;
line-height: 30px;
color: #888;
text-align: center;
}
.chat_category li:hover {
background: #83c76d;
color: #fff;
}
.chat_category li.active {
background: #83c76d;
color: #fff;
}
.tags li {
padding: 5px 10px;
border-radius: 40px;
border: 1px solid rgb(3, 117, 208);
margin: 5px;
display: inline-block;
color: rgb(3, 117, 208);
cursor: pointer;
}
.fab_field {
width: 100%;
display: inline-block;
text-align: center;
background: #fff;
border-top: 1px solid #eee;
border-bottom-right-radius: 10px;
border-bottom-left-radius: 10px;
}
.fab_field2 {
bottom: 0px;
position: absolute;
border-bottom-right-radius: 0px;
border-bottom-left-radius: 0px;
z-index: 999;
}
.fab_field a {
display: inline-block;
text-align: center;
}
#fab_camera {
float: left;
background: rgba(0, 0, 0, 0);
}
#fab_send {
float: right;
background: rgba(0, 0, 0, 0);
}
.fab_field .fab {
width: 35px;
height: 35px;
box-shadow: none;
margin: 5px;
}
.fab_field .fab > i {
font-size: 1.6em;
line-height: 35px;
color: #bbb;
}
.fab_field .fab > i:hover {
color: yellowgreen;
}
.chat_converse2 {
height: 100%;
max-height: 800px
}
.chat_list .chat_list_item {
opacity: 0;
visibility: hidden;
}
.chat .chat_converse .chat_msg_item {
position: relative;
margin: 8px 0 15px 0;
padding: 8px 10px;
max-width: 60%;
display: block;
word-wrap: break-word;
border-radius: 3px;
-webkit-animation: zoomIn .5s cubic-bezier(.42, 0, .58, 1);
animation: zoomIn .5s cubic-bezier(.42, 0, .58, 1);
clear: both;
z-index: 999;
}
.chat .chat_converse .chat_msg_item .chat_avatar {
position: absolute;
top: 0;
}
.chat .chat_converse .chat_msg_item.chat_msg_item_admin .chat_avatar {
left: -52px;
background: rgba(0, 0, 0, 0.03);
}
.chat .chat_converse .chat_msg_item.chat_msg_item_user .chat_avatar {
right: -52px;
background: rgba(0, 0, 0, 0.6);
}
.chat .chat_converse .chat_msg_item .chat_avatar, .chat_avatar img {
width: 40px;
height: 40px;
text-align: center;
border-radius: 50%;
}
.chat .chat_converse .chat_msg_item.chat_msg_item_admin {
margin-left: 60px;
float: left;
background: rgba(0, 0, 0, 0.03);
color: #666;
}
.chat .chat_converse .chat_msg_item.chat_msg_item_user {
margin-right: 20px;
float: right;
background: yellowgreen;
color: #eceff1;
}
.chat .chat_converse .chat_msg_item.chat_msg_item_admin:before {
content: '';
position: absolute;
top: 15px;
left: -12px;
z-index: 998;
border: 6px solid transparent;
border-right-color: rgba(255, 255, 255, .4);
}
.chat_form .get-notified label {
color: #077ad6;
font-weight: 600;
font-size: 11px;
}
input {
position: relative;
width: 90%;
font-family: 'Roboto';
font-size: 12px;
line-height: 20px;
font-weight: 500;
color: #4b4b4b;
-webkit-font-smoothing: antialiased;
font-smoothing: antialiased;
outline: none;
background: #fff;
display: inline-block;
resize: none;
padding: 5px;
border-radius: 3px;
}
.chat_form .get-notified input {
margin: 2px 0 0 0;
border: 1px solid #83c76d;
}
.chat_form .get-notified i {
background: #83c76d;
width: 30px;
height: 32px;
font-size: 18px;
color: #fff;
line-height: 30px;
font-weight: 600;
text-align: center;
margin: 2px 0 0 -30px;
position: absolute;
border-radius: 3px;
}
.chat_form .message_form {
margin: 10px 0 0 0;
}
.chat_form .message_form input {
margin: 5px 0 5px 0;
border: 1px solid #e0e0e0;
}
.chat_form .message_form textarea {
margin: 5px 0 5px 0;
border: 1px solid #e0e0e0;
position: relative;
width: 90%;
font-family: 'Roboto';
font-size: 12px;
line-height: 20px;
font-weight: 500;
color: #4b4b4b;
-webkit-font-smoothing: antialiased;
font-smoothing: antialiased;
outline: none;
background: #fff;
display: inline-block;
resize: none;
padding: 5px;
border-radius: 3px;
}
.chat_form .message_form button {
margin: 5px 0 5px 0;
border: 1px solid #e0e0e0;
position: relative;
width: 95%;
font-family: 'Roboto';
font-size: 12px;
line-height: 20px;
font-weight: 500;
color: #fff;
-webkit-font-smoothing: antialiased;
font-smoothing: antialiased;
outline: none;
background: #fff;
display: inline-block;
resize: none;
padding: 5px;
border-radius: 3px;
background: #83c76d;
cursor: pointer;
}
strong.chat_time {
padding: 0 1px 1px 0;
font-weight: 500;
font-size: 8px;
display: block;
}
/*Chatbox scrollbar*/
::-webkit-scrollbar {
width: 6px;
}
::-webkit-scrollbar-track {
border-radius: 0;
}
::-webkit-scrollbar-thumb {
margin: 2px;
border-radius: 10px;
background: rgba(0, 0, 0, 0.2);
}
/*Element state*/
.is-active {
-webkit-transform: rotate(180deg);
transform: rotate(180deg);
-webkit-transition: all 1s ease-in-out;
transition: all 1s ease-in-out;
}
.is-float {
box-shadow: 0 0 6px rgba(0, 0, 0, .16), 0 6px 12px rgba(0, 0, 0, .32);
}
.is-loading {
display: block;
-webkit-animation: load 1s cubic-bezier(0, .99, 1, 0.6) infinite;
animation: load 1s cubic-bezier(0, .99, 1, 0.6) infinite;
}
/*Animation*/
@-webkit-keyframes zoomIn {
0% {
-webkit-transform: scale(0);
transform: scale(0);
opacity: 0.0;
}
100% {
-webkit-transform: scale(1);
transform: scale(1);
opacity: 1;
}
}
@keyframes zoomIn {
0% {
-webkit-transform: scale(0);
transform: scale(0);
opacity: 0.0;
}
100% {
-webkit-transform: scale(1);
transform: scale(1);
opacity: 1;
}
}
@-webkit-keyframes load {
0% {
-webkit-transform: scale(0);
transform: scale(0);
opacity: 0.0;
}
50% {
-webkit-transform: scale(1.5);
transform: scale(1.5);
opacity: 1;
}
100% {
-webkit-transform: scale(1);
transform: scale(1);
opacity: 0;
}
}
@keyframes load {
0% {
-webkit-transform: scale(0);
transform: scale(0);
opacity: 0.0;
}
50% {
-webkit-transform: scale(1.5);
transform: scale(1.5);
opacity: 1;
}
100% {
-webkit-transform: scale(1);
transform: scale(1);
opacity: 0;
}
}
/* SMARTPHONES PORTRAIT */
@media only screen and (min-width: 300px) {
.chat {
width: 250px;
}
}
/* SMARTPHONES LANDSCAPE */
@media only screen and (min-width: 480px) {
.chat {
width: 300px;
}
.chat_field {
width: 65%;
}
}
/* TABLETS PORTRAIT */
@media only screen and (min-width: 768px) {
.chat {
width: 300px;
}
.chat_field {
width: 65%;
}
}
/* TABLET LANDSCAPE / DESKTOP */
@media only screen and (min-width: 1024px) {
.chat {
width: 300px;
}
.chat_field {
width: 65%;
}
}
/*Color Options*/
.blue .fab {
background: yellowgreen;
color: #fff;
}
.blue .chat {
background: yellowgreen;
color: #999;
}
@-webkit-keyframes ripple {
/*scale the element to 250% to safely cover the entire link and fade it out*/
100% {
opacity: 0;
-moz-transform: scale(5);
-ms-transform: scale(5);
webkit-transform: scale(5);
-webkit-transform: scale(5);
transform: scale(5);
}
}
@keyframes ripple {
/*scale the element to 250% to safely cover the entire link and fade it out*/
100% {
opacity: 0;
-moz-transform: scale(5);
-ms-transform: scale(5);
webkit-transform: scale(5);
-webkit-transform: scale(5);
transform: scale(5);
}
}
::-webkit-input-placeholder { /* Chrome */
color: #bbb;
}
:-ms-input-placeholder { /* IE 10+ */
color: #bbb;
}
::-moz-placeholder { /* Firefox 19+ */
color: #bbb;
}
:-moz-placeholder { /* Firefox 4 - 18 */
color: #bbb;
}
.fa-align-justify{
font-size: 30px;
padding: 10px;
}
</style>
<body>
<div class="fabs">
<div class="chat">
<div class="chat_header">
<div class="chat_option">
<div class="header_img">
<img src="../image/demo1.jpg"/>
</div>
<span id="chat_head"></span><span class="agent">Developer</span> <span
class="online">(Online)</span>
</div>
</div>
<div class="chat_body ">
<p>Ask us anything</p>
</div>
<div class="fab_field">
<a id="fab_camera" class="fab"><i class="fa fa-camera"></i></a>
<a id="fab_send" class="fab"><i class="fa fa-send"></i></a>
<textarea id="chatSend" name="chat_message" placeholder="Send a message"
class="chat_field chat_message"></textarea>
</div>
</div>
<a id="prime" class="fab"><i class="fa fa-align-justify"></i></a>
</div>
</body>
</html>
<script>
hideChat(0);
$('#prime').click(function () {
toggleFab();
});
//Toggle chat and links
function toggleFab() {
$('.prime').toggleClass('zmdi-comment-outline');
$('.prime').toggleClass('zmdi-close');
$('.prime').toggleClass('is-active');
$('.prime').toggleClass('is-visible');
$('#prime').toggleClass('is-float');
$('.chat').toggleClass('is-visible');
$('.fab').toggleClass('is-visible');
}
$('#chat_first_screen').click(function (e) {
hideChat(1);
});
$('#chat_second_screen').click(function (e) {
hideChat(2);
});
$('#chat_third_screen').click(function (e) {
hideChat(3);
});
$('#chat_fourth_screen').click(function (e) {
hideChat(4);
});
$('#chat_fullscreen_loader').click(function (e) {
$('.fullscreen').toggleClass('zmdi-window-maximize');
$('.fullscreen').toggleClass('zmdi-window-restore');
$('.chat').toggleClass('chat_fullscreen');
$('.fab').toggleClass('is-hide');
$('.header_img').toggleClass('change_img');
$('.img_container').toggleClass('change_img');
$('.chat_header').toggleClass('chat_header2');
$('.fab_field').toggleClass('fab_field2');
$('.chat_converse').toggleClass('chat_converse2');
//$('#chat_converse').css('display', 'none');
// $('#chat_body').css('display', 'none');
// $('#chat_form').css('display', 'none');
// $('.chat_login').css('display', 'none');
// $('#chat_fullscreen').css('display', 'block');
});
function hideChat(hide) {
switch (hide) {
case 0:
$('#chat_converse').css('display', 'none');
$('#chat_body').css('display', 'none');
$('#chat_form').css('display', 'none');
$('.chat_login').css('display', 'block');
$('.chat_fullscreen_loader').css('display', 'none');
$('#chat_fullscreen').css('display', 'none');
break;
case 1:
$('#chat_converse').css('display', 'block');
$('#chat_body').css('display', 'none');
$('#chat_form').css('display', 'none');
$('.chat_login').css('display', 'none');
$('.chat_fullscreen_loader').css('display', 'block');
break;
case 2:
$('#chat_converse').css('display', 'none');
$('#chat_body').css('display', 'block');
$('#chat_form').css('display', 'none');
$('.chat_login').css('display', 'none');
$('.chat_fullscreen_loader').css('display', 'block');
break;
case 3:
$('#chat_converse').css('display', 'none');
$('#chat_body').css('display', 'none');
$('#chat_form').css('display', 'block');
$('.chat_login').css('display', 'none');
$('.chat_fullscreen_loader').css('display', 'block');
break;
case 4:
$('#chat_converse').css('display', 'none');
$('#chat_body').css('display', 'none');
$('#chat_form').css('display', 'none');
$('.chat_login').css('display', 'none');
$('.chat_fullscreen_loader').css('display', 'block');
$('#chat_fullscreen').css('display', 'block');
break;
}
}
</script>