-
Notifications
You must be signed in to change notification settings - Fork 47
/
create.html
135 lines (105 loc) · 4.76 KB
/
create.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Firebase - Create</title>
<!-- Bootstrap -->
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css" rel="stylesheet">
<!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->
</head>
<body>
<div class="container">
<br>
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#nav" aria-expanded="false">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="index.html">Firebase</a>
</div>
<div class="collapse navbar-collapse" id="nav">
<ul class="nav navbar-nav">
<li><a href="login.html">Member</a></li>
<li class="active"><a href="create.html">New Entry</a></li>
</ul>
</div>
</div>
</nav>
<form id="new_entry">
<h2>Title</h2>
<br>
<input type="text" name="title" class="form-control col-md-12" required>
<br>
<br>
<h2>Content</h2>
<br>
<textarea name="content" id="content"></textarea>
<br>
<br>
<div class="text-right">
<button class="btn btn-large btn-primary">Create new entry</button>
</div>
</form>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/js/bootstrap.min.js"></script>
<script src="https://www.gstatic.com/firebasejs/3.3.0/firebase.js"></script>
<script src="//cdn.ckeditor.com/4.5.10/standard/ckeditor.js"></script>
<script>
// firebase config
var config = {
apiKey: "AIzaSyBqxEP00IKEgI163DnTRluzxIHwesx_QLQ",
authDomain: "example-crud-blog-d4912.firebaseapp.com",
databaseURL: "https://example-crud-blog-d4912.firebaseio.com",
storageBucket: "",
};
firebase.initializeApp(config);
/////////////////////////////////////
/**********************\
* login status check *
\**********************/
firebase.auth().onAuthStateChanged(function (user) {
if (user) {
// init CKEditor
CKEDITOR.replace('content');
/***************************************************\
* Process form data and save to Firebase database *
\***************************************************/
$('#new_entry').submit(function(e){
e.preventDefault();
var entry = {};
entry.title = $(this).find('[name="title"]').val();
entry.content = CKEDITOR.instances['content'].getData();
entry.createdAt = new Date().getTime();
entry.updatedAt = entry.createdAt;
entry.views = 0;
entry.author = user.email;
var Entry = firebase.database().ref('Entry');
Entry.push(entry).then(function(data){
window.location.href = 'entry.html?id='+data.getKey()
}).catch(function(error){
alert(error);
console.error(error);
})
return false;
});
}else{
// if not logged in
alert('Please login first')
window.location.href = 'login.html';
}
});
</script>
</body>
</html>