import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
-import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
-import android.widget.Toast;
import com.owncloud.android.R;
import com.owncloud.android.datamodel.FileDataStorageManager;
import com.owncloud.android.datamodel.OCFile;
import com.owncloud.android.datamodel.ThumbnailsCacheManager;
-import com.owncloud.android.lib.common.operations.RemoteOperationResult;
+import com.owncloud.android.lib.common.utils.Log_OC;
import com.owncloud.android.lib.resources.shares.OCShare;
-import com.owncloud.android.lib.resources.shares.ShareType;
-import com.owncloud.android.ui.activity.ShareActivity;
+import com.owncloud.android.ui.activity.FileActivity;
import com.owncloud.android.ui.adapter.ShareUserListAdapter;
import com.owncloud.android.utils.DisplayUtils;
-import com.owncloud.android.utils.GetShareWithUserAsyncTask;
import com.owncloud.android.utils.MimetypeIconUtil;
import java.util.ArrayList;
* Use the {@link ShareFileFragment#newInstance} factory method to
* create an instance of this fragment.
*/
-public class ShareFileFragment extends Fragment
- implements GetShareWithUserAsyncTask.OnGetSharesWithUserTaskListener, View.OnTouchListener {
+public class ShareFileFragment extends Fragment {
+
private static final String TAG = ShareFileFragment.class.getSimpleName();
// the fragment initialization parameters
/**
* Public factory method to create new ShareFileFragment instances.
*
- * @param fileToShare An {@link OCFile} to show in the fragment
- * @param account An ownCloud account
+ * @param fileToShare An {@link OCFile} to show in the fragment
+ * @param account An ownCloud account
* @return A new instance of fragment ShareFileFragment.
*/
- public static ShareFileFragment newInstance(OCFile fileToShare, Account account) {
+ public static ShareFileFragment newInstance(OCFile fileToShare, Account account) {
ShareFileFragment fragment = new ShareFileFragment();
Bundle args = new Bundle();
args.putParcelable(ARG_FILE, fileToShare);
if (mFile.isImage()) {
String remoteId = String.valueOf(mFile.getRemoteId());
Bitmap thumbnail = ThumbnailsCacheManager.getBitmapFromDiskCache(remoteId);
- if (thumbnail != null){
+ if (thumbnail != null) {
icon.setImageBitmap(thumbnail);
}
}
filename.setText(mFile.getFileName());
// Size
TextView size = (TextView) view.findViewById(R.id.shareFileSize);
- if (mFile.isFolder()){
+ if (mFile.isFolder()) {
size.setVisibility(View.GONE);
} else {
size.setText(DisplayUtils.bytesToHumanReadable(mFile.getFileLength()));
}
- // List of share with users
- TextView noShares = (TextView) view.findViewById(R.id.shareNoUsers);
-
- // TODO: Get shares from DB and show
-
-
// Add User Button
Button addUserGroupButton = (Button)
view.findViewById(R.id.addUserButton);
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
- getShares();
+ refreshUsersOrGroupsList();
}
// TODO: Rename method, update argument and hook method into UI event
}
// Get users and groups to fill the "share with" list
- private void getShares(){
+ public void refreshUsersOrGroupsList(){
mShares = new ArrayList<>();
// Get Users and Groups
FileDataStorageManager fileDataStorageManager =
new FileDataStorageManager(mAccount, getActivity().getContentResolver());
- mShares = fileDataStorageManager.getSharesWithForAFile(mFile.getRemotePath(), mAccount.name);
+ mShares = fileDataStorageManager.getSharesWithForAFile(mFile.getRemotePath(),
+ mAccount.name);
// Update list of users/groups
updateListOfUserGroups();
}
- @Override
- public void onGetDataShareWithFinish(RemoteOperationResult result) {
- // Remove loading
- ((ShareActivity) getActivity()).dismissWaitingLoadDialog();
- if (result != null && result.isSuccess()) {
- // update local database
- for(Object obj: result.getData()) {
- if ( ((OCShare) obj).getShareType() == ShareType.USER ||
- ((OCShare) obj).getShareType() == ShareType.GROUP ){
- mShares.add((OCShare) obj);
- }
- }
-
- // Update list of users/groups
- updateListOfUserGroups();
-
- } else {
- Toast.makeText(getActivity(), result.getLogMessage(), Toast.LENGTH_SHORT).show();
- }
-
- }
-
- private void updateListOfUserGroups(){
+ private void updateListOfUserGroups() {
// Update list of users/groups
mUserGroupsAdapter = new ShareUserListAdapter(getActivity().getApplicationContext(),
R.layout.share_user_item, mShares);
private void registerLongClickListener(final ListView listView) {
listView.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
@Override
- public boolean onItemLongClick(AdapterView<?> parent, View view, int position,
+ public boolean onItemLongClick(AdapterView<?> parent, View view, final int position,
long id) {
// Show unshare button
ImageView unshareButton = (ImageView) view.findViewById(R.id.unshareButton);
if (unshareButton.getVisibility() == View.GONE) {
unshareButton.setVisibility(View.VISIBLE);
+ unshareButton.setOnClickListener(new View.OnClickListener() {
+ @Override
+ public void onClick(View v) {
+ // Unshare
+ unshareWith(mShares.get(position));
+ Log_OC.d(TAG, "Unshare - " +
+ mShares.get(position).getSharedWithDisplayName());
+ }
+ });
+
} else {
unshareButton.setVisibility(View.GONE);
}
+ view.setAlpha(0);
+ view.animate().alpha(1).setDuration(500).start();
return false;
}
});
}
- @Override
- public boolean onTouch(View v, MotionEvent event) {
- return false;
+ // Call to Unshare operation
+ private void unshareWith(OCShare share){
+ OCFile file = ((FileActivity) getActivity()).getFile();
+
+ ((FileActivity) getActivity()).getFileOperationsHelper().
+ unshareFileWithUserOrGroup(
+ file, share.getShareType(), share.getShareWith()
+ );
}