diff --git a/common/src/main/java/com/yunbao/common/bean/OpenAdModel.java b/common/src/main/java/com/yunbao/common/bean/OpenAdModel.java index 0189513be..a6a4ce3ac 100644 --- a/common/src/main/java/com/yunbao/common/bean/OpenAdModel.java +++ b/common/src/main/java/com/yunbao/common/bean/OpenAdModel.java @@ -17,14 +17,17 @@ public class OpenAdModel extends BaseModel { public static final int MODEL_SQUARE = 1;//正方形 public static final int MODEL_RECTANGLE = 2;//长方形 public static final int MODEL_BOTTOM = 3;//底部 + public static final int SHOW_DEF = 1;//1. 杀死程序后弹出; + public static final int SHOW_DIY = 2;//2. 自定义时间:自上次弹出弹窗后,00:00小时(范围:00:01小时-48:00小时)后再弹出(到时间后也需满足触发条件再弹出); + public static final int SHOW_ONE = 3;//3. 仅弹出一次; @SerializedName("id") private int id; @SerializedName("popup_location") private int type = TYPE_HOME; @SerializedName("activity_url") - private String url; + private String url;//点击跳转url @SerializedName("image_url") - private String imageUrl; + private String imageUrl;//图片url @SerializedName("display_time") private int showTime; //持续展示时间 @SerializedName("delay_show_time") @@ -37,11 +40,48 @@ public class OpenAdModel extends BaseModel { private String endTime;//活动结束时间 @SerializedName("popup_permission") private int permission; + @SerializedName("popup_frequency") + private int showModel = SHOW_DEF;//显示模式,1:杀死程序后弹出 2:指定时间内(本机时间) 3:1. 仅弹出一次 + @SerializedName("popup_frequency_time") + private String section = "0";// SHOW_DEF = 2 public OpenAdModel() { } + public static OpenAdModel createTestData() { + OpenAdModel model = new OpenAdModel(); + model.id=3; + model.type=1; + model.url = "/h5/GuildTournament/20230821/rank.html"; + model.imageUrl = "https://ceshi.yaoulive.com/data/upload/20230913/1694589490.png"; + model.showTime = 10; + model.delayShowTime = 0; + model.model = MODEL_SQUARE; + model.startTime = "2019-01-01 00:00:00"; + model.endTime = "2029-01-01 00:00:00"; + model.permission = 4; + model.showModel = SHOW_DIY; + model.section = "5"; + return model; + } + + public int getShowModel() { + return showModel; + } + + public void setShowModel(int showModel) { + this.showModel = showModel; + } + + public String getSection() { + return section; + } + + public void setSection(String section) { + this.section = section; + } + public int getType() { return type; } diff --git a/common/src/main/java/com/yunbao/common/manager/IMLoginManager.java b/common/src/main/java/com/yunbao/common/manager/IMLoginManager.java index 90e1fbda8..7920c8b1c 100644 --- a/common/src/main/java/com/yunbao/common/manager/IMLoginManager.java +++ b/common/src/main/java/com/yunbao/common/manager/IMLoginManager.java @@ -58,7 +58,7 @@ public class IMLoginManager extends BaseCacheManager { } public boolean getRedPoint() { - return !TextUtils.isEmpty(getString("RedPoint")) && !TextUtils.equals(getString("RedPoint"), "1"); + return !TextUtils.isEmpty(getString("RedPoint")) || !TextUtils.equals(getString("RedPoint"), "1"); } public void setQuickGiftIfFirst() { put("quick_gift_if_first", "1"); diff --git a/common/src/main/java/com/yunbao/common/manager/OpenAdManager.java b/common/src/main/java/com/yunbao/common/manager/OpenAdManager.java index 7d64a092c..19e366823 100644 --- a/common/src/main/java/com/yunbao/common/manager/OpenAdManager.java +++ b/common/src/main/java/com/yunbao/common/manager/OpenAdManager.java @@ -11,6 +11,8 @@ import com.yunbao.common.dialog.OpenAdBottomDialogPopup; import com.yunbao.common.dialog.OpenAdCenterDialogPopup; import com.yunbao.common.http.base.HttpCallback; import com.yunbao.common.http.live.LiveNetManager; +import com.yunbao.common.utils.SpUtil; +import com.yunbao.common.utils.StringUtil; import com.yunbao.common.utils.ToastUtil; import java.util.ArrayList; @@ -93,6 +95,18 @@ public class OpenAdManager { if (type == OpenAdModel.TYPE_LIVE && !model.userIsPermission(isGuard)) { continue; } + if (model.getShowModel() == OpenAdModel.SHOW_ONE) { + if (SpUtil.getInstance().getBooleanValue("open_ad_popup_" + model.getId())) { + continue; + } + SpUtil.getInstance().setBooleanValue("open_ad_popup_" + model.getId(), true); + } + if (model.getShowModel() == OpenAdModel.SHOW_DIY) { + String value = SpUtil.getStringValue("open_ad_popup_time_" + model.getId()); + if (!StringUtil.isEmpty(value) && System.currentTimeMillis() < Long.parseLong(value)) { + continue; + } + } if (runnableMap.containsKey(model.getId())) { AdRunnable runnable = runnableMap.get(model.getId()); if (runnable != null) { @@ -166,6 +180,10 @@ public class OpenAdManager { return; } showMap.put(model.getId(), true); + if (model.getShowModel() == OpenAdModel.SHOW_DIY) { + String nextTime= String.valueOf(System.currentTimeMillis() + (Long.parseLong(model.getSection()) * 60 * 1000)); + SpUtil.setStringValue("open_ad_popup_time_" + model.getId(), nextTime); + } if (model.getModel() == OpenAdModel.MODEL_BOTTOM) { new OpenAdBottomDialogPopup(CommonAppContext.getTopActivity(), model).setListener((bean, position) -> { }).showDialog(); diff --git a/common/src/main/java/com/yunbao/common/pay/samsung/SamsungUtil.java b/common/src/main/java/com/yunbao/common/pay/samsung/SamsungUtil.java index 53d36c2b0..f18994593 100644 --- a/common/src/main/java/com/yunbao/common/pay/samsung/SamsungUtil.java +++ b/common/src/main/java/com/yunbao/common/pay/samsung/SamsungUtil.java @@ -11,18 +11,72 @@ import com.samsung.android.sdk.iap.lib.vo.ConsumeVo; import com.samsung.android.sdk.iap.lib.vo.ErrorVo; import com.samsung.android.sdk.iap.lib.vo.OwnedProductVo; import com.samsung.android.sdk.iap.lib.vo.PurchaseVo; +import com.yunbao.common.utils.L; import java.util.ArrayList; public class SamsungUtil { - public void init(Context context) { - //初始化 - IapHelper iapHelper = IapHelper.getInstance(context); + private Context mContext; - //设置支付模式 OPERATION_MODE_TEST 测试模式 + IapHelper iapHelper; + + private static SamsungUtil samsungUtil; + + public static SamsungUtil newInstance(Context context) { + if (samsungUtil == null) { + samsungUtil = new SamsungUtil(context); + } + return samsungUtil; + } + + public SamsungUtil(Context mContext) { + this.mContext = mContext; + } + + /** + * 初始化 + */ + public void init() { + iapHelper = IapHelper.getInstance(mContext); + //设置支付模式 OPERATION_MODE_PRODUCTION 正式模式 OPERATION_MODE_TEST 测试模式 iapHelper.setOperationMode(HelperDefine.OperationMode.OPERATION_MODE_TEST); + } + /** + * 购买 + * + * @param skuId + */ + public void buy(String skuId) { + //购买 + iapHelper.startPayment(skuId, "", new OnPaymentListener() { + @Override + public void onPayment(ErrorVo _errorVO, PurchaseVo _purchaseVO) { + L.e(_errorVO.getErrorString()); + } + }); + } + + /** + * 消耗指定商品 + * + * @param skuId + */ + public void consume(String skuId) { + //消耗 + iapHelper.consumePurchasedItems(skuId, new OnConsumePurchasedItemsListener() { + @Override + public void onConsumePurchasedItems(ErrorVo _errorVO, ArrayList _consumeList) { + + } + }); + } + + /** + * 消耗所有未消耗的消耗品 + */ + public void query() { //查询商品 PRODUCT_TYPE_ITEM 消耗品&非消耗品 iapHelper.getOwnedList(HelperDefine.PRODUCT_TYPE_ITEM, new OnGetOwnedListListener() { @Override @@ -33,6 +87,7 @@ public class SamsungUtil { for (OwnedProductVo item : _ownedList) { if (item.getIsConsumable()) { // TODO: 消耗尚未消耗的消耗品 + consume(item.getPurchaseId()); } } } @@ -42,21 +97,5 @@ public class SamsungUtil { } } }); - - //购买 - iapHelper.startPayment("zs640", "", new OnPaymentListener() { - @Override - public void onPayment(ErrorVo _errorVO, PurchaseVo _purchaseVO) { - - } - }); - - //消耗 - iapHelper.consumePurchasedItems("zs640", new OnConsumePurchasedItemsListener() { - @Override - public void onConsumePurchasedItems(ErrorVo _errorVO, ArrayList _consumeList) { - - } - }); } } diff --git a/common/src/main/java/com/yunbao/common/utils/GoogleUtils.java b/common/src/main/java/com/yunbao/common/utils/GoogleUtils.java index d1e89d8a7..dca1733c3 100644 --- a/common/src/main/java/com/yunbao/common/utils/GoogleUtils.java +++ b/common/src/main/java/com/yunbao/common/utils/GoogleUtils.java @@ -34,7 +34,6 @@ public class GoogleUtils { this.mContext = mContext; } - public static GoogleUtils newInstance(Context mContext) { if (googleUtils == null) { googleUtils = new GoogleUtils(mContext); @@ -43,6 +42,18 @@ public class GoogleUtils { } + public boolean getGoogleService() { + boolean flag; + try { + Class clz = mActivity.getClassLoader().loadClass("com.shayu.lib_google.utils.GoogleBillingManage"); + googlePay = clz.getConstructor(Activity.class).newInstance(mActivity); + flag = (boolean) googlePay.getClass().getMethod("getGoogleService").invoke(googlePay); + } catch (Exception e) { + throw new RuntimeException(e); + } + return flag; + } + public static GoogleUtils newInstance(Activity mContext) { if (googleUtils == null) { googleUtils = new GoogleUtils(mContext); diff --git a/common/src/main/java/com/yunbao/common/views/InteractionGamesChildViewHolder.java b/common/src/main/java/com/yunbao/common/views/InteractionGamesChildViewHolder.java index 8d1dde931..c989802b0 100644 --- a/common/src/main/java/com/yunbao/common/views/InteractionGamesChildViewHolder.java +++ b/common/src/main/java/com/yunbao/common/views/InteractionGamesChildViewHolder.java @@ -34,7 +34,7 @@ public class InteractionGamesChildViewHolder extends RecyclerView.ViewHolder { funGameName.setText(model.getTitle()); - if (!TextUtils.isEmpty(model.getSudGameIsNew())||TextUtils.equals(model.getSudGameIsNew(),"1")){ + if (!TextUtils.isEmpty(model.getSudGameIsNew())&&TextUtils.equals(model.getSudGameIsNew(),"1")){ itemView.findViewById(R.id.icon_new_game).setVisibility(View.VISIBLE); }else { itemView.findViewById(R.id.icon_new_game).setVisibility(View.GONE); diff --git a/common/src/main/res/values-en-rUS/string.xml b/common/src/main/res/values-en-rUS/string.xml index 56358e6b1..2bab89497 100644 --- a/common/src/main/res/values-en-rUS/string.xml +++ b/common/src/main/res/values-en-rUS/string.xml @@ -1390,8 +1390,8 @@ Limited ride And limited avatar frame Exchange quantity: Need %s Exchange&Usage Rules: - ·One star coin can be exchanged for one ticket. You can customize the exchange quantity according to your needs. Once the ticket is exchanged, it cannot be revoked. Please confirm in advance; - ·One ticket can be used to watch one episode of a short drama. After successful redemption, you can return to the viewing page and use the ticket to continue watching the movie; - ·Ticket prohibit illegal activities such as offline trading and acquisitions, and PDLIVE will crack down severely on various profit-making trading activities. + 1.One star coin can be exchanged for one ticket. You can customize the exchange quantity according to your needs. Once the ticket is exchanged, it cannot be revoked. Please confirm in advance; + 2.One ticket can be used to watch one episode of a short drama. After successful redemption, you can return to the viewing page and use the ticket to continue watching the movie; + 3.Ticket prohibit illegal activities such as offline trading and acquisitions, and PDLIVE will crack down severely on various profit-making trading activities. diff --git a/common/src/main/res/values-zh-rHK/strings.xml b/common/src/main/res/values-zh-rHK/strings.xml index 1c9c00ff1..20f17754b 100644 --- a/common/src/main/res/values-zh-rHK/strings.xml +++ b/common/src/main/res/values-zh-rHK/strings.xml @@ -1387,7 +1387,7 @@ 兌換數量: 需要 %s 兌換&使用規則: - ·1星幣兌換1張觀影券,您可以根據需求自定義兌換數量,觀影券一經兌換不可撤銷,請提前確認; - ·1張觀影券可觀看一集短劇,兌換成功後即可返回觀影頁面,使用觀影券繼續觀看影片; - ·觀影券禁止線下交易、收購等不正當行為,PDLIVE將對各類以盈利為目的的交易行為進行嚴厲 打擊。 + 1.1星幣兌換1張觀影券,您可以根據需求自定義兌換數量,觀影券一經兌換不可撤銷,請提前確認; + 2.1張觀影券可觀看一集短劇,兌換成功後即可返回觀影頁面,使用觀影券繼續觀看影片; + 3.觀影券禁止線下交易、收購等不正當行為,PDLIVE將對各類以盈利為目的的交易行為進行嚴厲打擊。 diff --git a/common/src/main/res/values-zh-rTW/strings.xml b/common/src/main/res/values-zh-rTW/strings.xml index 99a35ce6f..f14c42b6d 100644 --- a/common/src/main/res/values-zh-rTW/strings.xml +++ b/common/src/main/res/values-zh-rTW/strings.xml @@ -1386,7 +1386,7 @@ 兌換數量: 需要 %s 兌換&使用規則: - ·1星幣兌換1張觀影券,您可以根據需求自定義兌換數量,觀影券一經兌換不可撤銷,請提前確認; - ·1張觀影券可觀看一集短劇,兌換成功後即可返回觀影頁面,使用觀影券繼續觀看影片; - ·觀影券禁止線下交易、收購等不正當行為,PDLIVE將對各類以盈利為目的的交易行為進行嚴厲 打擊。 + 1.1星幣兌換1張觀影券,您可以根據需求自定義兌換數量,觀影券一經兌換不可撤銷,請提前確認; + 2.1張觀影券可觀看一集短劇,兌換成功後即可返回觀影頁面,使用觀影券繼續觀看影片; + 3.觀影券禁止線下交易、收購等不正當行為,PDLIVE將對各類以盈利為目的的交易行為進行嚴厲打擊。 diff --git a/common/src/main/res/values-zh/strings.xml b/common/src/main/res/values-zh/strings.xml index 9bcf8c8e3..68ced0bf7 100644 --- a/common/src/main/res/values-zh/strings.xml +++ b/common/src/main/res/values-zh/strings.xml @@ -1386,8 +1386,8 @@ 兌換數量: 需要 %s 兌換&使用規則: - ·1星幣兌換1張觀影券,您可以根據需求自定義兌換數量,觀影券一經兌換不可撤銷,請提前確認; - ·1張觀影券可觀看一集短劇,兌換成功後即可返回觀影頁面,使用觀影券繼續觀看影片; - ·觀影券禁止線下交易、收購等不正當行為,PDLIVE將對各類以盈利為目的的交易行為進行嚴厲打擊。 + 1.1星幣兌換1張觀影券,您可以根據需求自定義兌換數量,觀影券一經兌換不可撤銷,請提前確認; + 2.1張觀影券可觀看一集短劇,兌換成功後即可返回觀影頁面,使用觀影券繼續觀看影片; + 3.觀影券禁止線下交易、收購等不正當行為,PDLIVE將對各類以盈利為目的的交易行為進行嚴厲打擊。 diff --git a/common/src/main/res/values/strings.xml b/common/src/main/res/values/strings.xml index 9b648b88d..b8c3434d1 100644 --- a/common/src/main/res/values/strings.xml +++ b/common/src/main/res/values/strings.xml @@ -1393,7 +1393,7 @@ Limited ride And limited avatar frame Exchange quantity: Need %s Exchange&Usage Rules: - ·One star coin can be exchanged for one ticket. You can customize the exchange quantity according to your needs. Once the ticket is exchanged, it cannot be revoked. Please confirm in advance; - ·One ticket can be used to watch one episode of a short drama. After successful redemption, you can return to the viewing page and use the ticket to continue watching the movie; - ·Ticket prohibit illegal activities such as offline trading and acquisitions, and PDLIVE will crack down severely on various profit-making trading activities. + 1.One star coin can be exchanged for one ticket. You can customize the exchange quantity according to your needs. Once the ticket is exchanged, it cannot be revoked. Please confirm in advance; + 2.One ticket can be used to watch one episode of a short drama. After successful redemption, you can return to the viewing page and use the ticket to continue watching the movie; + 3.Ticket prohibit illegal activities such as offline trading and acquisitions, and PDLIVE will crack down severely on various profit-making trading activities. diff --git a/config.gradle b/config.gradle index e5bb387c3..c50fd5d5f 100644 --- a/config.gradle +++ b/config.gradle @@ -19,11 +19,11 @@ ext { baiduAppKey : "zgCgFhUKEOV7I3ZXDFpTfnRB", baiduAppSecretKey: "nEVSgmuGpU0pjPr6VleEGGAl0hzGW52S", -// true表示谷歌支付 false 0 链接包 1 谷歌包 2华为包 - isGooglePlay : 1, +// true表示谷歌支付 false 0 链接包 1 谷歌包 2华为包 3 三星包 + isGooglePlay : 3, //是否上报异常日志 isUploadLog : true, //是否打包成插件包模式 - isPluginModel : true, + isPluginModel : false, ] } diff --git a/lib_google/src/main/java/com/shayu/lib_google/utils/GoogleBillingManage.java b/lib_google/src/main/java/com/shayu/lib_google/utils/GoogleBillingManage.java index dfd43d032..3dcc293ff 100644 --- a/lib_google/src/main/java/com/shayu/lib_google/utils/GoogleBillingManage.java +++ b/lib_google/src/main/java/com/shayu/lib_google/utils/GoogleBillingManage.java @@ -20,6 +20,7 @@ import com.android.billingclient.api.SkuDetails; import com.android.billingclient.api.SkuDetailsParams; import com.android.billingclient.api.SkuDetailsResponseListener; import com.google.android.gms.ads.identifier.AdvertisingIdClient; +import com.google.android.gms.common.GoogleApiAvailability; import com.google.android.gms.common.GooglePlayServicesNotAvailableException; import com.google.android.gms.common.GooglePlayServicesRepairableException; @@ -119,6 +120,11 @@ public class GoogleBillingManage implements PurchasesUpdatedListener { } } + public boolean getGoogleService() { + int code = GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(mContext); + return code == 0; + } + int querySize = -1; JSONArray tokenList = new JSONArray(); JSONArray orderList = new JSONArray(); diff --git a/live/src/main/java/com/yunbao/live/activity/LiveAudienceActivity.java b/live/src/main/java/com/yunbao/live/activity/LiveAudienceActivity.java index d7c139793..4084f182c 100644 --- a/live/src/main/java/com/yunbao/live/activity/LiveAudienceActivity.java +++ b/live/src/main/java/com/yunbao/live/activity/LiveAudienceActivity.java @@ -1874,6 +1874,7 @@ public class LiveAudienceActivity extends LiveActivity { if (manager == null || manager.mLiveAudienceViewHolder == null || manager.mLiveAudienceViewHolder.mRedPointPrivilege == null) { return; } + manager.mLiveAudienceViewHolder.setShowCrownRed(isShow); if (isShow) { manager.mLiveAudienceViewHolder.mRedPointPrivilege.setVisibility(View.VISIBLE); } else { diff --git a/live/src/main/java/com/yunbao/live/views/LiveAudienceViewHolder.java b/live/src/main/java/com/yunbao/live/views/LiveAudienceViewHolder.java index 176e4a70f..12ab63efc 100644 --- a/live/src/main/java/com/yunbao/live/views/LiveAudienceViewHolder.java +++ b/live/src/main/java/com/yunbao/live/views/LiveAudienceViewHolder.java @@ -364,7 +364,7 @@ public class LiveAudienceViewHolder extends AbsLiveViewHolder { } mQuickGiftRemainingQuantity = mQuickGiftRemainingQuantity - 1; quick_gift_remaining_quantity.setText(String.valueOf(mQuickGiftRemainingQuantity)); - MobclickAgent.onEvent(mContext, "small_pd_gifts", "连点"+quickGiftingIndex); + MobclickAgent.onEvent(mContext, "small_pd_gifts", "连点" + quickGiftingIndex); } } }); @@ -401,7 +401,7 @@ public class LiveAudienceViewHolder extends AbsLiveViewHolder { if (!(quickGiftContDown > 0 && quickGiftContDown < 120)) { quickGiftHandler.postDelayed(quickGiftRunnable, 1000); } - }else { + } else { circleProgress.setCurrent(2); time_text.setVisibility(View.GONE); } @@ -720,6 +720,12 @@ public class LiveAudienceViewHolder extends AbsLiveViewHolder { liveHDDialogFragment.show(((LiveAudienceActivity) mContext).getSupportFragmentManager(), "LiveHDDialogFragment"); } + private boolean mIsShow; + + public void setShowCrownRed(boolean isShow) { + mIsShow = isShow; + } + /** * 身份特权 */ @@ -732,7 +738,7 @@ public class LiveAudienceViewHolder extends AbsLiveViewHolder { // fragment.show(((LiveAudienceActivity) mContext).getSupportFragmentManager(), "LiveRoleDialogFragment"); new XPopup.Builder(mContext) .enableDrag(false) - .asCustom(new LiveNewRolePopup(mContext, mRedPointPrivilege.getVisibility() == View.VISIBLE)) + .asCustom(new LiveNewRolePopup(mContext, mIsShow)) .show(); mRedPointPrivilege.setVisibility(View.GONE); } diff --git a/live/src/main/java/com/yunbao/live/views/LiveRoomViewHolder.java b/live/src/main/java/com/yunbao/live/views/LiveRoomViewHolder.java index 96c65ea14..61f54a739 100644 --- a/live/src/main/java/com/yunbao/live/views/LiveRoomViewHolder.java +++ b/live/src/main/java/com/yunbao/live/views/LiveRoomViewHolder.java @@ -714,6 +714,7 @@ public class LiveRoomViewHolder extends AbsViewHolder implements View.OnClickLis combo_layout.setVisibility(View.GONE); if (IMLoginManager.get(mContext).getQuickGiftIfFirst()) { quick_gift_reminder.setVisibility(View.VISIBLE); + IMLoginManager.get(mContext).setQuickGiftIfFirst(); } else { quick_gift_reminder.setVisibility(View.GONE); } diff --git a/live/src/main/res/layout/view_live_audience.xml b/live/src/main/res/layout/view_live_audience.xml index 2309da2b0..37024e358 100644 --- a/live/src/main/res/layout/view_live_audience.xml +++ b/live/src/main/res/layout/view_live_audience.xml @@ -454,8 +454,8 @@ INTERVAL_TIME) { + mProductId = ProductId; + mOrderid = OrderNumber; + MoneyUsds = MoneyUsd; + + SamsungUtil.newInstance(getActivity()).buy(mProductId); + } + lastClickTime = currentTime; + + Log.e(TAG, "ProductId" + ProductId + "OrderNumber" + OrderNumber + "MoneyUsd" + MoneyUsd); + } + + @JavascriptInterface + public void androidMethodBack() { + getActivity().onBackPressed(); + + } + + @JavascriptInterface + public void androidGoBack() { + getActivity().onBackPressed(); + } + } + + + public void release() { + + } +} + diff --git a/main/src/main/res/layout/view_main_home_live.xml b/main/src/main/res/layout/view_main_home_live.xml index a8350a20c..c98693050 100644 --- a/main/src/main/res/layout/view_main_home_live.xml +++ b/main/src/main/res/layout/view_main_home_live.xml @@ -1,6 +1,5 @@ @@ -9,14 +8,15 @@ android:id="@+id/classRecyclerView_top" android:layout_width="match_parent" android:layout_height="wrap_content" - android:overScrollMode="never"/> + android:overScrollMode="never" /> + android:layout_marginRight="10dp" + android:layout_marginBottom="55dp" /> \ No newline at end of file diff --git a/main/src/main/res/layout/view_search_results_item.xml b/main/src/main/res/layout/view_search_results_item.xml index aab38cf7e..48e508b79 100644 --- a/main/src/main/res/layout/view_search_results_item.xml +++ b/main/src/main/res/layout/view_search_results_item.xml @@ -76,9 +76,9 @@