2018-06-18 12:15:19 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018, Daniel Gultsch All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
|
|
* are permitted provided that the following conditions are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
|
|
|
* list of conditions and the following disclaimer.
|
|
|
|
*
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
* this list of conditions and the following disclaimer in the documentation and/or
|
|
|
|
* other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* 3. Neither the name of the copyright holder nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software without
|
|
|
|
* specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
|
|
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package eu.siacs.conversations.ui;
|
|
|
|
|
|
|
|
import android.content.Intent;
|
|
|
|
import android.databinding.DataBindingUtil;
|
|
|
|
import android.graphics.Bitmap;
|
|
|
|
import android.net.Uri;
|
|
|
|
import android.os.Bundle;
|
|
|
|
import android.support.annotation.StringRes;
|
|
|
|
import android.support.v7.widget.Toolbar;
|
|
|
|
import android.util.Log;
|
|
|
|
import android.view.View;
|
|
|
|
import android.widget.Toast;
|
|
|
|
|
|
|
|
import com.theartofdev.edmodo.cropper.CropImage;
|
|
|
|
|
|
|
|
import eu.siacs.conversations.Config;
|
|
|
|
import eu.siacs.conversations.R;
|
|
|
|
import eu.siacs.conversations.databinding.ActivityPublishProfilePictureBinding;
|
|
|
|
import eu.siacs.conversations.entities.Conversation;
|
|
|
|
import eu.siacs.conversations.ui.interfaces.OnAvatarPublication;
|
|
|
|
import eu.siacs.conversations.ui.util.PendingItem;
|
|
|
|
|
|
|
|
public class PublishGroupChatProfilePictureActivity extends XmppActivity implements OnAvatarPublication {
|
|
|
|
private final PendingItem<String> pendingConversationUuid = new PendingItem<>();
|
2018-06-18 15:32:48 +00:00
|
|
|
private ActivityPublishProfilePictureBinding binding;
|
2018-06-18 12:15:19 +00:00
|
|
|
private Conversation conversation;
|
|
|
|
private Uri uri;
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void refreshUiReal() {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
void onBackendConnected() {
|
|
|
|
String uuid = pendingConversationUuid.pop();
|
|
|
|
if (uuid != null) {
|
|
|
|
this.conversation = xmppConnectionService.findConversationByUuid(uuid);
|
|
|
|
}
|
|
|
|
if (this.conversation == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
reloadAvatar();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void reloadAvatar() {
|
|
|
|
final int size = (int) getResources().getDimension(R.dimen.publish_avatar_size);
|
|
|
|
Bitmap bitmap;
|
|
|
|
if (uri == null) {
|
|
|
|
bitmap = xmppConnectionService.getAvatarService().get(conversation, size);
|
|
|
|
} else {
|
|
|
|
Log.d(Config.LOGTAG, "loading " + uri.toString() + " into preview");
|
|
|
|
bitmap = xmppConnectionService.getFileBackend().cropCenterSquare(uri, size);
|
|
|
|
}
|
|
|
|
this.binding.accountImage.setImageBitmap(bitmap);
|
|
|
|
this.binding.publishButton.setEnabled(uri != null);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onCreate(Bundle savedInstanceState) {
|
|
|
|
super.onCreate(savedInstanceState);
|
|
|
|
this.binding = DataBindingUtil.setContentView(this, R.layout.activity_publish_profile_picture);
|
|
|
|
setSupportActionBar((Toolbar) this.binding.toolbar);
|
|
|
|
configureActionBar(getSupportActionBar());
|
|
|
|
this.binding.cancelButton.setOnClickListener((v) -> this.finish());
|
|
|
|
this.binding.secondaryHint.setVisibility(View.GONE);
|
|
|
|
this.binding.accountImage.setOnClickListener((v) -> this.chooseAvatar());
|
|
|
|
Intent intent = getIntent();
|
|
|
|
String uuid = intent == null ? null : intent.getStringExtra("uuid");
|
|
|
|
if (uuid != null) {
|
|
|
|
pendingConversationUuid.push(uuid);
|
|
|
|
}
|
|
|
|
this.binding.publishButton.setEnabled(uri != null);
|
|
|
|
this.binding.publishButton.setOnClickListener(this::publish);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void publish(View view) {
|
2018-06-18 15:32:48 +00:00
|
|
|
binding.publishButton.setText(R.string.publishing);
|
|
|
|
binding.publishButton.setEnabled(false);
|
2018-06-18 12:15:19 +00:00
|
|
|
xmppConnectionService.publishMucAvatar(conversation, uri, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
|
|
|
if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE) {
|
|
|
|
CropImage.ActivityResult result = CropImage.getActivityResult(data);
|
|
|
|
if (resultCode == RESULT_OK) {
|
|
|
|
this.uri = result.getUri();
|
|
|
|
if (xmppConnectionServiceBound) {
|
|
|
|
reloadAvatar();
|
|
|
|
}
|
|
|
|
} else if (resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE) {
|
|
|
|
Exception error = result.getError();
|
|
|
|
if (error != null) {
|
|
|
|
Toast.makeText(this, error.getMessage(), Toast.LENGTH_SHORT).show();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void chooseAvatar() {
|
|
|
|
CropImage.activity()
|
|
|
|
.setOutputCompressFormat(Bitmap.CompressFormat.PNG)
|
|
|
|
.setAspectRatio(1, 1)
|
|
|
|
.setMinCropResultSize(Config.AVATAR_SIZE, Config.AVATAR_SIZE)
|
|
|
|
.start(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onAvatarPublicationSucceeded() {
|
2018-06-18 15:32:48 +00:00
|
|
|
runOnUiThread(() -> {
|
|
|
|
Toast.makeText(this, R.string.avatar_has_been_published, Toast.LENGTH_SHORT).show();
|
|
|
|
finish();
|
|
|
|
});
|
2018-06-18 12:15:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onAvatarPublicationFailed(@StringRes int res) {
|
|
|
|
runOnUiThread(() -> {
|
2018-06-18 15:32:48 +00:00
|
|
|
Toast.makeText(this, res, Toast.LENGTH_SHORT).show();
|
2018-06-18 12:15:19 +00:00
|
|
|
this.binding.publishButton.setText(R.string.publish);
|
|
|
|
this.binding.publishButton.setEnabled(true);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|