1/*
2 * Copyright (c) 2018, Daniel Gultsch All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without modification,
5 * are permitted provided that the following conditions are met:
6 *
7 * 1. Redistributions of source code must retain the above copyright notice, this
8 * list of conditions and the following disclaimer.
9 *
10 * 2. Redistributions in binary form must reproduce the above copyright notice,
11 * this list of conditions and the following disclaimer in the documentation and/or
12 * other materials provided with the distribution.
13 *
14 * 3. Neither the name of the copyright holder nor the names of its contributors
15 * may be used to endorse or promote products derived from this software without
16 * specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
19 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
22 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
24 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
25 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30package eu.siacs.conversations.ui;
31
32import android.content.Intent;
33import android.graphics.Bitmap;
34import android.graphics.drawable.BitmapDrawable;
35import android.graphics.drawable.Drawable;
36import android.net.Uri;
37import android.os.Bundle;
38import android.util.Log;
39import android.view.View;
40import android.widget.Toast;
41
42import androidx.annotation.StringRes;
43import androidx.databinding.DataBindingUtil;
44
45import com.theartofdev.edmodo.cropper.CropImage;
46
47import eu.siacs.conversations.Config;
48import eu.siacs.conversations.R;
49import eu.siacs.conversations.databinding.ActivityPublishProfilePictureBinding;
50import eu.siacs.conversations.entities.Conversation;
51import eu.siacs.conversations.ui.interfaces.OnAvatarPublication;
52import eu.siacs.conversations.ui.util.PendingItem;
53
54import static eu.siacs.conversations.ui.PublishProfilePictureActivity.REQUEST_CHOOSE_PICTURE;
55
56public class PublishGroupChatProfilePictureActivity extends XmppActivity implements OnAvatarPublication {
57 private final PendingItem<String> pendingConversationUuid = new PendingItem<>();
58 private ActivityPublishProfilePictureBinding binding;
59 private Conversation conversation;
60 private Uri uri;
61
62 @Override
63 protected void refreshUiReal() {
64
65 }
66
67 @Override
68 void onBackendConnected() {
69 String uuid = pendingConversationUuid.pop();
70 if (uuid != null) {
71 this.conversation = xmppConnectionService.findConversationByUuid(uuid);
72 }
73 if (this.conversation == null) {
74 return;
75 }
76 reloadAvatar();
77 }
78
79 private void reloadAvatar() {
80 final int size = (int) getResources().getDimension(R.dimen.publish_avatar_size);
81 Drawable bitmap;
82 if (uri == null) {
83 bitmap = xmppConnectionService.getAvatarService().get(conversation, size);
84 } else {
85 Log.d(Config.LOGTAG, "loading " + uri.toString() + " into preview");
86 bitmap = new BitmapDrawable(xmppConnectionService.getFileBackend().cropCenterSquare(uri, size));
87 }
88 this.binding.accountImage.setImageDrawable(bitmap);
89 this.binding.publishButton.setEnabled(uri != null);
90 }
91
92 @Override
93 public void onCreate(Bundle savedInstanceState) {
94 super.onCreate(savedInstanceState);
95 this.binding = DataBindingUtil.setContentView(this, R.layout.activity_publish_profile_picture);
96 setSupportActionBar(this.binding.toolbar);
97 configureActionBar(getSupportActionBar());
98 this.binding.cancelButton.setOnClickListener((v) -> this.finish());
99 this.binding.secondaryHint.setVisibility(View.GONE);
100 this.binding.accountImage.setOnClickListener((v) -> PublishProfilePictureActivity.chooseAvatar(this));
101 Intent intent = getIntent();
102 String uuid = intent == null ? null : intent.getStringExtra("uuid");
103 if (uuid != null) {
104 pendingConversationUuid.push(uuid);
105 }
106 this.binding.publishButton.setEnabled(uri != null);
107 this.binding.publishButton.setOnClickListener(this::publish);
108 }
109
110
111 private void publish(View view) {
112 binding.publishButton.setText(R.string.publishing);
113 binding.publishButton.setEnabled(false);
114 xmppConnectionService.publishMucAvatar(conversation, uri, this);
115 }
116
117 @Override
118 public void onActivityResult(int requestCode, int resultCode, Intent data) {
119 if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE) {
120 final CropImage.ActivityResult result = CropImage.getActivityResult(data);
121 if (resultCode == RESULT_OK) {
122 this.uri = result.getUri();
123 if (xmppConnectionServiceBound) {
124 reloadAvatar();
125 }
126 } else if (resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE) {
127 Exception error = result.getError();
128 if (error != null) {
129 Toast.makeText(this, error.getMessage(), Toast.LENGTH_SHORT).show();
130 }
131 }
132 } else if (requestCode == REQUEST_CHOOSE_PICTURE) {
133 if (resultCode == RESULT_OK) {
134 PublishProfilePictureActivity.cropUri(this, data.getData());
135 }
136 }
137 }
138
139 @Override
140 public void onAvatarPublicationSucceeded() {
141 runOnUiThread(() -> {
142 Toast.makeText(this, R.string.avatar_has_been_published, Toast.LENGTH_SHORT).show();
143 finish();
144 });
145 }
146
147 @Override
148 public void onAvatarPublicationFailed(@StringRes int res) {
149 runOnUiThread(() -> {
150 Toast.makeText(this, res, Toast.LENGTH_SHORT).show();
151 this.binding.publishButton.setText(R.string.publish);
152 this.binding.publishButton.setEnabled(true);
153 });
154 }
155}