- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我现在遇到的问题是,删除帖子的唯一方法是在帖子到期的确切时间单击帖子。超过有效期没有我点击帖子,帖子将不会被删除。我想要的是在到期时间到达时自动从数据库中删除帖子,而不管用户将进行何种 Activity 。有什么办法可以绕过它吗?下面是我的数据库的快照以及用于将数据从我的数据库检索到我的主页 Activity 和单个帖子 Activity 的代码
Database
HomePage Activity
@Override
protected void onStart() {
super.onStart();
mAuth.addAuthStateListener(mAuthListener);
final String key = "";
Query query = FirebaseDatabase.getInstance().getReference("Posts").limitToLast(50);
FirebaseRecyclerOptions<Post> options = new FirebaseRecyclerOptions.Builder<Post>().setQuery(query,Post.class).build();
FirebaseRecyclerAdapter adapter = new FirebaseRecyclerAdapter<Post, PostViewHolder>(options){
@Override
public PostViewHolder onCreateViewHolder(ViewGroup parent, int viewType){
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.post_row,parent,false);
return new PostViewHolder(view);
}
@Override
protected void onBindViewHolder(PostViewHolder holder, int position, Post model){
final String post_key = getRef(position).getKey();
holder.setLocation("Location: " + model.getLocation());
holder.set_foodAvailable("Food Available: " + model.getFood_Available());
holder.setImage(model.getImage());
holder.set_foodExpiry("Food Expires At: " + model.getFood_Expiry() + "hrs");
holder.setCounter("Interested Parties: " + model.getCounter());
holder.setUsername("Posted by: " + model.getUsername());
holder.mView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//Toast.makeText(MainActivity.this,post_key, Toast.LENGTH_SHORT).show();
Intent singlePostIntent = new Intent(HomeActivity.this, SingleActivity.class);
singlePostIntent.putExtra("post_id", post_key);
startActivity(singlePostIntent);
((SimpleItemAnimator) mPostList.getItemAnimator()).setSupportsChangeAnimations(false);
}
});
if(key == post_key){
mDatabaseTest = mDatabase.child(key);
mDatabaseTest.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
String expiry = (String) dataSnapshot.child("Food_Expiry").getValue();
SimpleDateFormat format = new SimpleDateFormat("HH:mm", Locale.ENGLISH);
try {
Date currentDate = format.parse(time);
Date expiryDate = format.parse(expiry);
assert currentDate != null;
if(!currentDate.before(expiryDate) || currentDate.after(expiryDate)){
mDatabaseTest.removeValue();
}
} catch (ParseException e) {
e.printStackTrace();
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
}
}
};
adapter.startListening();
mPostList.setAdapter(adapter);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_single);
mSingleImage = findViewById(R.id.single_image);
mSingleEventName = findViewById(R.id.single_eventName);
mSingleLocation = findViewById(R.id.single_Location);
mSingleMoreDetails = findViewById(R.id.single_moreDetails);
mSingleFoodAvailable = findViewById(R.id.single_foodAvailable);
mSingleDietaryOptions = findViewById(R.id.single_dietaryOptions);
mSingleEstimatedPaxAvailability = findViewById(R.id.single_estimatedPaxAvailability);
mSingleFoodExpiry = findViewById(R.id.single_foodExpiry);
removeBtn = findViewById(R.id.removeButton);
mSingleUsername = findViewById(R.id.single_username);
mCounterView = findViewById(R.id.single_counter);
counterBtn = findViewById(R.id.counterButton);
mDatabaseTest = FirebaseDatabase.getInstance().getReference();
mDatabase = FirebaseDatabase.getInstance().getReference().child("Posts");
mAuth = FirebaseAuth.getInstance();
mPost_key = getIntent().getExtras().getString("post_id");
//Values that you want to retrieve
mDatabase.child(mPost_key).addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
String post_uid = (String) dataSnapshot.child("Uid").getValue();
String post_image = (String) dataSnapshot.child("Image").getValue();
String post_eventName = (String) dataSnapshot.child("Event_Name").getValue();
String post_location = (String) dataSnapshot.child("Location").getValue();
String post_moreDetails = (String) dataSnapshot.child("More_Details_On_Location").getValue();
String post_foodAvailable = (String) dataSnapshot.child("Food_Available").getValue();
String post_username = (String) dataSnapshot.child("Username").getValue();
post_click = (String) dataSnapshot.child("Clicked").getValue();
post_counter = (String) dataSnapshot.child("Counter").getValue();
mCounterView.setText("Interested Parties: " + post_counter);
ArrayList<String> names = new ArrayList<String>();
StringBuffer sb = new StringBuffer();
for(DataSnapshot s : dataSnapshot.child("Dietary_Options").getChildren()){
names.add(s.getValue().toString());
}
Log.d("tag","value" + names.size());
for(String a : names) {
sb.append(a);
sb.append(", ");
}
String str = sb.toString();
str = str.replaceAll(", $", "");
mSingleDietaryOptions.setText("Dietary Options: " + str);
String post_estimatedPaxAvailability = (String) dataSnapshot.child("Estimated_Pax_Availability").getValue();
String post_foodExpiry = (String) dataSnapshot.child("Food_Expiry").getValue();
mSingleEventName.setText("Event Name: " + post_eventName);
mSingleLocation.setText("Location: " + post_location);
mSingleMoreDetails.setText("More Details On Location: " + post_moreDetails);
mSingleFoodAvailable.setText("Food Available: " + post_foodAvailable);
mSingleEstimatedPaxAvailability.setText("Estimated Pax Available: " + post_estimatedPaxAvailability);
mSingleFoodExpiry.setText("Food Expires At: " + post_foodExpiry + "hrs");
mSingleUsername.setText("Posted By: " + post_username);
Picasso.get().load(post_image).into(mSingleImage);
if(mAuth.getCurrentUser().getUid().equals(post_uid)){
removeBtn.setVisibility(View.VISIBLE); //check that only user that post the location can remove the post
}
ArrayList<String> users = new ArrayList<String>();
for(DataSnapshot a : dataSnapshot.child("Users_Interested").getChildren()){
users.add(a.getValue().toString());
}
Calendar calendar = Calendar.getInstance();
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("HH:mm");
final String time = simpleDateFormat.format(calendar.getTime());
if(time.equals(post_foodExpiry)){
mDatabase.child(mPost_key).removeValue();
}
//check to see if current user has already clicked the button
if(mAuth.getCurrentUser().getUid().equals(post_click) || users.contains(mAuth.getCurrentUser().getUid())){
counterBtn.setEnabled(false);
counterBtn.setText("Confirmed!");
Log.i("testing",mPost_key);
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
counterBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showAlertDialog();
}
});
removeBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mDatabase.child(mPost_key).removeValue();
Intent mainIntent = new Intent(SingleActivity.this, HomeActivity.class);
startActivity(mainIntent);
}
});
}
最佳答案
@Override
protected void onStart() {
super.onStart();
mAuth.addAuthStateListener(mAuthListener);
String key = "";
Query query = FirebaseDatabase.getInstance().getReference("Posts").limitToLast(50);
FirebaseRecyclerOptions<Post> options = new FirebaseRecyclerOptions.Builder<Post>().setQuery(query,Post.class).build();
FirebaseRecyclerAdapter adapter = new FirebaseRecyclerAdapter<Post, PostViewHolder>(options){
@Override
public PostViewHolder onCreateViewHolder(ViewGroup parent, int viewType){
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.post_row,parent,false);
return new PostViewHolder(view);
}
@Override
protected void onBindViewHolder(PostViewHolder holder, int position, Post model){
final String post_key = getRef(position).getKey();
holder.setLocation("Location: " + model.getLocation());
holder.set_foodAvailable("Food Available: " + model.getFood_Available());
holder.setImage(model.getImage());
holder.set_foodExpiry("Food Expires At: " + model.getFood_Expiry() + "hrs");
holder.setCounter("Interested Parties: " + model.getCounter());
holder.setUsername("Posted by: " + model.getUsername());
holder.mView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//Toast.makeText(MainActivity.this,post_key, Toast.LENGTH_SHORT).show();
Intent singlePostIntent = new Intent(HomeActivity.this, SingleActivity.class);
singlePostIntent.putExtra("post_id", post_key);
startActivity(singlePostIntent);
((SimpleItemAnimator) mPostList.getItemAnimator()).setSupportsChangeAnimations(false);
}
});
String test = mDatabase.child(post_key).getRef().toString();
mDatabase.child(post_key).addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
String expiry = (String) dataSnapshot.child("Food_Expiry").getValue();
//Log.i("expiry",expiry);
SimpleDateFormat format = new SimpleDateFormat("HH:mm", Locale.ENGLISH);
try {
Date currentDate = format.parse(time);
Date expiryDate = format.parse(expiry);
assert currentDate!= null;
if(!currentDate.before(expiryDate) || currentDate.after(expiryDate)){
mDatabase.child(post_key).getRef().removeValue();
Log.i("remove","please");
}
} catch (ParseException e) {
e.printStackTrace();
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
Log.i("test",test);
}
};
adapter.startListening();
mPostList.setAdapter(adapter);
}
关于java - 到达时间选择器选择的时间后,如何自动删除我的 firebase 数据库中的整个帖子?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61568925/
我之前让 dll 注入(inject)器变得简单,但我有 Windows 7,我用 C# 和 C++ 做了它,它工作得很好!但是现在当我在 Windows 8 中尝试相同的代码时,它似乎没有以正确的方
我正在尝试制作一个名为 core-splitter 的元素,该元素在 1.0 中已弃用,因为它在我们的项目中起着关键作用。 如果您不知道 core-splitter 的作用,我可以提供一个简短的描述。
我有几个不同的蜘蛛,想一次运行所有它们。基于 this和 this ,我可以在同一个进程中运行多个蜘蛛。但是,我不知道如何设计一个信号系统来在所有蜘蛛都完成后停止 react 器。 我试过了: cra
有没有办法在达到特定条件时停止扭曲 react 器。例如,如果一个变量被设置为某个值,那么 react 器应该停止吗? 最佳答案 理想情况下,您不会将变量设置为一个值并停止 react 器,而是调用
https://code.angularjs.org/1.0.0rc9/angular-1.0.0rc9.js 上面的链接定义了外部js文件,我不知道Angular-1.0.0rc9.js的注入(in
我正在尝试运行一个函数并将服务注入(inject)其中。我认为这可以使用 $injector 轻松完成.所以我尝试了以下(简化示例): angular.injector().invoke( [ "$q
在 google Guice 中,我可以使用函数 createInjector 创建基于多个模块的注入(inject)器。 因为我使用 GWT.create 在 GoogleGin 中实例化注入(in
我在 ASP.NET Core 1.1 解决方案中使用配置绑定(bind)。基本上,我在“ConfigureServices Startup”部分中有一些用于绑定(bind)的简单代码,如下所示: s
我在 Spring MVC 中设置 initBinder 时遇到一些问题。我有一个 ModelAttribute,它有一个有时会显示的字段。 public class Model { privat
我正在尝试通过jquery post发布knockoutjs View 模型 var $form = $('#barcodeTemplate form'); var data = ko.toJS(vm
如何为包含多态对象集合的复杂模型编写自定义模型绑定(bind)程序? 我有下一个模型结构: public class CustomAttributeValueViewModel { publi
您好,我正在尝试实现我在 this article 中找到的扩展方法对于简单的注入(inject)器,因为它不支持开箱即用的特定构造函数的注册。 根据这篇文章,我需要用一个假的委托(delegate)
你好,我想自动注册我的依赖项。 我现在拥有的是: public interface IRepository where T : class public interface IFolderReposi
我正在使用 Jasmine 测试一些 Angular.js 代码。为此,我需要一个 Angular 注入(inject)器: var injector = angular.injector(['ng'
我正在使用 Matlab 代码生成器。不可能包含代码风格指南。这就是为什么我正在寻找一个工具来“ reshape ”、重命名和重新格式化生成的代码,根据我的: 功能横幅约定 文件横幅约定 命名约定 等
这个问题在这里已经有了答案: Where and why do I have to put the "template" and "typename" keywords? (8 个答案) 关闭 8
我开发了一种工具,可以更改某些程序的外观。为此,我需要在某些进程中注入(inject)一个 dll。 现在我基本上使用这个 approach .问题通常是人们无法注入(inject) dll,因为他们
我想使用 swing、spring 和 hibernate 编写一个 java 应用程序。 我想使用数据绑定(bind)器用 bean 的值填充 gui,并且我还希望它反射(reflect) gui
我有这段代码,当两个蜘蛛完成后,程序仍在运行。 #!C:\Python27\python.exe from twisted.internet import reactor from scrapy.cr
要点是 Spring Batch (v2) 测试框架具有带有 @Autowired 注释的 JobLauncherTestUtils.setJob。我们的测试套件有多个 Job 类提供者。因为这个类不
我是一名优秀的程序员,十分优秀!