mirror of https://github.com/readrops/Readrops.git
Add folders names to edit feed dialog spinner
This commit is contained in:
parent
4c538af36e
commit
bd3f279d0a
|
@ -14,7 +14,7 @@ import java.util.List;
|
|||
public interface FolderDao {
|
||||
|
||||
@Query("Select * from Folder")
|
||||
List<Folder> getAllFolders();
|
||||
LiveData<List<Folder>> getAllFolders();
|
||||
|
||||
@Insert
|
||||
long insert(Folder folder);
|
||||
|
|
|
@ -6,6 +6,7 @@ import android.arch.lifecycle.LiveData;
|
|||
import android.support.annotation.NonNull;
|
||||
|
||||
import com.readrops.app.database.Database;
|
||||
import com.readrops.app.database.entities.Folder;
|
||||
import com.readrops.app.database.pojo.FeedWithFolder;
|
||||
import com.readrops.app.repositories.LocalFeedRepository;
|
||||
|
||||
|
@ -15,6 +16,7 @@ public class ManageFeedsViewModel extends AndroidViewModel {
|
|||
|
||||
private Database db;
|
||||
private LiveData<List<FeedWithFolder>> feedsWithFolder;
|
||||
private LiveData<List<Folder>> folders;
|
||||
private LocalFeedRepository repository;
|
||||
|
||||
public ManageFeedsViewModel(@NonNull Application application) {
|
||||
|
@ -23,6 +25,7 @@ public class ManageFeedsViewModel extends AndroidViewModel {
|
|||
repository = new LocalFeedRepository(application);
|
||||
|
||||
feedsWithFolder = db.feedDao().getAllFeedsWithFolder();
|
||||
folders = db.folderDao().getAllFolders();
|
||||
}
|
||||
|
||||
public LiveData<List<FeedWithFolder>> getFeedsWithFolder() {
|
||||
|
@ -32,4 +35,8 @@ public class ManageFeedsViewModel extends AndroidViewModel {
|
|||
public void updateFeedWithFolder(FeedWithFolder feedWithFolder) {
|
||||
repository.updateFeedWithFolder(feedWithFolder);
|
||||
}
|
||||
|
||||
public LiveData<List<Folder>> getFolders() {
|
||||
return folders;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -8,20 +8,32 @@ import android.support.annotation.NonNull;
|
|||
import android.support.annotation.Nullable;
|
||||
import android.support.design.widget.TextInputEditText;
|
||||
import android.support.v4.app.DialogFragment;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
import android.widget.AdapterView;
|
||||
import android.widget.ArrayAdapter;
|
||||
import android.widget.Spinner;
|
||||
|
||||
import com.readrops.app.R;
|
||||
import com.readrops.app.database.entities.Feed;
|
||||
import com.readrops.app.database.entities.Folder;
|
||||
import com.readrops.app.database.pojo.FeedWithFolder;
|
||||
import com.readrops.app.viewmodels.ManageFeedsViewModel;
|
||||
|
||||
public class EditFeedDialog extends DialogFragment {
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.concurrent.Executors;
|
||||
|
||||
public class EditFeedDialog extends DialogFragment implements AdapterView.OnItemSelectedListener {
|
||||
|
||||
private TextInputEditText feedName;
|
||||
private TextInputEditText feedUrl;
|
||||
private Spinner folder;
|
||||
|
||||
Map<String, Integer> values;
|
||||
|
||||
private FeedWithFolder feedWithFolder;
|
||||
private ManageFeedsViewModel viewModel;
|
||||
|
||||
|
@ -43,9 +55,27 @@ public class EditFeedDialog extends DialogFragment {
|
|||
viewModel.updateFeedWithFolder(feedWithFolder);
|
||||
});
|
||||
|
||||
|
||||
|
||||
builder.setView(v);
|
||||
fillData(v);
|
||||
|
||||
viewModel.getFolders().observe(this, folders -> {
|
||||
values = new HashMap<>();
|
||||
for (Folder folder : folders) {
|
||||
if (folder.getId() != 1)
|
||||
values.put(folder.getName(), folder.getId());
|
||||
else
|
||||
values.put(getString(R.string.no_folder), 1);
|
||||
}
|
||||
|
||||
ArrayAdapter<String> spinnerData = new ArrayAdapter<String>(getActivity(),
|
||||
android.R.layout.simple_spinner_dropdown_item, new ArrayList<>(values.keySet()));
|
||||
spinnerData.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
|
||||
folder.setAdapter(spinnerData);
|
||||
folder.setOnItemSelectedListener(this);
|
||||
});
|
||||
|
||||
return builder.create();
|
||||
}
|
||||
|
||||
|
@ -58,5 +88,14 @@ public class EditFeedDialog extends DialogFragment {
|
|||
feedUrl.setText(feedWithFolder.getFeed().getUrl());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
|
||||
String folderName = (String)parent.getAdapter().getItem(position);
|
||||
feedWithFolder.getFeed().setFolderId(values.get(folderName));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onNothingSelected(AdapterView<?> parent) {
|
||||
|
||||
}
|
||||
}
|
||||
|
|
|
@ -49,7 +49,8 @@ public class FeedWithFolderItem extends ModelAbstractItem<FeedWithFolder, FeedWi
|
|||
.diskCacheStrategy(DiskCacheStrategy.ALL)
|
||||
.placeholder(R.drawable.ic_rss_feed)
|
||||
.into(holder.feedIcon);
|
||||
}
|
||||
} else
|
||||
holder.feedIcon.setImageResource(R.drawable.ic_rss_feed);
|
||||
|
||||
holder.feedName.setText(feedWithFolder.getFeed().getName());
|
||||
if (feedWithFolder.getFeed().getDescription() != null) {
|
||||
|
@ -58,7 +59,10 @@ public class FeedWithFolderItem extends ModelAbstractItem<FeedWithFolder, FeedWi
|
|||
} else
|
||||
holder.feedDescription.setVisibility(View.GONE);
|
||||
|
||||
holder.folderName.setText(feedWithFolder.getFolder().getName());
|
||||
if (feedWithFolder.getFolder().getId() != 1)
|
||||
holder.folderName.setText(feedWithFolder.getFolder().getName());
|
||||
else
|
||||
holder.folderName.setText(holder.itemView.getResources().getString(R.string.no_folder));
|
||||
|
||||
holder.editFeed.setOnClickListener(v -> listener.onEdit(feedWithFolder));
|
||||
holder.deleteFeed.setOnClickListener(v -> listener.onDelete(feedWithFolder));
|
||||
|
|
|
@ -48,17 +48,16 @@
|
|||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="8dp"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@+id/edit_feed_url_textinputlayout"
|
||||
android:text="@string/folder"
|
||||
android:textAppearance="@style/TextAppearance.Design.Hint"/>
|
||||
android:textAppearance="@style/TextAppearance.Design.Hint"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@+id/edit_feed_url_textinputlayout" />
|
||||
|
||||
<Spinner
|
||||
android:id="@+id/edit_feed_folder_spinner"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintHorizontal_bias="0.514"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@+id/edit_feed_folder" />
|
||||
|
||||
|
|
|
@ -7,13 +7,15 @@
|
|||
android:layout_marginStart="6dp"
|
||||
android:layout_marginTop="6dp"
|
||||
android:layout_marginEnd="6dp"
|
||||
android:background="?android:attr/selectableItemBackground"
|
||||
android:clickable="true"
|
||||
android:focusable="true">
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="?android:attr/selectableItemBackground"
|
||||
android:clickable="true"
|
||||
android:focusable="true"
|
||||
android:padding="6dp">
|
||||
|
||||
<RelativeLayout
|
||||
|
@ -34,8 +36,8 @@
|
|||
style="@style/Base.TextAppearance.AppCompat.Subhead"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_toEndOf="@id/feed_layout_icon"
|
||||
android:layout_toStartOf="@id/feed_layout_delete"
|
||||
android:layout_toEndOf="@id/feed_layout_icon"
|
||||
android:ellipsize="end"
|
||||
android:maxLines="2"
|
||||
android:minLines="1"
|
||||
|
@ -53,8 +55,8 @@
|
|||
android:maxLines="3"
|
||||
android:minLines="1"
|
||||
android:visibility="visible"
|
||||
tools:visibility="visible"
|
||||
tools:text="This is a feed description" />
|
||||
tools:text="This is a feed description"
|
||||
tools:visibility="visible" />
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/feed_layout_delete"
|
||||
|
@ -69,8 +71,8 @@
|
|||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="6dp"
|
||||
android:layout_below="@id/feed_layout_first_part">
|
||||
android:layout_below="@id/feed_layout_first_part"
|
||||
android:layout_marginTop="6dp">
|
||||
|
||||
<TextView
|
||||
android:id="@+id/feed_layout_folder"
|
||||
|
@ -79,8 +81,8 @@
|
|||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentStart="true"
|
||||
android:layout_toStartOf="@id/feed_layout_edit"
|
||||
android:maxLines="1"
|
||||
android:ellipsize="end"
|
||||
android:maxLines="1"
|
||||
tools:text="Folder 1" />
|
||||
|
||||
<ImageView
|
||||
|
@ -92,11 +94,9 @@
|
|||
android:src="@drawable/ic_edit_grey" />
|
||||
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
|
||||
</android.support.v7.widget.CardView>
|
|
@ -26,6 +26,7 @@
|
|||
<string name="feed_folder">Dossier du flux</string>
|
||||
<string name="feed_name">Nom du flux</string>
|
||||
<string name="edit_feed">Modifier le flux</string>
|
||||
<string name="folder">dossier</string>
|
||||
<string name="folder">Dossier</string>
|
||||
<string name="no_folder">Pas de dossier</string>
|
||||
|
||||
</resources>
|
|
@ -29,4 +29,5 @@
|
|||
<string name="feed_name">Feed name</string>
|
||||
<string name="edit_feed">Edit feed</string>
|
||||
<string name="folder">Folder</string>
|
||||
<string name="no_folder">No folder</string>
|
||||
</resources>
|
||||
|
|
Loading…
Reference in New Issue