add 分享

add 推送(搜索还没做、卡片还没做)
add 打招呼
This commit is contained in:
2024-03-15 16:06:18 +08:00
parent 828c5bd53e
commit 687d6e9bc0
66 changed files with 2225 additions and 31 deletions

View File

@@ -0,0 +1,84 @@
package com.yunbao.share.adapters;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.RadioButton;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import com.pdlive.shayu.R;
import com.yunbao.common.glide.ImgLoader;
import com.yunbao.common.views.weight.ClipPathCircleImage;
import java.util.ArrayList;
import java.util.List;
import io.rong.imkit.conversationlist.model.SingleConversation;
import io.rong.imlib.model.Conversation;
public class InternalShareAdapter extends RecyclerView.Adapter<InternalShareAdapter.ViewHolder> {
List<SingleConversation> listData = new ArrayList<>();
int selectPosition = -1;
@NonNull
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
return new ViewHolder(LayoutInflater.from(parent.getContext()).inflate(R.layout.item_internal_user, parent, false));
}
@Override
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
holder.bind(listData.get(position), position);
}
@Override
public int getItemCount() {
return listData.size();
}
public void setList(List<SingleConversation> listData) {
if (listData == null) {
listData = new ArrayList<>();
}
this.listData = listData;
notifyDataSetChanged();
}
public int getSelectPosition() {
return selectPosition;
}
public class ViewHolder extends RecyclerView.ViewHolder {
ClipPathCircleImage mAvatar;
TextView userName;
TextView content;
RadioButton radioButton;
public ViewHolder(@NonNull View itemView) {
super(itemView);
mAvatar = itemView.findViewById(R.id.rc_conversation_portrait);
userName = itemView.findViewById(R.id.rc_conversation_title);
content = itemView.findViewById(R.id.rc_conversation_content);
radioButton = itemView.findViewById(R.id.btn);
}
public void bind(SingleConversation item, int position) {
ImgLoader.display(itemView.getContext(), item.mCore.getPortraitUrl(), mAvatar);
userName.setText(item.mCore.getConversationTitle());
content.setText("");
if (selectPosition == position) {
radioButton.setChecked(true);
} else {
radioButton.setChecked(false);
}
itemView.setOnClickListener(view -> {
selectPosition = position;
notifyDataSetChanged();
});
}
}
}

View File

@@ -18,6 +18,7 @@ import com.yunbao.share.ICallback;
import com.yunbao.share.bean.ShareBuilder;
import com.yunbao.share.platform.FacebookShare;
import com.yunbao.share.platform.Instagram;
import com.yunbao.share.platform.Internal;
import com.yunbao.share.platform.Line;
import com.yunbao.share.platform.MessengerShare;
import com.yunbao.share.platform.TwitterShare;
@@ -30,6 +31,7 @@ import java.util.List;
public class ShareAppAdapter extends RecyclerView.Adapter<ShareAppAdapter.AppViewHolder> {
private Context mContext;
private List<ShareBuilder> list;
ShareCallback shareCallback;
public ShareAppAdapter(Context mContext) {
list = new ArrayList<>();
@@ -69,6 +71,9 @@ public class ShareAppAdapter extends RecyclerView.Adapter<ShareAppAdapter.AppVie
case ShareBuilder.APP_INSTAGRAM:
holder.setData(builder, R.mipmap.icon_share_instagram, R.string.dialog_share_app_instagram);
break;
case ShareBuilder.APP_INTERNAL:
holder.setData(builder, R.mipmap.ic_share_friend, R.string.dialog_share_app_internal);
break;
}
}
@@ -77,7 +82,14 @@ public class ShareAppAdapter extends RecyclerView.Adapter<ShareAppAdapter.AppVie
return list.size();
}
public static class AppViewHolder extends RecyclerView.ViewHolder {
public void setOnShareStatusListener(ShareCallback shareCallback) {
this.shareCallback = shareCallback;
if (this.shareCallback == null) {
this.shareCallback = new ShareCallback();
}
}
public class AppViewHolder extends RecyclerView.ViewHolder {
ImageView icon;
TextView title;
@@ -110,21 +122,25 @@ public class ShareAppAdapter extends RecyclerView.Adapter<ShareAppAdapter.AppVie
case ShareBuilder.APP_INSTAGRAM:
new Instagram(itemView.getContext()).share(bean, new ShareCallback());
break;
case ShareBuilder.APP_INTERNAL:
new Internal(itemView.getContext()).share(bean, shareCallback);
break;
}
});
}
private static class ShareCallback implements ICallback {
@Override
public void onSuccess() {
}
public static class ShareCallback implements ICallback {
}
@Override
public void onSuccess() {
@Override
public void onFailure() {
}
@Override
public void onFailure() {
}
}
}
}

View File

@@ -19,6 +19,7 @@ public class ShareBuilder {
public static final int APP_WHATSAPP = 3;
public static final int APP_MESSENGER = 4;
public static final int APP_INSTAGRAM = 5;
public static final int APP_INTERNAL = 6;
private String text;
private String link;

View File

@@ -0,0 +1,35 @@
package com.yunbao.share.platform;
import android.content.Context;
import com.yunbao.common.interfaces.OnItemClickListener;
import com.yunbao.common.utils.ToastUtil;
import com.yunbao.share.AbsShareInterface;
import com.yunbao.share.ICallback;
import com.yunbao.share.bean.ShareBuilder;
import com.yunbao.share.ui.AppInternalShareDialog;
import com.yunbao.share.ui.ShareSuccessNotifyDialog;
public class Internal extends AbsShareInterface {
public Internal(Context context) {
super(context);
}
@Override
public void share(ShareBuilder builder, ICallback callback) {
new AppInternalShareDialog(mContext)
.setOnItemClickListener(new OnItemClickListener<String>() {
@Override
public void onItemClick(String toUid, int position) {
if (position == -1) {
callback.onFailure();
return;
}
builder.setUid(toUid);
new ShareSuccessNotifyDialog(mContext, builder)
.showDialog();
callback.onSuccess();
}
}).showDialog();
}
}

View File

@@ -0,0 +1,141 @@
package com.yunbao.share.ui;
import android.content.Context;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import com.lxj.xpopup.XPopup;
import com.pdlive.shayu.R;
import com.yunbao.common.bean.MessageChatUserBean;
import com.yunbao.common.dialog.AbsDialogFullScreenPopupWindow;
import com.yunbao.common.interfaces.OnItemClickListener;
import com.yunbao.common.utils.ToastUtil;
import com.yunbao.common.utils.ViewUtils;
import com.yunbao.share.adapters.InternalShareAdapter;
import com.yunbao.share.bean.ShareBuilder;
import java.util.ArrayList;
import java.util.List;
import io.rong.imkit.conversationlist.model.SingleConversation;
import io.rong.imkit.userinfo.RongUserInfoManager;
import io.rong.imkit.widget.refresh.SmartRefreshLayout;
import io.rong.imkit.widget.refresh.api.RefreshLayout;
import io.rong.imkit.widget.refresh.listener.OnLoadMoreListener;
import io.rong.imkit.widget.refresh.listener.OnRefreshListener;
import io.rong.imkit.widget.refresh.wrapper.RongRefreshHeader;
import io.rong.imlib.IRongCoreCallback;
import io.rong.imlib.IRongCoreEnum;
import io.rong.imlib.RongCoreClient;
import io.rong.imlib.RongIMClient;
import io.rong.imlib.model.Conversation;
public class AppInternalShareDialog extends AbsDialogFullScreenPopupWindow {
EditText search;
OnItemClickListener<String> onItemClickListener;
InternalShareAdapter adapter;
protected SmartRefreshLayout mRefreshLayout;
protected RecyclerView mList;
long startTime = 0;
List<SingleConversation> listData = new ArrayList<>();
public AppInternalShareDialog(@NonNull Context context) {
super(context);
}
@Override
public void buildDialog(XPopup.Builder builder) {
}
public AppInternalShareDialog setOnItemClickListener(OnItemClickListener<String> onItemClickListener) {
this.onItemClickListener = onItemClickListener;
return this;
}
@Override
public int bindLayoutId() {
return R.layout.dialog_shrea_internal;
}
@Override
protected void onCreate() {
super.onCreate();
findViewById(R.id.btn_back).setOnClickListener(view -> {
if (onItemClickListener != null) {
onItemClickListener.onItemClick(null, -1);
}
dismiss();
});
findViewById(R.id.btn_share).setOnClickListener(view -> {
if (onItemClickListener != null) {
onItemClickListener.onItemClick(listData.get(adapter.getSelectPosition()).mCore.getTargetId(), adapter.getSelectPosition());
}
dismiss();
});
search = findViewById(R.id.search);
mList = findViewById(R.id.recyclerView);
mRefreshLayout = findViewById(R.id.rc_refresh);
adapter = new InternalShareAdapter();
mList.setAdapter(adapter);
initRefreshView();
refreshData();
}
protected void initRefreshView() {
this.mRefreshLayout.setNestedScrollingEnabled(false);
this.mRefreshLayout.setRefreshHeader(new RongRefreshHeader(this.getContext()));
this.mRefreshLayout.setRefreshFooter(new RongRefreshHeader(this.getContext()));
this.mRefreshLayout.setOnRefreshListener(new OnRefreshListener() {
public void onRefresh(@NonNull RefreshLayout refreshLayout) {
onConversationListRefresh(refreshLayout);
}
});
this.mRefreshLayout.setOnLoadMoreListener(new OnLoadMoreListener() {
public void onLoadMore(@NonNull RefreshLayout refreshLayout) {
onConversationListLoadMore();
}
});
}
private void onConversationListLoadMore() {
refreshData();
}
private void onConversationListRefresh(RefreshLayout refreshLayout) {
listData.clear();
startTime = 0;
refreshData();
}
private void refreshData() {
RongCoreClient.getInstance().getConversationListByPage(new IRongCoreCallback.ResultCallback<List<Conversation>>() {
@Override
public void onSuccess(List<Conversation> conversations) {
if (conversations.isEmpty()) {
mRefreshLayout.finishLoadMoreWithNoMoreData();
return;
}
List<SingleConversation> tmp = new ArrayList<>();
for (Conversation conversation : conversations) {
tmp.add(new SingleConversation(getContext(), conversation));
}
startTime = conversations.get(conversations.size() - 1).getSentTime();
listData.addAll(tmp);
adapter.setList(listData);
mRefreshLayout.finishRefresh(true);
}
@Override
public void onError(IRongCoreEnum.CoreErrorCode e) {
ToastUtil.show("出错了:" + e.getMessage());
}
}, startTime, 10, Conversation.ConversationType.PRIVATE);
}
}

View File

@@ -12,6 +12,7 @@ import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.lxj.xpopup.XPopup;
import com.lxj.xpopup.util.XPopupUtils;
import com.makeramen.roundedimageview.RoundedImageView;
import com.pdlive.shayu.R;
import com.yunbao.common.dialog.AbsDialogPopupWindow;
@@ -70,7 +71,6 @@ public class SharePopDialog extends AbsDialogPopupWindow {
@Override
public void buildDialog(XPopup.Builder builder) {
}
@Override
@@ -89,6 +89,13 @@ public class SharePopDialog extends AbsDialogPopupWindow {
info = findViewById(R.id.share_info);
link = findViewById(R.id.share_link);
adapter = new ShareAppAdapter(getContext());
adapter.setOnShareStatusListener(new ShareAppAdapter.ShareCallback(){
@Override
public void onSuccess() {
super.onSuccess();
dismiss();
}
});
list.setLayoutManager(new GridLayoutManager(getContext(), 3));
list.setAdapter(adapter);
initData();
@@ -101,7 +108,7 @@ public class SharePopDialog extends AbsDialogPopupWindow {
data.add(builder(ShareBuilder.APP_TWITTER));
data.add(builder(ShareBuilder.APP_WHATSAPP));
data.add(builder(ShareBuilder.APP_MESSENGER));
//data.add(builder(ShareBuilder.APP_INSTAGRAM));
data.add(builder(ShareBuilder.APP_INTERNAL));
adapter.setList(data);
String url;
if (shareLink == null) {

View File

@@ -0,0 +1,87 @@
package com.yunbao.share.ui;
import android.content.Context;
import android.content.DialogInterface;
import android.os.Handler;
import android.os.Looper;
import android.widget.TextView;
import androidx.annotation.NonNull;
import com.lxj.xpopup.XPopup;
import com.lxj.xpopup.enums.PopupAnimation;
import com.pdlive.shayu.R;
import com.yunbao.common.bean.MessageUserInfoBean;
import com.yunbao.common.custom.RatioRoundImageView;
import com.yunbao.common.dialog.AbsDialogPositionPopupWindow;
import com.yunbao.common.glide.ImgLoader;
import com.yunbao.common.utils.DpUtil;
import com.yunbao.common.utils.StringUtil;
import com.yunbao.share.bean.ShareBuilder;
import io.rong.imkit.utils.RouteUtils;
import io.rong.imlib.model.Conversation;
public class ShareSuccessNotifyDialog extends AbsDialogPositionPopupWindow {
private ShareBuilder bean;
private DialogInterface.OnDismissListener onDismissListener;
private TextView anchorName;
private RatioRoundImageView avatar;
public ShareSuccessNotifyDialog(@NonNull Context context) {
super(context);
}
public ShareSuccessNotifyDialog(@NonNull Context context, ShareBuilder bean) {
super(context);
this.bean = bean;
}
public ShareSuccessNotifyDialog setOnDismissListener(DialogInterface.OnDismissListener onDismissListener) {
this.onDismissListener = onDismissListener;
return this;
}
@Override
public void buildDialog(XPopup.Builder builder) {
builder.positionByWindowCenter(true);
builder.moveUpToKeyboard(false);
builder.dismissOnTouchOutside(false);
builder.dismissOnBackPressed(false);
builder.isTouchThrough(true);
builder.isClickThrough(true);
builder.isCenterHorizontal(true);
builder.hasShadowBg(false);
builder.animationDuration(500);
builder.popupAnimation(PopupAnimation.ScaleAlphaFromCenter);
builder.offsetY(DpUtil.dp2px(60));
}
@Override
public int bindLayoutId() {
return R.layout.view_share_success_notify;
}
@Override
protected void onShow() {
super.onShow();
}
@Override
protected void onCreate() {
super.onCreate();
findViewById(R.id.liveGo).setOnClickListener(v -> {
Conversation.ConversationType type = Conversation.ConversationType.PRIVATE;
RouteUtils.routeToConversationActivity(mContext, type, bean.getUid(), null);
});
new Handler(Looper.getMainLooper()).postDelayed(() -> {
dismiss();
if (onDismissListener != null) {
onDismissListener.onDismiss(null);
}
}, 5000);
}
}