]> git.ktnx.net Git - mobile-ledger.git/blob - app/src/main/java/net/ktnx/mobileledger/ui/profiles/ProfileDetailActivity.java
fix crash when profile has no value yet
[mobile-ledger.git] / app / src / main / java / net / ktnx / mobileledger / ui / profiles / ProfileDetailActivity.java
1 /*
2  * Copyright © 2019 Damyan Ivanov.
3  * This file is part of MoLe.
4  * MoLe is free software: you can distribute it and/or modify it
5  * under the term of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your opinion), any later version.
8  *
9  * MoLe is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License terms for details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with MoLe. If not, see <https://www.gnu.org/licenses/>.
16  */
17
18 package net.ktnx.mobileledger.ui.profiles;
19
20 import android.content.Intent;
21 import android.os.Bundle;
22 import android.support.design.widget.FloatingActionButton;
23 import android.support.design.widget.Snackbar;
24 import android.support.v7.app.ActionBar;
25 import android.support.v7.app.AppCompatActivity;
26 import android.support.v7.widget.Toolbar;
27 import android.util.Log;
28 import android.view.Menu;
29 import android.view.MenuItem;
30 import android.view.View;
31
32 import net.ktnx.mobileledger.R;
33 import net.ktnx.mobileledger.model.Data;
34 import net.ktnx.mobileledger.model.MobileLedgerProfile;
35 import net.ktnx.mobileledger.ui.activity.ProfileListActivity;
36
37 /**
38  * An activity representing a single Profile detail screen. This
39  * activity is only used on narrow width devices. On tablet-size devices,
40  * item details are presented side-by-side with a list of items
41  * in a {@link ProfileListActivity}.
42  */
43 public class ProfileDetailActivity extends AppCompatActivity {
44     private MobileLedgerProfile profile;
45     @Override
46     protected void onCreate(Bundle savedInstanceState) {
47         super.onCreate(savedInstanceState);
48         setContentView(R.layout.activity_profile_detail);
49         Toolbar toolbar = findViewById(R.id.detail_toolbar);
50         setSupportActionBar(toolbar);
51
52         FloatingActionButton fab = findViewById(R.id.fab);
53         fab.setOnClickListener(new View.OnClickListener() {
54             @Override
55             public void onClick(View view) {
56                 Snackbar.make(view, "Replace with your own detail action", Snackbar.LENGTH_LONG)
57                         .setAction("Action", null).show();
58             }
59         });
60
61         // Show the Up button in the action bar.
62         ActionBar actionBar = getSupportActionBar();
63         if (actionBar != null) {
64             actionBar.setDisplayHomeAsUpEnabled(true);
65         }
66
67         // savedInstanceState is non-null when there is fragment state
68         // saved from previous configurations of this activity
69         // (e.g. when rotating the screen from portrait to landscape).
70         // In this case, the fragment will automatically be re-added
71         // to its container so we don't need to manually add it.
72         // For more information, see the Fragments API guide at:
73         //
74         // http://developer.android.com/guide/components/fragments.html
75         //
76         if (savedInstanceState == null) {
77             final int index = getIntent().getIntExtra(ProfileDetailFragment.ARG_ITEM_ID, -1);
78
79             if (index != -1) {
80                 profile = Data.profiles.get(index);
81                 if (profile == null) throw new AssertionError(
82                         String.format("Can't get profile " + "(index:%d) from the global list",
83                                 index));
84             }
85
86             // Create the detail fragment and add it to the activity
87             // using a fragment transaction.
88             Bundle arguments = new Bundle();
89             arguments.putInt(ProfileDetailFragment.ARG_ITEM_ID, index);
90             ProfileDetailFragment fragment = new ProfileDetailFragment();
91             fragment.setArguments(arguments);
92             getSupportFragmentManager().beginTransaction()
93                     .add(R.id.profile_detail_container, fragment).commit();
94         }
95     }
96     @Override
97     public boolean onCreateOptionsMenu(Menu menu) {
98         super.onCreateOptionsMenu(menu);
99         Log.d("profiles", "[activity] Creating profile details options menu");
100         getMenuInflater().inflate(R.menu.profile_details, menu);
101         MenuItem menuDeleteProfile = menu.findItem(R.id.menuDelete);
102         menuDeleteProfile.setOnMenuItemClickListener(item -> {
103             Log.d("profiles", String.format("[activity] deleting profile %s", profile.getUuid()));
104             profile.removeFromDB();
105             Data.profiles.remove(profile);
106             if (Data.profile.get().equals(profile)) {
107                 Log.d("profiles", "[activity] selecting profile 0");
108                 Data.setCurrentProfile(Data.profiles.get(0));
109             }
110             finish();
111             return true;
112         });
113
114         menuDeleteProfile.setVisible((profile != null) && (Data.profiles.size() > 1));
115
116         return true;
117     }
118
119     @Override
120     public boolean onOptionsItemSelected(MenuItem item) {
121         int id = item.getItemId();
122         if (id == android.R.id.home) {
123             // This ID represents the Home or Up button. In the case of this
124             // activity, the Up button is shown. For
125             // more details, see the Navigation pattern on Android Design:
126             //
127             // http://developer.android.com/design/patterns/navigation.html#up-vs-back
128             //
129             navigateUpTo(new Intent(this, ProfileListActivity.class));
130             return true;
131         }
132         return super.onOptionsItemSelected(item);
133     }
134 }