Fix issue #411
This commit is contained in:
parent
1d4da5ad98
commit
f716688a8d
|
@ -107,6 +107,7 @@ import app.fedilab.android.asynctasks.UpdateAccountInfoAsyncTask;
|
||||||
import app.fedilab.android.asynctasks.UpdateAccountInfoByIDAsyncTask;
|
import app.fedilab.android.asynctasks.UpdateAccountInfoByIDAsyncTask;
|
||||||
import app.fedilab.android.client.APIResponse;
|
import app.fedilab.android.client.APIResponse;
|
||||||
import app.fedilab.android.client.Entities.Account;
|
import app.fedilab.android.client.Entities.Account;
|
||||||
|
import app.fedilab.android.client.Entities.Announcement;
|
||||||
import app.fedilab.android.client.Entities.Error;
|
import app.fedilab.android.client.Entities.Error;
|
||||||
import app.fedilab.android.client.Entities.Filters;
|
import app.fedilab.android.client.Entities.Filters;
|
||||||
import app.fedilab.android.client.Entities.Instance;
|
import app.fedilab.android.client.Entities.Instance;
|
||||||
|
@ -117,7 +118,6 @@ import app.fedilab.android.client.Entities.Status;
|
||||||
import app.fedilab.android.client.Entities.TagTimeline;
|
import app.fedilab.android.client.Entities.TagTimeline;
|
||||||
import app.fedilab.android.drawers.AccountSearchDevAdapter;
|
import app.fedilab.android.drawers.AccountSearchDevAdapter;
|
||||||
import app.fedilab.android.fragments.DisplayAccountsFragment;
|
import app.fedilab.android.fragments.DisplayAccountsFragment;
|
||||||
import app.fedilab.android.fragments.DisplayAnnouncementsFragment;
|
|
||||||
import app.fedilab.android.fragments.DisplayBookmarksPixelfedFragment;
|
import app.fedilab.android.fragments.DisplayBookmarksPixelfedFragment;
|
||||||
import app.fedilab.android.fragments.DisplayDraftsFragment;
|
import app.fedilab.android.fragments.DisplayDraftsFragment;
|
||||||
import app.fedilab.android.fragments.DisplayFavoritesPeertubeFragment;
|
import app.fedilab.android.fragments.DisplayFavoritesPeertubeFragment;
|
||||||
|
@ -140,6 +140,7 @@ import app.fedilab.android.helper.Helper;
|
||||||
import app.fedilab.android.helper.MenuFloating;
|
import app.fedilab.android.helper.MenuFloating;
|
||||||
import app.fedilab.android.interfaces.OnFilterActionInterface;
|
import app.fedilab.android.interfaces.OnFilterActionInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveEmojiAccountInterface;
|
import app.fedilab.android.interfaces.OnRetrieveEmojiAccountInterface;
|
||||||
|
import app.fedilab.android.interfaces.OnRetrieveFeedsInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveInstanceInterface;
|
import app.fedilab.android.interfaces.OnRetrieveInstanceInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveMetaDataInterface;
|
import app.fedilab.android.interfaces.OnRetrieveMetaDataInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveRelationshipInterface;
|
import app.fedilab.android.interfaces.OnRetrieveRelationshipInterface;
|
||||||
|
@ -161,7 +162,7 @@ import static app.fedilab.android.helper.Helper.changeDrawableColor;
|
||||||
|
|
||||||
|
|
||||||
public abstract class BaseMainActivity extends BaseActivity
|
public abstract class BaseMainActivity extends BaseActivity
|
||||||
implements NavigationView.OnNavigationItemSelectedListener, OnUpdateAccountInfoInterface, OnRetrieveMetaDataInterface, OnRetrieveInstanceInterface, OnRetrieveRemoteAccountInterface, OnRetrieveEmojiAccountInterface, OnFilterActionInterface, OnSyncTimelineInterface, OnRetrieveRelationshipInterface {
|
implements NavigationView.OnNavigationItemSelectedListener, OnRetrieveFeedsInterface, OnUpdateAccountInfoInterface, OnRetrieveMetaDataInterface, OnRetrieveInstanceInterface, OnRetrieveRemoteAccountInterface, OnRetrieveEmojiAccountInterface, OnFilterActionInterface, OnSyncTimelineInterface, OnRetrieveRelationshipInterface {
|
||||||
|
|
||||||
|
|
||||||
public static String currentLocale;
|
public static String currentLocale;
|
||||||
|
@ -1331,7 +1332,9 @@ public abstract class BaseMainActivity extends BaseActivity
|
||||||
new UpdateAccountInfoByIDAsyncTask(getApplicationContext(), social, BaseMainActivity.this).execute();
|
new UpdateAccountInfoByIDAsyncTask(getApplicationContext(), social, BaseMainActivity.this).execute();
|
||||||
}
|
}
|
||||||
mutedAccount = new TempMuteDAO(getApplicationContext(), db).getAllTimeMuted(account);
|
mutedAccount = new TempMuteDAO(getApplicationContext(), db).getAllTimeMuted(account);
|
||||||
|
if (social == UpdateAccountInfoAsyncTask.SOCIAL.MASTODON || social == UpdateAccountInfoAsyncTask.SOCIAL.PLEROMA){
|
||||||
|
new RetrieveFeedsAsyncTask(getApplicationContext(), RetrieveFeedsAsyncTask.Type.ANNOUNCEMENTS, null, BaseMainActivity.this).execute();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void manageTimelineList(boolean displayed) {
|
private void manageTimelineList(boolean displayed) {
|
||||||
|
@ -2528,5 +2531,26 @@ public abstract class BaseMainActivity extends BaseActivity
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onRetrieveFeeds(APIResponse apiResponse) {
|
||||||
|
if( apiResponse != null && apiResponse.getAnnouncements() != null && apiResponse.getAnnouncements().size() > 0 ){
|
||||||
|
int unread = 0;
|
||||||
|
for(Announcement announcement: apiResponse.getAnnouncements()){
|
||||||
|
if( !announcement.isRead()){
|
||||||
|
unread++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
final NavigationView navigationView = findViewById(R.id.nav_view);
|
||||||
|
MenuItem item = navigationView.getMenu().findItem(R.id.nav_announcements);
|
||||||
|
TextView actionView = item.getActionView().findViewById(R.id.counter);
|
||||||
|
if(actionView != null) {
|
||||||
|
if (unread > 0) {
|
||||||
|
actionView.setText(unread);
|
||||||
|
actionView.setVisibility(View.VISIBLE);
|
||||||
|
}else{
|
||||||
|
actionView.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -179,7 +179,9 @@ public class PostActionAsyncTask extends AsyncTask<Void, Void, Void> {
|
||||||
} else {
|
} else {
|
||||||
statusCode = api.reportAction(targetedId, comment);
|
statusCode = api.reportAction(targetedId, comment);
|
||||||
}
|
}
|
||||||
} else if (apiAction == API.StatusAction.CREATESTATUS)
|
}else if (apiAction == API.StatusAction.ADD_REACTION || apiAction == API.StatusAction.REMOVE_REACTION) {
|
||||||
|
statusCode = api.postAction(apiAction, targetedId, comment);
|
||||||
|
}else if (apiAction == API.StatusAction.CREATESTATUS)
|
||||||
statusCode = api.statusAction(status);
|
statusCode = api.statusAction(status);
|
||||||
else if (apiAction == API.StatusAction.UPDATESERVERSCHEDULE) {
|
else if (apiAction == API.StatusAction.UPDATESERVERSCHEDULE) {
|
||||||
api.scheduledAction("PUT", storedStatus.getStatus(), null, storedStatus.getScheduledServerdId());
|
api.scheduledAction("PUT", storedStatus.getStatus(), null, storedStatus.getScheduledServerdId());
|
||||||
|
|
|
@ -556,6 +556,9 @@ public class API {
|
||||||
reaction.setName(resobj.getString("name"));
|
reaction.setName(resobj.getString("name"));
|
||||||
reaction.setCount(resobj.getInt("count"));
|
reaction.setCount(resobj.getInt("count"));
|
||||||
reaction.setMe(resobj.getBoolean("me"));
|
reaction.setMe(resobj.getBoolean("me"));
|
||||||
|
if( resobj.has("url")){
|
||||||
|
reaction.setUrl(resobj.getString("url"));
|
||||||
|
}
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -4094,6 +4097,17 @@ public class API {
|
||||||
return postAction(statusAction, targetedId, null, null);
|
return postAction(statusAction, targetedId, null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes the post action for a status
|
||||||
|
*
|
||||||
|
* @param statusAction Enum
|
||||||
|
* @param targetedId String id of the targeted Id *can be this of a status or an account*
|
||||||
|
* @return in status code - Should be equal to 200 when action is done
|
||||||
|
*/
|
||||||
|
public int postAction(StatusAction statusAction, String targetedId, String comment) {
|
||||||
|
return postAction(statusAction, targetedId, null, comment);
|
||||||
|
}
|
||||||
|
|
||||||
//Pleroma admin calls
|
//Pleroma admin calls
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -4245,7 +4259,10 @@ public class API {
|
||||||
break;
|
break;
|
||||||
case REMOVE_REACTION:
|
case REMOVE_REACTION:
|
||||||
case ADD_REACTION:
|
case ADD_REACTION:
|
||||||
action = String.format("announcements/%s/reactions/%s", targetedId, comment);
|
action = String.format("/announcements/%s/reactions/%s", targetedId, comment);
|
||||||
|
break;
|
||||||
|
case DISMISS_ANNOUNCEMENT:
|
||||||
|
action = String.format("/announcements/%s/dismiss", targetedId);
|
||||||
break;
|
break;
|
||||||
case AUTHORIZE:
|
case AUTHORIZE:
|
||||||
action = String.format("/follow_requests/%s/authorize", targetedId);
|
action = String.format("/follow_requests/%s/authorize", targetedId);
|
||||||
|
@ -6183,7 +6200,8 @@ public class API {
|
||||||
DELETESCHEDULED,
|
DELETESCHEDULED,
|
||||||
REFRESHPOLL,
|
REFRESHPOLL,
|
||||||
ADD_REACTION,
|
ADD_REACTION,
|
||||||
REMOVE_REACTION
|
REMOVE_REACTION,
|
||||||
|
DISMISS_ANNOUNCEMENT
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum accountPrivacy {
|
public enum accountPrivacy {
|
||||||
|
|
|
@ -21,6 +21,7 @@ public class Reaction implements Parcelable {
|
||||||
private String name;
|
private String name;
|
||||||
private int count;
|
private int count;
|
||||||
private boolean me;
|
private boolean me;
|
||||||
|
private String url;
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
|
@ -46,6 +47,17 @@ public class Reaction implements Parcelable {
|
||||||
this.me = me;
|
this.me = me;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Reaction() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getUrl() {
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUrl(String url) {
|
||||||
|
this.url = url;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int describeContents() {
|
public int describeContents() {
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -56,18 +68,17 @@ public class Reaction implements Parcelable {
|
||||||
dest.writeString(this.name);
|
dest.writeString(this.name);
|
||||||
dest.writeInt(this.count);
|
dest.writeInt(this.count);
|
||||||
dest.writeByte(this.me ? (byte) 1 : (byte) 0);
|
dest.writeByte(this.me ? (byte) 1 : (byte) 0);
|
||||||
}
|
dest.writeString(this.url);
|
||||||
|
|
||||||
public Reaction() {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Reaction(Parcel in) {
|
protected Reaction(Parcel in) {
|
||||||
this.name = in.readString();
|
this.name = in.readString();
|
||||||
this.count = in.readInt();
|
this.count = in.readInt();
|
||||||
this.me = in.readByte() != 0;
|
this.me = in.readByte() != 0;
|
||||||
|
this.url = in.readString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final Parcelable.Creator<Reaction> CREATOR = new Parcelable.Creator<Reaction>() {
|
public static final Creator<Reaction> CREATOR = new Creator<Reaction>() {
|
||||||
@Override
|
@Override
|
||||||
public Reaction createFromParcel(Parcel source) {
|
public Reaction createFromParcel(Parcel source) {
|
||||||
return new Reaction(source);
|
return new Reaction(source);
|
||||||
|
|
|
@ -15,17 +15,19 @@ package app.fedilab.android.drawers;
|
||||||
* see <http://www.gnu.org/licenses>. */
|
* see <http://www.gnu.org/licenses>. */
|
||||||
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import app.fedilab.android.R;
|
import app.fedilab.android.R;
|
||||||
import app.fedilab.android.client.Entities.Reaction;
|
import app.fedilab.android.client.Entities.Reaction;
|
||||||
|
import app.fedilab.android.helper.Helper;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -36,7 +38,7 @@ public class ReactionAdapter extends RecyclerView.Adapter {
|
||||||
|
|
||||||
private List<Reaction> reactions;
|
private List<Reaction> reactions;
|
||||||
|
|
||||||
public ReactionAdapter(List<Reaction> reactions) {
|
ReactionAdapter(List<Reaction> reactions) {
|
||||||
this.reactions = reactions;
|
this.reactions = reactions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,8 +53,23 @@ public class ReactionAdapter extends RecyclerView.Adapter {
|
||||||
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int i) {
|
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder viewHolder, int i) {
|
||||||
final Reaction reaction = reactions.get(viewHolder.getAdapterPosition());
|
final Reaction reaction = reactions.get(viewHolder.getAdapterPosition());
|
||||||
ViewHolder holder = (ViewHolder) viewHolder;
|
ViewHolder holder = (ViewHolder) viewHolder;
|
||||||
holder.reaction_name.setText(reaction.getName());
|
|
||||||
holder.reaction_count.setText(String.valueOf(reaction.getCount()));
|
holder.reaction_count.setText(String.valueOf(reaction.getCount()));
|
||||||
|
if(reaction.isMe()) {
|
||||||
|
holder.reaction_container.setBackgroundResource(R.drawable.reaction_voted);
|
||||||
|
}else{
|
||||||
|
holder.reaction_container.setBackgroundResource(R.drawable.reaction_border);
|
||||||
|
}
|
||||||
|
if(reaction.getUrl() != null){
|
||||||
|
holder.reaction_name.setVisibility(View.GONE);
|
||||||
|
holder.reaction_emoji.setVisibility(View.VISIBLE);
|
||||||
|
holder.reaction_emoji.setContentDescription(reaction.getName());
|
||||||
|
Helper.loadGiF(holder.itemView.getContext(), reaction.getUrl(), holder.reaction_emoji);
|
||||||
|
}else{
|
||||||
|
holder.reaction_name.setText(reaction.getName());
|
||||||
|
holder.reaction_name.setVisibility(View.VISIBLE);
|
||||||
|
holder.reaction_emoji.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -69,12 +86,14 @@ public class ReactionAdapter extends RecyclerView.Adapter {
|
||||||
static class ViewHolder extends RecyclerView.ViewHolder {
|
static class ViewHolder extends RecyclerView.ViewHolder {
|
||||||
TextView reaction_name, reaction_count;
|
TextView reaction_name, reaction_count;
|
||||||
LinearLayout reaction_container;
|
LinearLayout reaction_container;
|
||||||
|
ImageView reaction_emoji;
|
||||||
|
|
||||||
public ViewHolder(@NonNull View itemView) {
|
public ViewHolder(@NonNull View itemView) {
|
||||||
super(itemView);
|
super(itemView);
|
||||||
reaction_name = itemView.findViewById(R.id.reaction_name);
|
reaction_name = itemView.findViewById(R.id.reaction_name);
|
||||||
reaction_count = itemView.findViewById(R.id.reaction_count);
|
reaction_count = itemView.findViewById(R.id.reaction_count);
|
||||||
reaction_container = itemView.findViewById(R.id.reaction_container);
|
reaction_container = itemView.findViewById(R.id.reaction_container);
|
||||||
|
reaction_emoji = itemView.findViewById(R.id.reaction_emoji);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -93,6 +93,13 @@ import com.github.stom79.mytransl.client.HttpsConnectionException;
|
||||||
import com.github.stom79.mytransl.client.Results;
|
import com.github.stom79.mytransl.client.Results;
|
||||||
import com.github.stom79.mytransl.translate.Translate;
|
import com.github.stom79.mytransl.translate.Translate;
|
||||||
import com.google.android.material.floatingactionbutton.FloatingActionButton;
|
import com.google.android.material.floatingactionbutton.FloatingActionButton;
|
||||||
|
import com.vanniktech.emoji.EmojiImageView;
|
||||||
|
import com.vanniktech.emoji.EmojiManager;
|
||||||
|
import com.vanniktech.emoji.EmojiPopup;
|
||||||
|
import com.vanniktech.emoji.emoji.Emoji;
|
||||||
|
import com.vanniktech.emoji.listeners.OnEmojiClickListener;
|
||||||
|
import com.vanniktech.emoji.listeners.OnEmojiPopupDismissListener;
|
||||||
|
import com.vanniktech.emoji.one.EmojiOneProvider;
|
||||||
import com.varunest.sparkbutton.SparkButton;
|
import com.varunest.sparkbutton.SparkButton;
|
||||||
|
|
||||||
import org.apache.poi.sl.usermodel.Line;
|
import org.apache.poi.sl.usermodel.Line;
|
||||||
|
@ -181,6 +188,7 @@ import br.com.felix.horizontalbargraph.model.BarItem;
|
||||||
import es.dmoral.toasty.Toasty;
|
import es.dmoral.toasty.Toasty;
|
||||||
import jp.wasabeef.glide.transformations.BlurTransformation;
|
import jp.wasabeef.glide.transformations.BlurTransformation;
|
||||||
|
|
||||||
|
import static android.content.Context.INPUT_METHOD_SERVICE;
|
||||||
import static android.content.Context.MODE_PRIVATE;
|
import static android.content.Context.MODE_PRIVATE;
|
||||||
import static app.fedilab.android.activities.BaseMainActivity.mPageReferenceMap;
|
import static app.fedilab.android.activities.BaseMainActivity.mPageReferenceMap;
|
||||||
import static app.fedilab.android.activities.BaseMainActivity.mutedAccount;
|
import static app.fedilab.android.activities.BaseMainActivity.mutedAccount;
|
||||||
|
@ -246,6 +254,7 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
private Handler mHandler = new Handler();
|
private Handler mHandler = new Handler();
|
||||||
|
private int style;
|
||||||
|
|
||||||
public StatusListAdapter(StatusDrawerParams statusDrawerParams) {
|
public StatusListAdapter(StatusDrawerParams statusDrawerParams) {
|
||||||
statuses = statusDrawerParams.getStatuses();
|
statuses = statusDrawerParams.getStatuses();
|
||||||
|
@ -1017,6 +1026,100 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
LinearLayoutManager layoutManager
|
LinearLayoutManager layoutManager
|
||||||
= new LinearLayoutManager(context, LinearLayoutManager.HORIZONTAL, false);
|
= new LinearLayoutManager(context, LinearLayoutManager.HORIZONTAL, false);
|
||||||
holder.reactions_view.setLayoutManager(layoutManager);
|
holder.reactions_view.setLayoutManager(layoutManager);
|
||||||
|
|
||||||
|
|
||||||
|
holder.status_add_reaction.setOnClickListener(v -> {
|
||||||
|
EmojiManager.install(new EmojiOneProvider());
|
||||||
|
final EmojiPopup emojiPopup = EmojiPopup.Builder.fromRootView(holder.status_add_reaction).setOnEmojiPopupDismissListener(() -> {
|
||||||
|
InputMethodManager imm = (InputMethodManager) context.getSystemService(INPUT_METHOD_SERVICE);
|
||||||
|
assert imm != null;
|
||||||
|
imm.hideSoftInputFromWindow(holder.status_add_reaction.getWindowToken(), 0);
|
||||||
|
}).setOnEmojiClickListener((emoji, imageView) -> {
|
||||||
|
String emojiStr = imageView.getUnicode();
|
||||||
|
boolean alreadyAdded = false;
|
||||||
|
for(Reaction reaction: status.getReactions()){
|
||||||
|
if( reaction.getName().compareTo(emojiStr) == 0){
|
||||||
|
alreadyAdded = true;
|
||||||
|
reaction.setCount(reaction.getCount()-1);
|
||||||
|
if( reaction.getCount() == 0) {
|
||||||
|
status.getReactions().remove(reaction);
|
||||||
|
}
|
||||||
|
notifyStatusChanged(status);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( !alreadyAdded){
|
||||||
|
Reaction reaction = new Reaction();
|
||||||
|
reaction.setMe(true);
|
||||||
|
reaction.setCount(1);
|
||||||
|
reaction.setName(emojiStr);
|
||||||
|
status.getReactions().add(0, reaction);
|
||||||
|
notifyStatusChanged(status);
|
||||||
|
}
|
||||||
|
API.StatusAction statusAction = alreadyAdded?API.StatusAction.REMOVE_REACTION:API.StatusAction.ADD_REACTION;
|
||||||
|
new PostActionAsyncTask(context, statusAction, status.getId(), null,emojiStr, StatusListAdapter.this).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
|
||||||
|
})
|
||||||
|
.build(holder.fake_edittext);
|
||||||
|
emojiPopup.toggle();
|
||||||
|
});
|
||||||
|
holder.status_add_custom_emoji.setOnClickListener(v -> {
|
||||||
|
SQLiteDatabase db = Sqlite.getInstance(context, Sqlite.DB_NAME, null, Sqlite.DB_VERSION).open();
|
||||||
|
String instance = sharedpreferences.getString(Helper.PREF_INSTANCE, null);
|
||||||
|
Account account = new AccountDAO(context, db).getUniqAccount(userId, instance);
|
||||||
|
List<Emojis> emojis = new CustomEmojiDAO(context, db).getAllEmojis(account.getInstance());
|
||||||
|
if (theme == Helper.THEME_DARK) {
|
||||||
|
style = R.style.DialogDark;
|
||||||
|
} else if (theme == Helper.THEME_BLACK) {
|
||||||
|
style = R.style.DialogBlack;
|
||||||
|
} else {
|
||||||
|
style = R.style.Dialog;
|
||||||
|
}
|
||||||
|
final AlertDialog.Builder builder = new AlertDialog.Builder(context, style);
|
||||||
|
int paddingPixel = 15;
|
||||||
|
float density = context.getResources().getDisplayMetrics().density;
|
||||||
|
int paddingDp = (int) (paddingPixel * density);
|
||||||
|
builder.setNegativeButton(R.string.cancel, (dialog, which) -> dialog.dismiss());
|
||||||
|
builder.setTitle(R.string.insert_emoji);
|
||||||
|
if (emojis != null && emojis.size() > 0) {
|
||||||
|
GridView gridView = new GridView(context);
|
||||||
|
gridView.setAdapter(new CustomEmojiAdapter(emojis));
|
||||||
|
gridView.setNumColumns(5);
|
||||||
|
gridView.setOnItemClickListener((parent, view, position, id) -> {
|
||||||
|
boolean alreadyAdded = false;
|
||||||
|
for(Reaction reaction: status.getReactions()){
|
||||||
|
if( reaction.getName().compareTo(emojis.get(position).getShortcode()) == 0){
|
||||||
|
alreadyAdded = true;
|
||||||
|
reaction.setCount(reaction.getCount()-1);
|
||||||
|
if( reaction.getCount() == 0) {
|
||||||
|
status.getReactions().remove(reaction);
|
||||||
|
}
|
||||||
|
notifyStatusChanged(status);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( !alreadyAdded){
|
||||||
|
Reaction reaction = new Reaction();
|
||||||
|
reaction.setMe(true);
|
||||||
|
reaction.setCount(1);
|
||||||
|
reaction.setName(emojis.get(position).getShortcode());
|
||||||
|
reaction.setUrl(emojis.get(position).getUrl());
|
||||||
|
status.getReactions().add(0, reaction);
|
||||||
|
notifyStatusChanged(status);
|
||||||
|
}
|
||||||
|
API.StatusAction statusAction = alreadyAdded?API.StatusAction.REMOVE_REACTION:API.StatusAction.ADD_REACTION;
|
||||||
|
new PostActionAsyncTask(context, statusAction, status.getId(), null, emojis.get(position).getShortcode(), StatusListAdapter.this).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
|
||||||
|
alertDialogEmoji.dismiss();
|
||||||
|
});
|
||||||
|
gridView.setPadding(paddingDp, paddingDp, paddingDp, paddingDp);
|
||||||
|
builder.setView(gridView);
|
||||||
|
} else {
|
||||||
|
TextView textView = new TextView(context);
|
||||||
|
textView.setText(context.getString(R.string.no_emoji));
|
||||||
|
textView.setPadding(paddingDp, paddingDp, paddingDp, paddingDp);
|
||||||
|
builder.setView(textView);
|
||||||
|
}
|
||||||
|
alertDialogEmoji = builder.show();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
holder.status_cardview_title.setTextColor(ContextCompat.getColor(context, R.color.dark_text_toot_header));
|
holder.status_cardview_title.setTextColor(ContextCompat.getColor(context, R.color.dark_text_toot_header));
|
||||||
|
@ -2073,7 +2176,7 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
sendToot(status, null);
|
sendToot(status, null);
|
||||||
status.setShortReply(false);
|
status.setShortReply(false);
|
||||||
holder.quick_reply_container.setVisibility(View.GONE);
|
holder.quick_reply_container.setVisibility(View.GONE);
|
||||||
InputMethodManager imm = (InputMethodManager) context.getSystemService(Activity.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) context.getSystemService(INPUT_METHOD_SERVICE);
|
||||||
imm.hideSoftInputFromWindow(holder.quick_reply_button.getWindowToken(), 0);
|
imm.hideSoftInputFromWindow(holder.quick_reply_button.getWindowToken(), 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -2102,7 +2205,7 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
sendToot(status, contentType);
|
sendToot(status, contentType);
|
||||||
status.setShortReply(false);
|
status.setShortReply(false);
|
||||||
holder.quick_reply_container.setVisibility(View.GONE);
|
holder.quick_reply_container.setVisibility(View.GONE);
|
||||||
InputMethodManager imm = (InputMethodManager) context.getSystemService(Activity.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) context.getSystemService(INPUT_METHOD_SERVICE);
|
||||||
imm.hideSoftInputFromWindow(holder.quick_reply_button.getWindowToken(), 0);
|
imm.hideSoftInputFromWindow(holder.quick_reply_button.getWindowToken(), 0);
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
@ -2289,7 +2392,7 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
statusForQuickReply = status;
|
statusForQuickReply = status;
|
||||||
holder.quick_reply_container.setVisibility(View.VISIBLE);
|
holder.quick_reply_container.setVisibility(View.VISIBLE);
|
||||||
InputMethodManager inputMethodManager =
|
InputMethodManager inputMethodManager =
|
||||||
(InputMethodManager) context.getSystemService(Context.INPUT_METHOD_SERVICE);
|
(InputMethodManager) context.getSystemService(INPUT_METHOD_SERVICE);
|
||||||
inputMethodManager.toggleSoftInputFromWindow(
|
inputMethodManager.toggleSoftInputFromWindow(
|
||||||
holder.quick_reply_text.getApplicationWindowToken(),
|
holder.quick_reply_text.getApplicationWindowToken(),
|
||||||
InputMethodManager.SHOW_FORCED, 0);
|
InputMethodManager.SHOW_FORCED, 0);
|
||||||
|
@ -2401,7 +2504,7 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
} else {
|
} else {
|
||||||
status.setShortReply(false);
|
status.setShortReply(false);
|
||||||
holder.quick_reply_container.setVisibility(View.GONE);
|
holder.quick_reply_container.setVisibility(View.GONE);
|
||||||
InputMethodManager imm = (InputMethodManager) context.getSystemService(Activity.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) context.getSystemService(INPUT_METHOD_SERVICE);
|
||||||
imm.hideSoftInputFromWindow(holder.quick_reply_text.getWindowToken(), 0);
|
imm.hideSoftInputFromWindow(holder.quick_reply_text.getWindowToken(), 0);
|
||||||
}
|
}
|
||||||
holder.quick_reply_switch_to_full.setOnClickListener(v12 -> {
|
holder.quick_reply_switch_to_full.setOnClickListener(v12 -> {
|
||||||
|
@ -2433,7 +2536,7 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
if (status.isShortReply()) {
|
if (status.isShortReply()) {
|
||||||
status.setShortReply(false);
|
status.setShortReply(false);
|
||||||
holder.quick_reply_container.setVisibility(View.GONE);
|
holder.quick_reply_container.setVisibility(View.GONE);
|
||||||
InputMethodManager imm = (InputMethodManager) context.getSystemService(Activity.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) context.getSystemService(INPUT_METHOD_SERVICE);
|
||||||
imm.hideSoftInputFromWindow(holder.quick_reply_text.getWindowToken(), 0);
|
imm.hideSoftInputFromWindow(holder.quick_reply_text.getWindowToken(), 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3986,8 +4089,9 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
TextView translation_label;
|
TextView translation_label;
|
||||||
|
|
||||||
LinearLayout status_reactions;
|
LinearLayout status_reactions;
|
||||||
ImageView status_add_reaction;
|
ImageView status_add_reaction, status_add_custom_emoji;
|
||||||
RecyclerView reactions_view;
|
RecyclerView reactions_view;
|
||||||
|
MastalabAutoCompleteTextView fake_edittext;
|
||||||
|
|
||||||
@SuppressLint("SetJavaScriptEnabled")
|
@SuppressLint("SetJavaScriptEnabled")
|
||||||
ViewHolder(View itemView) {
|
ViewHolder(View itemView) {
|
||||||
|
@ -4119,7 +4223,9 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
|
||||||
|
|
||||||
status_reactions = itemView.findViewById(R.id.status_reactions);
|
status_reactions = itemView.findViewById(R.id.status_reactions);
|
||||||
status_add_reaction = itemView.findViewById(R.id.status_add_reaction);
|
status_add_reaction = itemView.findViewById(R.id.status_add_reaction);
|
||||||
|
status_add_custom_emoji = itemView.findViewById(R.id.status_add_custom_emoji);
|
||||||
reactions_view = itemView.findViewById(R.id.reactions_view);
|
reactions_view = itemView.findViewById(R.id.reactions_view);
|
||||||
|
fake_edittext = itemView.findViewById(R.id.fake_edittext);
|
||||||
}
|
}
|
||||||
|
|
||||||
public View getView() {
|
public View getView() {
|
||||||
|
|
|
@ -26,6 +26,7 @@ import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.view.inputmethod.InputMethodManager;
|
import android.view.inputmethod.InputMethodManager;
|
||||||
|
@ -46,6 +47,7 @@ import com.bumptech.glide.ListPreloader;
|
||||||
import com.bumptech.glide.RequestBuilder;
|
import com.bumptech.glide.RequestBuilder;
|
||||||
import com.bumptech.glide.integration.recyclerview.RecyclerViewPreloader;
|
import com.bumptech.glide.integration.recyclerview.RecyclerViewPreloader;
|
||||||
import com.bumptech.glide.util.FixedPreloadSizeProvider;
|
import com.bumptech.glide.util.FixedPreloadSizeProvider;
|
||||||
|
import com.google.android.material.navigation.NavigationView;
|
||||||
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@ -59,15 +61,19 @@ import app.fedilab.android.R;
|
||||||
import app.fedilab.android.activities.BaseMainActivity;
|
import app.fedilab.android.activities.BaseMainActivity;
|
||||||
import app.fedilab.android.activities.MainActivity;
|
import app.fedilab.android.activities.MainActivity;
|
||||||
import app.fedilab.android.asynctasks.ManageListsAsyncTask;
|
import app.fedilab.android.asynctasks.ManageListsAsyncTask;
|
||||||
|
import app.fedilab.android.asynctasks.PostActionAsyncTask;
|
||||||
import app.fedilab.android.asynctasks.RetrieveFeedsAfterBookmarkAsyncTask;
|
import app.fedilab.android.asynctasks.RetrieveFeedsAfterBookmarkAsyncTask;
|
||||||
import app.fedilab.android.asynctasks.RetrieveFeedsAsyncTask;
|
import app.fedilab.android.asynctasks.RetrieveFeedsAsyncTask;
|
||||||
import app.fedilab.android.asynctasks.RetrieveMissingFeedsAsyncTask;
|
import app.fedilab.android.asynctasks.RetrieveMissingFeedsAsyncTask;
|
||||||
import app.fedilab.android.asynctasks.RetrievePeertubeSearchAsyncTask;
|
import app.fedilab.android.asynctasks.RetrievePeertubeSearchAsyncTask;
|
||||||
import app.fedilab.android.asynctasks.UpdateAccountInfoAsyncTask;
|
import app.fedilab.android.asynctasks.UpdateAccountInfoAsyncTask;
|
||||||
|
import app.fedilab.android.client.API;
|
||||||
import app.fedilab.android.client.APIResponse;
|
import app.fedilab.android.client.APIResponse;
|
||||||
import app.fedilab.android.client.Entities.Account;
|
import app.fedilab.android.client.Entities.Account;
|
||||||
|
import app.fedilab.android.client.Entities.Announcement;
|
||||||
import app.fedilab.android.client.Entities.Attachment;
|
import app.fedilab.android.client.Entities.Attachment;
|
||||||
import app.fedilab.android.client.Entities.Conversation;
|
import app.fedilab.android.client.Entities.Conversation;
|
||||||
|
import app.fedilab.android.client.Entities.Error;
|
||||||
import app.fedilab.android.client.Entities.Peertube;
|
import app.fedilab.android.client.Entities.Peertube;
|
||||||
import app.fedilab.android.client.Entities.RemoteInstance;
|
import app.fedilab.android.client.Entities.RemoteInstance;
|
||||||
import app.fedilab.android.client.Entities.RetrieveFeedsParam;
|
import app.fedilab.android.client.Entities.RetrieveFeedsParam;
|
||||||
|
@ -80,6 +86,7 @@ import app.fedilab.android.drawers.PixelfedListAdapter;
|
||||||
import app.fedilab.android.drawers.StatusListAdapter;
|
import app.fedilab.android.drawers.StatusListAdapter;
|
||||||
import app.fedilab.android.helper.Helper;
|
import app.fedilab.android.helper.Helper;
|
||||||
import app.fedilab.android.interfaces.OnListActionInterface;
|
import app.fedilab.android.interfaces.OnListActionInterface;
|
||||||
|
import app.fedilab.android.interfaces.OnPostActionInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveFeedsAfterBookmarkInterface;
|
import app.fedilab.android.interfaces.OnRetrieveFeedsAfterBookmarkInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveFeedsInterface;
|
import app.fedilab.android.interfaces.OnRetrieveFeedsInterface;
|
||||||
import app.fedilab.android.interfaces.OnRetrieveMissingFeedsInterface;
|
import app.fedilab.android.interfaces.OnRetrieveMissingFeedsInterface;
|
||||||
|
@ -95,7 +102,7 @@ import es.dmoral.toasty.Toasty;
|
||||||
* Created by Thomas on 24/04/2017.
|
* Created by Thomas on 24/04/2017.
|
||||||
* Fragment to display content related to status
|
* Fragment to display content related to status
|
||||||
*/
|
*/
|
||||||
public class DisplayStatusFragment extends Fragment implements OnRetrieveFeedsInterface, OnRetrieveMissingFeedsInterface, OnRetrieveFeedsAfterBookmarkInterface, OnListActionInterface {
|
public class DisplayStatusFragment extends Fragment implements OnPostActionInterface, OnRetrieveFeedsInterface, OnRetrieveMissingFeedsInterface, OnRetrieveFeedsAfterBookmarkInterface, OnListActionInterface {
|
||||||
|
|
||||||
|
|
||||||
private LinearLayoutManager mLayoutManager;
|
private LinearLayoutManager mLayoutManager;
|
||||||
|
@ -602,8 +609,20 @@ public class DisplayStatusFragment extends Fragment implements OnRetrieveFeedsIn
|
||||||
apiResponse.setStatuses(statusesConversations);
|
apiResponse.setStatuses(statusesConversations);
|
||||||
}else if( type == RetrieveFeedsAsyncTask.Type.ANNOUNCEMENTS){
|
}else if( type == RetrieveFeedsAsyncTask.Type.ANNOUNCEMENTS){
|
||||||
if( apiResponse.getAnnouncements() != null && apiResponse.getAnnouncements().size() > 0 ){
|
if( apiResponse.getAnnouncements() != null && apiResponse.getAnnouncements().size() > 0 ){
|
||||||
List<Status> statusesAnnouncements = new ArrayList<>(apiResponse.getAnnouncements());
|
List<Status> statusesAnnouncements = new ArrayList<>();
|
||||||
apiResponse.setStatuses(statusesAnnouncements);
|
apiResponse.setStatuses(statusesAnnouncements);
|
||||||
|
for(Announcement announcement: apiResponse.getAnnouncements()){
|
||||||
|
statusesAnnouncements.add(0,announcement);
|
||||||
|
if( !announcement.isRead()){
|
||||||
|
new PostActionAsyncTask(context, API.StatusAction.DISMISS_ANNOUNCEMENT, announcement.getId(), DisplayStatusFragment.this).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
final NavigationView navigationView = ((MainActivity)context).findViewById(R.id.nav_view);
|
||||||
|
MenuItem item = navigationView.getMenu().findItem(R.id.nav_announcements);
|
||||||
|
TextView actionView = item.getActionView().findViewById(R.id.counter);
|
||||||
|
if(actionView != null) {
|
||||||
|
actionView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
int previousPosition = this.statuses.size();
|
int previousPosition = this.statuses.size();
|
||||||
|
@ -1266,6 +1285,11 @@ public class DisplayStatusFragment extends Fragment implements OnRetrieveFeedsIn
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPostAction(int statusCode, API.StatusAction statusAction, String userId, Error error) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private class MyPreloadModelProvider implements ListPreloader.PreloadModelProvider<String> {
|
private class MyPreloadModelProvider implements ListPreloader.PreloadModelProvider<String> {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -3,5 +3,5 @@
|
||||||
<stroke
|
<stroke
|
||||||
android:width="1dp"
|
android:width="1dp"
|
||||||
android:color="@color/mastodonC4" />
|
android:color="@color/mastodonC4" />
|
||||||
<corners android:radius="4dp" />
|
<corners android:radius="10dp" />
|
||||||
</shape>
|
</shape>
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<solid android:color="@color/mastodonC4" />
|
||||||
<stroke
|
<stroke
|
||||||
android:width="1dp"
|
android:width="1dp"
|
||||||
android:color="@color/mastodonC4" />
|
android:color="@color/mastodonC4" />
|
||||||
|
|
|
@ -2,6 +2,6 @@
|
||||||
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
<stroke
|
<stroke
|
||||||
android:width="1dp"
|
android:width="1dp"
|
||||||
android:color="@color/mastodonC4" />
|
android:color="?colorAccent" />
|
||||||
<corners android:radius="10dp" />
|
<corners android:radius="10dp" />
|
||||||
</shape>
|
</shape>
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<solid android:color="?colorAccent" />
|
||||||
<stroke
|
<stroke
|
||||||
android:width="1dp"
|
android:width="1dp"
|
||||||
android:color="?colorAccent" />
|
android:color="?colorAccent" />
|
||||||
|
|
|
@ -15,17 +15,35 @@
|
||||||
see <http://www.gnu.org/licenses>.
|
see <http://www.gnu.org/licenses>.
|
||||||
-->
|
-->
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:id="@+id/reaction_container"
|
android:id="@+id/reaction_container"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:paddingTop="2dp"
|
||||||
|
android:paddingBottom="2dp"
|
||||||
|
android:paddingEnd="5dp"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:paddingStart="5dp"
|
||||||
|
android:paddingLeft="5dp"
|
||||||
|
android:layout_marginEnd="10dp"
|
||||||
|
android:gravity="center"
|
||||||
android:orientation="horizontal">
|
android:orientation="horizontal">
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/reaction_name"
|
android:id="@+id/reaction_name"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="center"
|
android:layout_gravity="center"
|
||||||
|
android:textSize="16sp"
|
||||||
|
android:layout_marginEnd="3dp"
|
||||||
/>
|
/>
|
||||||
|
<ImageView
|
||||||
|
android:layout_width="20dp"
|
||||||
|
android:layout_height="20dp"
|
||||||
|
android:layout_marginEnd="3dp"
|
||||||
|
android:id="@+id/reaction_emoji"
|
||||||
|
tools:ignore="ContentDescription" />
|
||||||
<TextView
|
<TextView
|
||||||
|
android:textSize="16sp"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:id="@+id/reaction_count"/>
|
android:id="@+id/reaction_count"/>
|
||||||
|
|
|
@ -865,24 +865,51 @@
|
||||||
android:id="@+id/status_reactions"
|
android:id="@+id/status_reactions"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="10dp"
|
||||||
android:layout_marginBottom="10dp"
|
android:layout_marginBottom="10dp"
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
|
android:layout_gravity="center"
|
||||||
app:layout_constraintBottom_toBottomOf="parent">
|
app:layout_constraintBottom_toBottomOf="parent">
|
||||||
|
<LinearLayout
|
||||||
|
android:visibility="gone"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
<app.fedilab.android.helper.MastalabAutoCompleteTextView
|
||||||
|
android:id="@+id/fake_edittext"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:importantForAutofill="no"
|
||||||
|
android:inputType="text" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/status_add_reaction"
|
android:id="@+id/status_add_reaction"
|
||||||
android:layout_width="30dp"
|
android:layout_width="30dp"
|
||||||
android:layout_height="30dp"
|
android:layout_height="30dp"
|
||||||
android:src="@drawable/ic_add"
|
android:src="@drawable/ic_add"
|
||||||
|
android:layout_marginEnd="10dp"
|
||||||
app:tint="?attr/iconColor"
|
app:tint="?attr/iconColor"
|
||||||
app:layout_constraintBottom_toBottomOf="parent"
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent"
|
app:layout_constraintTop_toTopOf="parent"
|
||||||
android:contentDescription="@string/add_reaction" />
|
android:contentDescription="@string/add_reaction" />
|
||||||
|
|
||||||
<androidx.recyclerview.widget.RecyclerView
|
<androidx.recyclerview.widget.RecyclerView
|
||||||
android:id="@+id/reactions_view"
|
android:id="@+id/reactions_view"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_weight="1"/>
|
android:layout_weight="1"/>
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/status_add_custom_emoji"
|
||||||
|
android:layout_width="30dp"
|
||||||
|
android:layout_height="30dp"
|
||||||
|
android:src="@drawable/ic_insert_emoticon"
|
||||||
|
android:layout_marginStart="10dp"
|
||||||
|
app:tint="?attr/iconColor"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent"
|
||||||
|
android:contentDescription="@string/add_reaction" />
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
<androidx.constraintlayout.widget.ConstraintLayout
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
android:id="@+id/status_action_container"
|
android:id="@+id/status_action_container"
|
||||||
|
|
|
@ -14,12 +14,21 @@
|
||||||
You should have received a copy of the GNU General Public License along with Fedilab; if not,
|
You should have received a copy of the GNU General Public License along with Fedilab; if not,
|
||||||
see <http://www.gnu.org/licenses>.
|
see <http://www.gnu.org/licenses>.
|
||||||
-->
|
-->
|
||||||
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_gravity="center"
|
||||||
android:background="@drawable/shape_counter"
|
android:gravity="center"
|
||||||
android:paddingLeft="2dp"
|
android:layout_height="match_parent">
|
||||||
android:paddingRight="2dp"
|
<TextView
|
||||||
android:textColor="@color/mastodonC1"
|
android:layout_width="wrap_content"
|
||||||
android:textSize="12sp"
|
android:layout_height="wrap_content"
|
||||||
android:visibility="gone" />
|
android:layout_gravity="center"
|
||||||
|
android:gravity="center"
|
||||||
|
android:background="@drawable/shape_counter"
|
||||||
|
android:id="@+id/counter"
|
||||||
|
android:paddingLeft="5dp"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:textColor="@color/mastodonC1"
|
||||||
|
android:visibility="gone" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue