-
Notifications
You must be signed in to change notification settings - Fork 16
Expand file tree
/
Copy pathHomeActivity.java
More file actions
297 lines (248 loc) · 11.2 KB
/
Copy pathHomeActivity.java
File metadata and controls
297 lines (248 loc) · 11.2 KB
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
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
package com.harpreet.notes_app;
import android.app.ProgressDialog;
import android.content.Intent;
import android.support.annotation.NonNull;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.Toolbar;
import android.text.TextUtils;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import com.firebase.ui.database.FirebaseRecyclerAdapter;
import com.firebase.ui.database.FirebaseRecyclerOptions;
import com.firebase.ui.database.SnapshotParser;
import com.google.firebase.auth.FirebaseAuth;
import com.google.firebase.auth.FirebaseUser;
import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.Query;
import com.harpreet.notes_app.Modal.Data;
import java.text.DateFormat;
import java.util.Date;
public class HomeActivity extends AppCompatActivity {
private Toolbar mtoolbar;
private FloatingActionButton fab;
private RecyclerView recyclerView;
private FirebaseRecyclerAdapter<Data,Myviewholder> adapter; //These lines declare various variables used within the HomeActivity class, including references to UI
// elements (toolbar, floating action button, and recycler view), an adapter for
// the recycler view, instances of Firebase-related classes (FirebaseAuth and DatabaseReference),
// and other variables to store data.
private FirebaseAuth mauth;
private DatabaseReference mDatabase;
public String name;
public String description;
public String post_key;
private ProgressDialog pd;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
pd = new ProgressDialog(this);
pd.setMessage("Fetching Data...");
pd.show();
mtoolbar = findViewById(R.id.tbar);
fab = findViewById(R.id.fab);
recyclerView = findViewById(R.id.recyclerView);
LinearLayoutManager layoutManager = new LinearLayoutManager(getApplicationContext());
layoutManager.setReverseLayout(true);
layoutManager.setStackFromEnd(true);
recyclerView.setHasFixedSize(true);
recyclerView.setLayoutManager(layoutManager);
setSupportActionBar(mtoolbar);
getSupportActionBar().setTitle("Keep My Notes");
mauth = FirebaseAuth.getInstance();
FirebaseUser mUser = mauth.getCurrentUser();
String uid = mUser.getUid();
mDatabase = FirebaseDatabase.getInstance().getReference().child("All data").child(uid);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
addData();
}
});
}
private void addData() //This method is responsible for displaying an AlertDialog that allows the user to input data (name and description) for a new note.
{
AlertDialog.Builder mydialog = new AlertDialog.Builder(this);
LayoutInflater inflater = LayoutInflater.from(this);
View myview = inflater.inflate(R.layout.input_layout,null);
mydialog.setView(myview);
final AlertDialog myalert_dialogue = mydialog.create();
myalert_dialogue.setCancelable(false);
myalert_dialogue.show();
final EditText name = myview.findViewById(R.id.name);
final EditText des = myview.findViewById(R.id.des);
Button btnCancle = myview.findViewById(R.id.cancle);
Button btnsave = myview.findViewById(R.id.save);
btnsave.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String mname = name.getText().toString().trim();
String mdes = des.getText().toString().trim();
if (TextUtils.isEmpty(mname))
{
name.setError("Required Field");
return;
}
if (TextUtils.isEmpty(mdes))
{
des.setError("Required Field");
return;
}
String id = mDatabase.push().getKey();
String mDate = DateFormat.getDateInstance().format(new Date());
Data data = new Data(mname,mdes,id,mDate);
mDatabase.child(id).setValue(data);
myalert_dialogue.dismiss();
}
});
btnCancle.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
myalert_dialogue.dismiss();
}
});
}
@Override
protected void onStart() { //It sets up the FirebaseRecyclerAdapter for displaying the notes in the RecyclerView and starts listening for changes in the data.
super.onStart();
Query query = FirebaseDatabase.getInstance().getReference().child("All data").child(mauth.getUid());
FirebaseRecyclerOptions<Data> options = new FirebaseRecyclerOptions.Builder<Data>().setQuery(query,new SnapshotParser<Data>(){
@NonNull
@Override
public Data parseSnapshot(@NonNull DataSnapshot snapshot) {
return new Data(snapshot.child("name").getValue().toString(),snapshot.child("description").getValue().toString(),snapshot.child("id").getValue().toString(),
snapshot.child("date").getValue().toString());
} }).build();
adapter = new FirebaseRecyclerAdapter<Data, Myviewholder>(options) {
@NonNull
@Override
public Myviewholder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.item_layout_design,viewGroup,false);
return new Myviewholder(view);
}
@Override
protected void onBindViewHolder(@NonNull Myviewholder holder, final int position, @NonNull final Data model) {
pd.dismiss();
holder.setDate(model.getDate());
holder.setDescription(model.getDescription());
holder.setName(model.getName());
holder.mView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(HomeActivity.this, "Item Selected", Toast.LENGTH_SHORT).show();
post_key = getRef(position).getKey();
name = model.getName();
description = model.getDescription();
updateData();
}
});
}
};
recyclerView.setAdapter(adapter);
adapter.startListening();
}
@Override
protected void onStop() { //This method is called when the activity is stopped. It stops the FirebaseRecyclerAdapter from listening to changes in the data.
super.onStop();
adapter.stopListening();
}
public static class Myviewholder extends RecyclerView.ViewHolder{ //This is a static inner class that defines a
// custom RecyclerView.ViewHolder for the notes. It holds references
// to the UI elements within each item of the RecyclerView.
View mView;
public Myviewholder(@NonNull View itemView) {
super(itemView);
mView = itemView;
}
public void setName(String name){
TextView Mname = mView.findViewById(R.id.name_item);
Mname.setText(name);
}
public void setDescription(String description)
{
TextView Mdescription = mView.findViewById(R.id.des_item);
Mdescription.setText(description);
}
public void setDate(String date)
{
TextView Mdate = mView.findViewById(R.id.date);
Mdate.setText(date);
}
}
public void updateData() //
// The updateData() method is responsible for displaying an AlertDialog that allows the user to update the
// selected note's data or delete the note. Here's a breakdown of what the method does:
{
final AlertDialog.Builder mydia = new AlertDialog.Builder(this);
LayoutInflater inflater = LayoutInflater.from(this);
View myview = inflater.inflate(R.layout.update_layout,null);
mydia.setView(myview);
final AlertDialog alertDialog = mydia.create();
alertDialog.show();
final EditText mName = myview.findViewById(R.id.name);
final EditText mDescription = myview.findViewById(R.id.des);
mName.setText(name);
mName.setSelection(name.length());
mDescription.setText(description);
mDescription.setSelection(description.length());
Button btndelete = myview.findViewById(R.id.btndelete);
Button btnupdate = myview.findViewById(R.id.btnupdate);
btndelete.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mDatabase.child(post_key).removeValue();
alertDialog.dismiss();
}
});
btnupdate.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
name = mName.getText().toString().trim();
description = mDescription.getText().toString();
if (TextUtils.isEmpty(name))
{
mName.setError("Required Field");
return;
}
if (TextUtils.isEmpty(description))
{
mDescription.setError("Required Field");
return;
}
String mDate =DateFormat.getDateInstance().format(new Date());
Data data = new Data(name,description,post_key,mDate);
mDatabase.child(post_key).setValue(data);
alertDialog.dismiss();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.mainmenu,menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId())
{
case R.id.logout:
mauth.signOut();
startActivity(new Intent(getApplicationContext(),MainActivity.class));
break;
}
return super.onOptionsItemSelected(item);
}
}