-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfirebase.html
93 lines (91 loc) · 10.5 KB
/
firebase.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<!DOCTYPE html>
<html>
<head>
<title>Firebase Firestore Database</title>
<meta name="viewport" content="width=device-width,initial-scale=1" >
<script src="https://www.gstatic.com/firebasejs/7.8.1/firebase-app.js"></script>
<script src="https://www.gstatic.com/firebasejs/7.8.0/firebase-firestore.js"></script>
<style type="text/css">
*{margin:0;padding:0;box-sizing:border-box
}.container{padding:1.5rem}
#loading{padding:1rem;display:flex;justify-content:center;align-items:center;z-index:5;background:rgba(0,0,0,.75);position:fixed;top:0;bottom:0;left:0;right:0}
#loading p{text-align:center;width:100%;padding:1.5rem 0;background:rgba(0,0,0,.75);color:#fff;font-size:1.3rem}
button{padding:5px 12px;font-size:1.5rem;background:green;border:none;border-radius:5px;outline:0;box-shadow:none;color:#fff;transition:all .3s}
.btn:hover,button:active,button:hover{color:#fff;transform:translate3d(-1px,-1px,5px);box-shadow:2px 2px 5px rgba(0,0,0,.5)}
button+button{margin-left:.25rem;background:red}
.table-box{border:2px solid #4caf50}
.sk-table{font-family:"Trebuchet MS",Arial,Helvetica,sans-serif;border-collapse:collapse;width:100%;box-sizing:border-box;overflow-x:scroll}
.sk-table td,.sk-table th{border-bottom:1px solid #ddd;padding:5px;text-align:center}
.sk-table tr:nth-child(even){background-color:#f2f2f2}
.sk-table tr:hover{background-color:#ededed}
.sk-table th{padding-top:12px;padding-bottom:12px;text-align:center;background-color:#4caf50;color:#fff}
input[type=text],select{width:100%;padding:12px 20px;margin:8px 0;display:inline-block;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}
.btn,input[type=submit]{width:100%;font-size:1rem;background-color:#4caf50;color:#fff;padding:14px 20px;margin:8px 0;border:none;border-radius:4px;cursor:pointer;transition:all .3s}
input[type=submit]:hover{background-color:#45a049}.box{border-radius:5px;background-color:#f2f2f2;padding:20px}
#details{background:#f2f2f2}
#details h2{padding:1rem 0}
.btn{text-align:center}
.bg-red{background:red}
.font2x{font-size:1.2rem}
.heading{font-size:1.3rem;padding:50px 0;text-align:center;background:#dfdfdf;color:teal}
.btn img, button img{height:20px;width:20px;}</style>
</head>
<body>
<div id="loading" >
<p id="respMsg" >Wait...</p>
</div>
<p class="heading" >Firebase CRUD App with <strong>Firestore</strong><p>
<div class="container" >
<div id="form-container" ></div>
<div id="data-list-box" >
<p id="addNewRecordBtn" class="btn font2x" >Add New Record </p>
<div id="details"></div>
</div>
</div>
<script src="https://cdn.jsdelivr.net/gh/skwebs/skwebs.github.io@master/js/config.js"></script>
<script>;
const db=config();var loading=document.getElementById("loading"),respMsg=document.querySelector("#respMsg"),dataList=document.querySelector("#dataList"),form=document.querySelector("#form");
function createRecord(){
var
e=document.getElementById("fname").value,
t=document.getElementById("lname").value;
""==e?alert("First Name required."):""==t?alert("Last Name required."):(
msgScreen("teal","New record adding..."),
showLoading(),
db
.collection("sololearn")
.add({fname:e,lname:t})
.then(function(){
console.log("Document successfully written!"),
respMsg.style.background="green",
respMsg.innerHTML="Record added successfully.",
hideLoading(),
document.getElementById("form-container").innerHTML="",
document.querySelector("#data-list-box").style.display="block",
readRecords()
})
.catch(function(e){
respMsg.style.background="red",
respMsg.innerHTML="Error writing document: "+e,
hideLoading(),
console.error("Error writing document: ",e),
readRecords()
})
)
}
function readRecords(){msgScreen("magenta","All records loading..."),showLoading();var e="<div class='table-box'><table class='sk-table'><tr><td colspan='100%'><h2>All Records List</h2></td></tr><tr><th>S.N.</th><th>First Name</th><th>Last Name</th><th>Action</th></tr>",t=1;db.collection("sololearn").get().then(function(n){n.forEach(function(n){e+="<tr><td>"+t+++"</td><td>"+n.data().fname+" </td> <td> "+n.data().lname+"</td><td><button onclick=\"updateRecordForm('"+n.id+'\')"><img src=""> </button><button onclick="deleteRecord(\''+n.id+'\')"> <img src=""> </button></td><tr/>'}),e+="</table></div>",document.getElementById("details").innerHTML=e,msgScreen("black","Records loaded successfully."),hideLoading()})}
function updateRecord(e){var t=document.getElementById("fname").value,n=document.getElementById("lname").value;if(""==t)alert("First Name required.");else{if(""!=n)return msgScreen("green","Id : "+e+" associated data updating...!"),showLoading(),db.collection("sololearn").doc(e).update({fname:document.getElementById("fname").value,lname:document.getElementById("lname").value}).then(function(){msgScreen("green","Id : "+e+" records updated successfully."),hideLoading(),showDataBox(),document.getElementById("form-container").innerHTML="",readRecords()}).catch(function(e){console.error("Error updating document: ",e)});alert("Last Name required.")}}
function deleteRecord(e){confirm("Id : "+e+"\n\nAre you want to delete it?")&&(msgScreen("red","Id : "+e+" associated data deleting...!"),showLoading(),db.collection("sololearn").doc(e).delete().then(function(){msgScreen("green"," : "+e+" records deleted successfully."),hideLoading(),readRecords()}).catch(function(e){console.error("Error removing document: ",e)}))}
function msgScreen(e,t){respMsg.style.background=e,respMsg.innerHTML=t}
function showLoading(){loading.style.display="flex"}
function hideLoading(){loading.style.display="none"}
function showCreateForm(){document.getElementById("form-container").innerHTML='<div class="box" ><label for="fname">First Name</label><input type="text" id="fname" placeholder="First name.."><label for="lname">Last Name</label><input type="text" id="lname" placeholder="Last name.."><input id="submit" type="submit" value="Save" onclick="createRecord()"><button class="btn bg-red" onclick=\'cancelAction()\'>Cancel</button></div></div></div>'}
function hideForm(){document.getElementById("form-container").innerHTML=""}
function showDataBox(){document.querySelector("#data-list-box").style.display="block"}
function hideDataBox(){document.querySelector("#data-list-box").style.display="none"}
function updateRecordForm(e){msgScreen("green","Loading record for editing..."),showLoading(),db.collection("sololearn").doc(e).get().then(function(t){t.exists?(document.getElementById("form-container").innerHTML='<div class="box" ><label for="fname">First Name</label><input type="text" id="fname" value="'+t.data().fname+'" placeholder="First name.."><label for="lname">Last Name</label><input type="text" id="lname" value="'+t.data().lname+'" placeholder="Last name.."><input id="submit" type="submit" value="Update" onclick=\'updateRecord("'+e+"\")'><button class=\"bg-red btn\" onclick='cancelAction()'>Cancel</button></div>",hideDataBox(),hideLoading()):console.log("No such document!")}).catch(function(e){console.log("Error getting document:",e)})}
function cancelAction(){document.querySelector("#data-list-box").style.display="block",hideForm()}
function editData(e){showLoading()}document.querySelector("#addNewRecordBtn").addEventListener("click",e=>{hideDataBox(),showCreateForm()}),readRecords();
</script>
</body>
</html>