aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/pixart/messenger/ui/PublishGroupChatProfilePictureActivity.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/de/pixart/messenger/ui/PublishGroupChatProfilePictureActivity.java')
-rw-r--r--src/main/java/de/pixart/messenger/ui/PublishGroupChatProfilePictureActivity.java155
1 files changed, 155 insertions, 0 deletions
diff --git a/src/main/java/de/pixart/messenger/ui/PublishGroupChatProfilePictureActivity.java b/src/main/java/de/pixart/messenger/ui/PublishGroupChatProfilePictureActivity.java
new file mode 100644
index 000000000..a4bf6b440
--- /dev/null
+++ b/src/main/java/de/pixart/messenger/ui/PublishGroupChatProfilePictureActivity.java
@@ -0,0 +1,155 @@
+/*
+ * 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 de.pixart.messenger.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 de.pixart.messenger.Config;
+import de.pixart.messenger.R;
+import de.pixart.messenger.databinding.ActivityPublishProfilePictureBinding;
+import de.pixart.messenger.entities.Conversation;
+import de.pixart.messenger.ui.interfaces.OnAvatarPublication;
+import de.pixart.messenger.ui.util.PendingItem;
+
+public class PublishGroupChatProfilePictureActivity extends XmppActivity implements OnAvatarPublication {
+
+ private static final int REQUEST_CHOOSE_FILE = 0xac24;
+
+ private ActivityPublishProfilePictureBinding binding;
+
+ private final PendingItem<String> pendingConversationUuid = new PendingItem<>();
+
+ 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 = getPixel(Config.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) {
+ 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() {
+ finish();
+ }
+
+ @Override
+ public void onAvatarPublicationFailed(@StringRes int res) {
+ runOnUiThread(() -> {
+ Toast.makeText(this,res,Toast.LENGTH_SHORT).show();
+ this.binding.publishButton.setText(R.string.publish);
+ this.binding.publishButton.setEnabled(true);
+ });
+ }
+} \ No newline at end of file