Commit 92296cd5015b99e36beb1bb5bf073124fb021b6c
1 parent
15180ba7
Exists in
master
implementado os comentários em projetos
Showing
14 changed files
with
413 additions
and
143 deletions
Show diff stats
app/app.iml
... | ... | @@ -120,45 +120,45 @@ |
120 | 120 | </content> |
121 | 121 | <orderEntry type="jdk" jdkName="Android API 22 Platform" jdkType="Android SDK" /> |
122 | 122 | <orderEntry type="sourceFolder" forTests="false" /> |
123 | - <orderEntry type="library" exported="" name="design-22.2.0" level="project" /> | |
124 | - <orderEntry type="library" exported="" name="iconics-1.0.2" level="project" /> | |
125 | - <orderEntry type="library" exported="" name="play-services-base-7.5.0" level="project" /> | |
126 | - <orderEntry type="library" exported="" name="crashlytics-core-2.3.3" level="project" /> | |
127 | - <orderEntry type="library" exported="" name="Parse-1.9.2" level="project" /> | |
128 | - <orderEntry type="library" exported="" name="play-services-appinvite-7.5.0" level="project" /> | |
129 | - <orderEntry type="library" exported="" name="play-services-panorama-7.5.0" level="project" /> | |
123 | + <orderEntry type="library" exported="" name="play-services-wallet-7.5.0" level="project" /> | |
124 | + <orderEntry type="library" exported="" name="gson-2.3.1" level="project" /> | |
125 | + <orderEntry type="library" exported="" name="play-services-cast-7.5.0" level="project" /> | |
126 | + <orderEntry type="library" exported="" name="mediarouter-v7-22.0.0" level="project" /> | |
127 | + <orderEntry type="library" exported="" name="recyclerview-v7-22.2.0" level="project" /> | |
130 | 128 | <orderEntry type="library" exported="" name="play-services-drive-7.5.0" level="project" /> |
131 | - <orderEntry type="library" exported="" name="crashlytics-2.4.0" level="project" /> | |
132 | - <orderEntry type="library" exported="" name="answers-1.2.2" level="project" /> | |
133 | - <orderEntry type="library" exported="" name="play-services-gcm-7.5.0" level="project" /> | |
129 | + <orderEntry type="library" exported="" name="support-annotations-22.2.0" level="project" /> | |
130 | + <orderEntry type="library" exported="" name="play-services-analytics-7.5.0" level="project" /> | |
131 | + <orderEntry type="library" exported="" name="play-services-panorama-7.5.0" level="project" /> | |
132 | + <orderEntry type="library" exported="" name="materialdrawer-3.0.6" level="project" /> | |
133 | + <orderEntry type="library" exported="" name="appcompat-v7-22.2.0" level="project" /> | |
134 | 134 | <orderEntry type="library" exported="" name="play-services-appindexing-7.5.0" level="project" /> |
135 | - <orderEntry type="library" exported="" name="MPAndroidChart-v2.1.0" level="project" /> | |
136 | - <orderEntry type="library" exported="" name="play-services-wearable-7.5.0" level="project" /> | |
135 | + <orderEntry type="library" exported="" name="play-services-location-7.5.0" level="project" /> | |
136 | + <orderEntry type="library" exported="" name="Parse-1.9.2" level="project" /> | |
137 | + <orderEntry type="library" exported="" name="play-services-ads-7.5.0" level="project" /> | |
137 | 138 | <orderEntry type="library" exported="" name="play-services-safetynet-7.5.0" level="project" /> |
138 | - <orderEntry type="library" exported="" name="play-services-games-7.5.0" level="project" /> | |
139 | - <orderEntry type="library" exported="" name="universal-image-loader-1.9.3" level="project" /> | |
140 | - <orderEntry type="library" exported="" name="fabric-1.3.4" level="project" /> | |
141 | - <orderEntry type="library" exported="" name="play-services-plus-7.5.0" level="project" /> | |
142 | - <orderEntry type="library" exported="" name="play-services-maps-7.5.0" level="project" /> | |
143 | - <orderEntry type="library" exported="" name="play-services-fitness-7.5.0" level="project" /> | |
144 | - <orderEntry type="library" exported="" name="mediarouter-v7-22.0.0" level="project" /> | |
139 | + <orderEntry type="library" exported="" name="play-services-base-7.5.0" level="project" /> | |
145 | 140 | <orderEntry type="library" exported="" name="play-services-7.5.0" level="project" /> |
146 | - <orderEntry type="library" exported="" name="play-services-analytics-7.5.0" level="project" /> | |
147 | - <orderEntry type="library" exported="" name="play-services-wallet-7.5.0" level="project" /> | |
148 | - <orderEntry type="library" exported="" name="support-annotations-22.2.0" level="project" /> | |
149 | - <orderEntry type="library" exported="" name="play-services-identity-7.5.0" level="project" /> | |
141 | + <orderEntry type="library" exported="" name="play-services-gcm-7.5.0" level="project" /> | |
150 | 142 | <orderEntry type="library" exported="" name="bolts-android-1.2.0" level="project" /> |
151 | - <orderEntry type="library" exported="" name="materialdrawer-3.0.6" level="project" /> | |
152 | - <orderEntry type="library" exported="" name="recyclerview-v7-22.2.0" level="project" /> | |
153 | - <orderEntry type="library" exported="" name="cardview-v7-22.2.0" level="project" /> | |
154 | - <orderEntry type="library" exported="" name="gson-2.3.1" level="project" /> | |
155 | - <orderEntry type="library" exported="" name="play-services-appstate-7.5.0" level="project" /> | |
156 | - <orderEntry type="library" exported="" name="play-services-nearby-7.5.0" level="project" /> | |
143 | + <orderEntry type="library" exported="" name="play-services-appinvite-7.5.0" level="project" /> | |
144 | + <orderEntry type="library" exported="" name="iconics-1.0.2" level="project" /> | |
145 | + <orderEntry type="library" exported="" name="fabric-1.3.4" level="project" /> | |
157 | 146 | <orderEntry type="library" exported="" name="beta-1.1.3" level="project" /> |
158 | 147 | <orderEntry type="library" exported="" name="support-v4-22.2.0" level="project" /> |
159 | - <orderEntry type="library" exported="" name="play-services-cast-7.5.0" level="project" /> | |
160 | - <orderEntry type="library" exported="" name="appcompat-v7-22.2.0" level="project" /> | |
161 | - <orderEntry type="library" exported="" name="play-services-ads-7.5.0" level="project" /> | |
162 | - <orderEntry type="library" exported="" name="play-services-location-7.5.0" level="project" /> | |
148 | + <orderEntry type="library" exported="" name="universal-image-loader-1.9.3" level="project" /> | |
149 | + <orderEntry type="library" exported="" name="crashlytics-core-2.3.3" level="project" /> | |
150 | + <orderEntry type="library" exported="" name="play-services-fitness-7.5.0" level="project" /> | |
151 | + <orderEntry type="library" exported="" name="play-services-nearby-7.5.0" level="project" /> | |
152 | + <orderEntry type="library" exported="" name="crashlytics-2.4.0" level="project" /> | |
153 | + <orderEntry type="library" exported="" name="play-services-plus-7.5.0" level="project" /> | |
154 | + <orderEntry type="library" exported="" name="play-services-wearable-7.5.0" level="project" /> | |
155 | + <orderEntry type="library" exported="" name="play-services-appstate-7.5.0" level="project" /> | |
156 | + <orderEntry type="library" exported="" name="play-services-games-7.5.0" level="project" /> | |
157 | + <orderEntry type="library" exported="" name="play-services-identity-7.5.0" level="project" /> | |
158 | + <orderEntry type="library" exported="" name="MPAndroidChart-v2.1.0" level="project" /> | |
159 | + <orderEntry type="library" exported="" name="answers-1.2.2" level="project" /> | |
160 | + <orderEntry type="library" exported="" name="design-22.2.0" level="project" /> | |
161 | + <orderEntry type="library" exported="" name="play-services-maps-7.5.0" level="project" /> | |
162 | + <orderEntry type="library" exported="" name="cardview-v7-22.2.0" level="project" /> | |
163 | 163 | </component> |
164 | 164 | </module> |
165 | 165 | \ No newline at end of file | ... | ... |
app/build.gradle
... | ... | @@ -18,13 +18,14 @@ repositories { |
18 | 18 | android { |
19 | 19 | compileSdkVersion 22 |
20 | 20 | buildToolsVersion "23.0.0 rc2" |
21 | + compileOptions.encoding = 'ISO-8859-1' | |
21 | 22 | |
22 | 23 | defaultConfig { |
23 | 24 | applicationId "com.monitorabrasil.monitoramunicipio" |
24 | 25 | minSdkVersion 16 |
25 | 26 | targetSdkVersion 22 |
26 | - versionCode 4 | |
27 | - versionName "0.4" | |
27 | + versionCode 5 | |
28 | + versionName "0.5" | |
28 | 29 | } |
29 | 30 | buildTypes { |
30 | 31 | release { | ... | ... |
app/src/main/java/com/monitorabrasil/monitoralegislativo/ComentarioActivity.java
1 | 1 | package com.monitorabrasil.monitoralegislativo; |
2 | 2 | |
3 | +import android.content.Intent; | |
4 | +import android.os.Build; | |
5 | +import android.support.design.widget.Snackbar; | |
3 | 6 | import android.support.v7.app.ActionBarActivity; |
4 | 7 | import android.os.Bundle; |
8 | +import android.support.v7.app.AppCompatActivity; | |
9 | +import android.support.v7.widget.LinearLayoutManager; | |
10 | +import android.support.v7.widget.RecyclerView; | |
11 | +import android.support.v7.widget.Toolbar; | |
12 | +import android.transition.Transition; | |
13 | +import android.transition.TransitionInflater; | |
14 | +import android.util.Log; | |
5 | 15 | import android.view.Menu; |
6 | 16 | import android.view.MenuItem; |
17 | +import android.view.View; | |
18 | +import android.widget.Button; | |
19 | +import android.widget.EditText; | |
20 | +import android.widget.ProgressBar; | |
7 | 21 | |
22 | +import com.google.gson.Gson; | |
8 | 23 | import com.monitorabrasil.monitoralegislativo.R; |
24 | +import com.monitorabrasil.monitoralegislativo.adapters.ComentarioAdapter; | |
25 | +import com.monitorabrasil.monitoralegislativo.application.MyApp; | |
26 | +import com.parse.FindCallback; | |
27 | +import com.parse.GetCallback; | |
28 | +import com.parse.ParseException; | |
29 | +import com.parse.ParseObject; | |
30 | +import com.parse.ParseQuery; | |
31 | +import com.parse.ParseUser; | |
32 | +import com.parse.SaveCallback; | |
9 | 33 | |
10 | -public class ComentarioActivity extends ActionBarActivity { | |
34 | +import java.util.List; | |
35 | + | |
36 | +public class ComentarioActivity extends AppCompatActivity { | |
37 | + | |
38 | + private ParseObject projeto; | |
39 | + private Toolbar mToolbar; | |
40 | + private RecyclerView mRecyclerView; | |
41 | + private ComentarioAdapter mAdapter; | |
42 | + private List<ParseObject> ob; | |
43 | + private ProgressBar pb; | |
11 | 44 | |
12 | 45 | @Override |
13 | 46 | protected void onCreate(Bundle savedInstanceState) { |
14 | 47 | super.onCreate(savedInstanceState); |
15 | 48 | setContentView(R.layout.activity_comentario); |
49 | + Gson gson =new Gson(); | |
50 | + Intent bundle = getIntent(); | |
51 | + | |
52 | + ParseQuery<ParseObject> query = ParseQuery.getQuery("Projeto"); | |
53 | + query.getInBackground(getIntent().getStringExtra("projeto"), new GetCallback<ParseObject>() { | |
54 | + public void done(ParseObject object, ParseException e) { | |
55 | + if (e == null) { | |
56 | + projeto = object; | |
57 | + mToolbar.setTitle(projeto.get("classificacao").toString()); | |
58 | + buscaComentarios(); | |
59 | + } else { | |
60 | + // something went wrong | |
61 | + } | |
62 | + } | |
63 | + }); | |
64 | + | |
65 | + | |
66 | + // TOOLBAR | |
67 | + mToolbar = (Toolbar) findViewById(R.id.tb_main); | |
68 | + | |
69 | + //mToolbar.setSubtitle("just a subtitle"); | |
70 | + //mToolbar.setLogo(R.drawable.ic_launcher); | |
71 | + setSupportActionBar(mToolbar); | |
72 | + mToolbar.setTitleTextColor(getResources().getColor(R.color.md_white_1000)); | |
73 | + | |
74 | + if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP){ | |
75 | + //fazer a animacao | |
76 | + TransitionInflater inflater = TransitionInflater.from(this); | |
77 | + Transition transition = inflater.inflateTransition(R.transition.transitions); | |
78 | + | |
79 | + getWindow().setSharedElementEnterTransition(transition); | |
80 | + } | |
81 | + | |
82 | + //botao para enviar mensagem | |
83 | + Button btnEnviar = (Button)findViewById(R.id.btnEnviar); | |
84 | + btnEnviar.setOnClickListener(new View.OnClickListener() { | |
85 | + @Override | |
86 | + public void onClick(View v) { | |
87 | + enviarMensagem(v); | |
88 | + } | |
89 | + }); | |
90 | + | |
91 | + pb = (ProgressBar) findViewById(R.id.progressBar); | |
92 | + | |
93 | + | |
94 | + //tableview | |
95 | + mRecyclerView = (RecyclerView) findViewById(R.id.my_recycler_view); | |
96 | + | |
97 | + // use this setting to improve performance if you know that changes | |
98 | + // in content do not change the layout size of the RecyclerView | |
99 | + mRecyclerView.setHasFixedSize(true); | |
100 | + | |
101 | + LinearLayoutManager llm = new LinearLayoutManager(this); | |
102 | + llm.setOrientation(LinearLayoutManager.VERTICAL); | |
103 | + mRecyclerView.setLayoutManager(llm); | |
104 | + | |
105 | + | |
106 | + | |
107 | + } | |
108 | + | |
109 | + public void buscaComentarios(){ | |
110 | + pb.setVisibility(View.VISIBLE); | |
111 | + ParseQuery<ParseObject> query = ParseQuery.getQuery("Comentario"); | |
112 | + query.whereEqualTo("projeto",projeto); | |
113 | + query.addAscendingOrder("createdAt"); | |
114 | + //query.whereEqualTo("playerName", "Dan Stemkoski"); | |
115 | + query.findInBackground(new FindCallback<ParseObject>() { | |
116 | + @Override | |
117 | + public void done(List<ParseObject> list, com.parse.ParseException e) { | |
118 | + if (e == null) { | |
119 | + ob = list; | |
120 | + carregaList(list); | |
121 | + } else { | |
122 | + Log.d("score", "Error: " + e.getMessage()); | |
123 | + } | |
124 | + } | |
125 | + | |
126 | + | |
127 | + }); | |
128 | + } | |
129 | + public void carregaList(List<ParseObject> list){ | |
130 | + mAdapter = new ComentarioAdapter(list); | |
131 | + // mAdapter.setRecyclerViewOnClickListenerHack(this); | |
132 | + mRecyclerView.setAdapter(mAdapter); | |
133 | + pb.setVisibility(View.INVISIBLE); | |
134 | + } | |
135 | + | |
136 | + | |
137 | + private void enviarMensagem(final View v) { | |
138 | + final EditText txtMensagem = (EditText)findViewById(R.id.mensagem); | |
139 | + String mensagem = txtMensagem.getText().toString(); | |
140 | + ParseUser user = ParseUser.getCurrentUser(); | |
141 | + if(user!= null){ | |
142 | + ParseObject comentario = new ParseObject("Comentario"); | |
143 | + comentario.put("mensagem",mensagem); | |
144 | + comentario.put("user",user); | |
145 | + comentario.put("nome",user.getString("nome")); | |
146 | + comentario.put("projeto",projeto); | |
147 | + comentario.saveInBackground(new SaveCallback() { | |
148 | + @Override | |
149 | + public void done(ParseException e) { | |
150 | + Snackbar.make(v, "Comentário enviado", Snackbar.LENGTH_LONG) | |
151 | + .setAction("Action", null).show(); | |
152 | + | |
153 | + //recarregar lista | |
154 | + buscaComentarios(); | |
155 | + } | |
156 | + }); | |
157 | + projeto.increment("nr_comentarios"); | |
158 | + projeto.saveInBackground(); | |
159 | + | |
160 | + }else{ | |
161 | + Snackbar.make(v, "Para comentar é necessário estar logado", Snackbar.LENGTH_LONG) | |
162 | + .setAction("Action", null).show(); | |
163 | + return; | |
164 | + } | |
165 | + | |
166 | + txtMensagem.setText(""); | |
16 | 167 | } |
17 | 168 | |
18 | 169 | @Override | ... | ... |
app/src/main/java/com/monitorabrasil/monitoralegislativo/MainActivity.java
... | ... | @@ -67,8 +67,6 @@ public class MainActivity extends AppCompatActivity implements HomeFragment.OnFr |
67 | 67 | |
68 | 68 | |
69 | 69 | |
70 | - | |
71 | - | |
72 | 70 | @Override |
73 | 71 | protected void onCreate(Bundle savedInstanceState) { |
74 | 72 | super.onCreate(savedInstanceState); |
... | ... | @@ -95,11 +93,12 @@ public class MainActivity extends AppCompatActivity implements HomeFragment.OnFr |
95 | 93 | |
96 | 94 | // TOOLBAR |
97 | 95 | mToolbar = (Toolbar) findViewById(R.id.tb_main); |
98 | - mToolbar.setTitle("Monitora, Ouro Branco!"); | |
99 | - //mToolbar.setSubtitle("just a subtitle"); | |
96 | + mToolbar.setTitle(getString(R.string.app_name)); | |
97 | + mToolbar.setSubtitle("Ouro Branco - MG"); | |
100 | 98 | //mToolbar.setLogo(R.drawable.ic_launcher); |
101 | 99 | setSupportActionBar(mToolbar); |
102 | - mToolbar.setTitleTextColor(getResources().getColor(R.color.md_white_1000)); | |
100 | + mToolbar.setTitleTextColor(getResources().getColor(R.color.md_white_1000)); | |
101 | + mToolbar.setSubtitleTextColor(getResources().getColor(R.color.md_white_1000)); | |
103 | 102 | |
104 | 103 | /*getSupportActionBar().setDisplayHomeAsUpEnabled(true); |
105 | 104 | getSupportActionBar().setHomeButtonEnabled(false);*/ |
... | ... | @@ -173,7 +172,7 @@ public class MainActivity extends AppCompatActivity implements HomeFragment.OnFr |
173 | 172 | |
174 | 173 | } else { |
175 | 174 | headerNavigationLeft.addProfiles( |
176 | - new ProfileDrawerItem().withName("Faça seu cadastro")); | |
175 | + new ProfileDrawerItem().withName("Faça seu cadastro")); | |
177 | 176 | } |
178 | 177 | |
179 | 178 | navigationDrawerLeft = new DrawerBuilder() |
... | ... | @@ -190,7 +189,7 @@ public class MainActivity extends AppCompatActivity implements HomeFragment.OnFr |
190 | 189 | new DividerDrawerItem(), |
191 | 190 | new PrimaryDrawerItem().withName("Vereadores"), |
192 | 191 | new SecondaryDrawerItem().withName("Projetos"), |
193 | - new SecondaryDrawerItem().withName("Câmara") | |
192 | + new SecondaryDrawerItem().withName("Câmara") | |
194 | 193 | ) |
195 | 194 | .withOnDrawerItemClickListener(new Drawer.OnDrawerItemClickListener() { |
196 | 195 | @Override | ... | ... |
app/src/main/java/com/monitorabrasil/monitoralegislativo/adapters/ComentarioAdapter.java
0 → 100644
... | ... | @@ -0,0 +1,75 @@ |
1 | +package com.monitorabrasil.monitoralegislativo.adapters; | |
2 | + | |
3 | +import android.support.v7.widget.RecyclerView; | |
4 | +import android.view.LayoutInflater; | |
5 | +import android.view.View; | |
6 | +import android.view.ViewGroup; | |
7 | +import android.widget.TextView; | |
8 | + | |
9 | +import com.monitorabrasil.monitoralegislativo.R; | |
10 | +import com.monitorabrasil.monitoralegislativo.interfaces.RecyclerViewOnClickListenerHack; | |
11 | +import com.parse.ParseObject; | |
12 | + | |
13 | +import java.util.List; | |
14 | + | |
15 | +/** | |
16 | + * Created by geral_000 on 05/07/2015. | |
17 | + */ | |
18 | +public class ComentarioAdapter extends RecyclerView.Adapter<ComentarioAdapter.ViewHolder> { | |
19 | + | |
20 | + private List<ParseObject> mDataset; | |
21 | + private RecyclerViewOnClickListenerHack mRecyclerViewOnClickListenerHack; | |
22 | + | |
23 | + // Provide a reference to the views for each data item | |
24 | + // Complex data items may need more than one view per item, and | |
25 | + // you provide access to all the views for a data item in a view holder | |
26 | + public class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener{ | |
27 | + // each data item is just a string in this case | |
28 | + public TextView txtUser; | |
29 | + public TextView txtComentario; | |
30 | + public ViewHolder(View v) { | |
31 | + super(v); | |
32 | + txtUser = (TextView) v.findViewById(R.id.txtUser); | |
33 | + txtComentario = (TextView) v.findViewById(R.id.txtComentario); | |
34 | + | |
35 | + itemView.setOnClickListener(this); | |
36 | + } | |
37 | + | |
38 | + @Override | |
39 | + public void onClick(View v) { | |
40 | + if(mRecyclerViewOnClickListenerHack != null){ | |
41 | + mRecyclerViewOnClickListenerHack.onClickListener(v, getPosition()); | |
42 | + } | |
43 | + } | |
44 | + } | |
45 | + | |
46 | + public ComentarioAdapter(List<ParseObject> myDataset) { | |
47 | + mDataset = myDataset; | |
48 | + } | |
49 | + | |
50 | + @Override | |
51 | + public ComentarioAdapter.ViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) { | |
52 | + // create a new view | |
53 | + View v = LayoutInflater.from(viewGroup.getContext()) | |
54 | + .inflate(R.layout.item_comentario, viewGroup, false); | |
55 | + // set the view's size, margins, paddings and layout parameter | |
56 | + ViewHolder vh = new ViewHolder(v); | |
57 | + return vh; | |
58 | + } | |
59 | + public void setRecyclerViewOnClickListenerHack(RecyclerViewOnClickListenerHack r){ | |
60 | + mRecyclerViewOnClickListenerHack = r; | |
61 | + } | |
62 | + | |
63 | + @Override | |
64 | + public void onBindViewHolder(ComentarioAdapter.ViewHolder viewHolder, int i) { | |
65 | + ParseObject comentario = mDataset.get(i); | |
66 | + // vereador.pinInBackground(); | |
67 | + viewHolder.txtUser.setText(comentario.get("nome").toString()); | |
68 | + viewHolder.txtComentario.setText(comentario.get("mensagem").toString()); | |
69 | + } | |
70 | + | |
71 | + @Override | |
72 | + public int getItemCount() { | |
73 | + return mDataset.size(); | |
74 | + } | |
75 | +} | ... | ... |
app/src/main/java/com/monitorabrasil/monitoralegislativo/adapters/ProjetoAdapter.java
... | ... | @@ -2,8 +2,13 @@ package com.monitorabrasil.monitoralegislativo.adapters; |
2 | 2 | |
3 | 3 | import android.content.Intent; |
4 | 4 | import android.graphics.drawable.Drawable; |
5 | +import android.os.Build; | |
6 | +import android.os.Bundle; | |
5 | 7 | import android.support.design.widget.Snackbar; |
8 | +import android.support.v4.app.ActivityOptionsCompat; | |
9 | +import android.support.v4.app.FragmentActivity; | |
6 | 10 | import android.support.v4.content.ContextCompat; |
11 | +import android.support.v4.util.Pair; | |
7 | 12 | import android.support.v7.widget.RecyclerView; |
8 | 13 | import android.view.LayoutInflater; |
9 | 14 | import android.view.View; |
... | ... | @@ -11,6 +16,7 @@ import android.view.ViewGroup; |
11 | 16 | import android.widget.Button; |
12 | 17 | import android.widget.TextView; |
13 | 18 | |
19 | +import com.google.gson.Gson; | |
14 | 20 | import com.monitorabrasil.monitoralegislativo.ComentarioActivity; |
15 | 21 | import com.monitorabrasil.monitoralegislativo.R; |
16 | 22 | import com.monitorabrasil.monitoralegislativo.application.MyApp; |
... | ... | @@ -32,6 +38,7 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
32 | 38 | |
33 | 39 | private List<ParseObject> mDataset; |
34 | 40 | private RecyclerViewOnClickListenerHack mRecyclerViewOnClickListenerHack; |
41 | + private FragmentActivity mActivity; | |
35 | 42 | |
36 | 43 | // Provide a reference to the views for each data item |
37 | 44 | // Complex data items may need more than one view per item, and |
... | ... | @@ -49,6 +56,7 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
49 | 56 | public Button btnDiscordo; |
50 | 57 | public Button btnComentar; |
51 | 58 | public String voto; |
59 | + public ParseObject projeto; | |
52 | 60 | |
53 | 61 | public ViewHolder(View v) { |
54 | 62 | super(v); |
... | ... | @@ -73,8 +81,9 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
73 | 81 | } |
74 | 82 | } |
75 | 83 | |
76 | - public ProjetoAdapter(List<ParseObject> myDataset) { | |
84 | + public ProjetoAdapter(List<ParseObject> myDataset, FragmentActivity activity) { | |
77 | 85 | mDataset = myDataset; |
86 | + mActivity = activity; | |
78 | 87 | } |
79 | 88 | |
80 | 89 | @Override |
... | ... | @@ -101,6 +110,7 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
101 | 110 | viewHolder.btnConcordo.setEnabled(true); |
102 | 111 | viewHolder.voto = "sem_voto"; |
103 | 112 | final ParseObject projeto = mDataset.get(i); |
113 | + viewHolder.projeto = projeto; | |
104 | 114 | //verifica se ja votou |
105 | 115 | ParseQuery<ParseObject> query = ParseQuery.getQuery("Voto"); |
106 | 116 | query.fromLocalDatastore(); |
... | ... | @@ -112,7 +122,7 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
112 | 122 | String voto = list.get(0).get("voto").toString(); |
113 | 123 | viewHolder.projetoVotado = list.get(0); |
114 | 124 | if (voto.equals("s")) { |
115 | - viewHolder.btnConcordo .setBackground(apoioVerde); | |
125 | + viewHolder.btnConcordo.setBackground(apoioVerde); | |
116 | 126 | viewHolder.btnConcordo.setEnabled(false); |
117 | 127 | viewHolder.voto = "apoioado"; |
118 | 128 | ; |
... | ... | @@ -129,6 +139,11 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
129 | 139 | viewHolder.classificacao.setText(projeto.get("classificacao").toString()); |
130 | 140 | viewHolder.data.setText(projeto.get("data").toString()); |
131 | 141 | viewHolder.descricao.setText(projeto.get("descricao").toString()); |
142 | + int numComentario = 0; | |
143 | + if(projeto.get("nr_comentarios") != null){ | |
144 | + numComentario = Integer.valueOf( projeto.get("nr_comentarios").toString()); | |
145 | + } | |
146 | + viewHolder.btnComentar.setText(String.valueOf(numComentario)); | |
132 | 147 | int num=0; |
133 | 148 | if(projeto.get("apoio") != null){ |
134 | 149 | num = Integer.valueOf( projeto.get("apoio").toString()); |
... | ... | @@ -167,8 +182,21 @@ public class ProjetoAdapter extends RecyclerView.Adapter<ProjetoAdapter.ViewHold |
167 | 182 | @Override |
168 | 183 | public void onClick(View v) { |
169 | 184 | Intent mIntent =new Intent(MyApp.getInstance().getApplicationContext(), ComentarioActivity.class); |
185 | + Gson gson = new Gson(); | |
186 | + mIntent.putExtra("projeto",viewHolder.projeto.getObjectId()); | |
187 | + | |
170 | 188 | mIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); |
171 | - MyApp.getInstance().startActivity(mIntent); | |
189 | + if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP){ | |
190 | + View titulo = viewHolder.descricao; | |
191 | + ActivityOptionsCompat options = ActivityOptionsCompat. | |
192 | + makeSceneTransitionAnimation(mActivity, | |
193 | + Pair.create(titulo, "element1")); | |
194 | + mActivity.startActivity(mIntent, options.toBundle()); | |
195 | + }else{ | |
196 | + MyApp.getInstance().startActivity(mIntent); | |
197 | + } | |
198 | + | |
199 | + | |
172 | 200 | } |
173 | 201 | }); |
174 | 202 | } | ... | ... |
app/src/main/java/com/monitorabrasil/monitoralegislativo/fragments/ListaProjetosFragment.java
... | ... | @@ -80,7 +80,7 @@ public class ListaProjetosFragment extends Fragment implements RecyclerViewOnCli |
80 | 80 | }); |
81 | 81 | } |
82 | 82 | public void carregaList(List<ParseObject> list){ |
83 | - mAdapter = new ProjetoAdapter(list); | |
83 | + mAdapter = new ProjetoAdapter(list,getActivity()); | |
84 | 84 | mAdapter.setRecyclerViewOnClickListenerHack(this); |
85 | 85 | mRecyclerView.setAdapter(mAdapter); |
86 | 86 | pb.setVisibility(View.INVISIBLE); |
... | ... | @@ -92,17 +92,17 @@ public class ListaProjetosFragment extends Fragment implements RecyclerViewOnCli |
92 | 92 | |
93 | 93 | PoliticoFragment frag = new PoliticoFragment(); |
94 | 94 | Bundle bundle = new Bundle(); |
95 | - try { | |
96 | - ob.get(position).pin(); | |
97 | - } catch (ParseException e) { | |
98 | - e.printStackTrace(); | |
99 | - } | |
100 | - bundle.putString("politico", ob.get(position).getObjectId()); | |
101 | - frag.setArguments(bundle); | |
102 | - FragmentTransaction ft = getActivity().getSupportFragmentManager().beginTransaction(); | |
103 | - ft.replace(R.id.rl_fragment_container, frag, "politicoFrag"); | |
104 | - ft.addToBackStack(null); | |
105 | - ft.commit(); | |
95 | +// try { | |
96 | +// ob.get(position).pin(); | |
97 | +// } catch (ParseException e) { | |
98 | +// e.printStackTrace(); | |
99 | +// } | |
100 | +// bundle.putString("politico", ob.get(position).getObjectId()); | |
101 | +// frag.setArguments(bundle); | |
102 | +// FragmentTransaction ft = getActivity().getSupportFragmentManager().beginTransaction(); | |
103 | +// ft.replace(R.id.rl_fragment_container, frag, "politicoFrag"); | |
104 | +// ft.addToBackStack(null); | |
105 | +// ft.commit(); | |
106 | 106 | } |
107 | 107 | |
108 | 108 | } | ... | ... |
359 Bytes
227 Bytes
351 Bytes
638 Bytes
app/src/main/res/layout/activity_comentario.xml
1 | -<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" | |
2 | - xmlns:app="http://schemas.android.com/apk/res-auto" | |
3 | - xmlns:tools="http://schemas.android.com/tools" | |
4 | - android:id="@+id/drawerLayout" | |
5 | - android:layout_width="match_parent" | |
6 | - android:layout_height="match_parent" | |
7 | - tools:context="com.monitorabrasil.monitoralegislativo.ComentarioActivity"> | |
8 | - | |
9 | - <android.support.design.widget.CoordinatorLayout | |
10 | - android:id="@+id/rootLayout" | |
1 | + <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | |
2 | + xmlns:app="http://schemas.android.com/apk/res-auto" | |
3 | + xmlns:tools="http://schemas.android.com/tools" | |
4 | + android:id="@+id/drawerLayout" | |
11 | 5 | android:layout_width="match_parent" |
12 | - android:layout_height="match_parent"> | |
13 | - | |
14 | - <android.support.design.widget.AppBarLayout | |
15 | - android:layout_width="match_parent" | |
16 | - android:layout_height="@dimen/app_bar_height" | |
17 | - android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> | |
18 | - | |
19 | - <android.support.design.widget.CollapsingToolbarLayout | |
20 | - android:id="@+id/collapsingToolbarLayout" | |
21 | - android:layout_width="match_parent" | |
22 | - android:layout_height="match_parent" | |
23 | - app:contentScrim="?attr/colorPrimary" | |
24 | - app:expandedTitleMarginStart="@dimen/expanded_toolbar_title_margin_start" | |
25 | - app:layout_scrollFlags="scroll|exitUntilCollapsed"> | |
26 | - | |
27 | - <ImageView | |
28 | - android:layout_width="match_parent" | |
29 | - android:layout_height="match_parent" | |
30 | - android:scaleType="centerCrop" | |
31 | - android:src="@drawable/pattern1" | |
32 | - app:layout_collapseMode="parallax" | |
33 | - app:layout_collapseParallaxMultiplier="0.7" /> | |
34 | - <TextView | |
35 | - android:layout_width="wrap_content" | |
36 | - android:layout_height="wrap_content" | |
37 | - android:textAppearance="?android:attr/textAppearanceMedium" | |
38 | - android:text="Projeto" | |
39 | - android:id="@+id/projeto" /> | |
40 | - | |
41 | - | |
42 | - <android.support.v7.widget.Toolbar | |
43 | - android:id="@+id/toolbar" | |
44 | - android:layout_width="match_parent" | |
45 | - android:layout_height="?attr/actionBarSize" | |
46 | - app:layout_collapseMode="pin" | |
47 | - app:popupTheme="@style/ThemeOverlay.AppCompat.Light" | |
48 | - app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" /> | |
49 | - | |
50 | - </android.support.design.widget.CollapsingToolbarLayout> | |
6 | + android:layout_height="match_parent" | |
7 | + android:orientation="vertical" | |
8 | + tools:context="com.monitorabrasil.monitoralegislativo.ComentarioActivity"> | |
51 | 9 | |
52 | - </android.support.design.widget.AppBarLayout> | |
53 | - | |
54 | - <android.support.v4.widget.NestedScrollView | |
10 | + <android.support.v7.widget.Toolbar | |
11 | + android:id="@+id/tb_main" | |
12 | + android:layout_height="?attr/actionBarSize" | |
55 | 13 | android:layout_width="match_parent" |
56 | - android:layout_height="match_parent" | |
57 | - app:layout_behavior="@string/appbar_scrolling_view_behavior"> | |
58 | - | |
59 | - <LinearLayout | |
60 | - android:layout_width="match_parent" | |
61 | - android:layout_height="match_parent" | |
62 | - android:orientation="vertical"> | |
63 | - | |
64 | - | |
65 | - <include layout="@layout/fragment_politico_detalhe"/> | |
66 | - <RelativeLayout | |
67 | - android:id="@+id/rl_fragment_container" | |
68 | - android:layout_width="match_parent" | |
69 | - android:layout_height="400dp"> | |
14 | + android:minHeight="?attr/actionBarSize" | |
15 | + android:background="?attr/colorPrimary" | |
16 | + app:popupTheme="@style/ThemeOverlay.AppCompat.Dark" /> | |
17 | + | |
18 | + <RelativeLayout | |
19 | + android:id="@+id/rl_fragment_container" | |
20 | + android:layout_width="match_parent" | |
21 | + android:layout_height="match_parent"> | |
22 | + | |
23 | + <android.support.v7.widget.RecyclerView | |
24 | + android:id="@+id/my_recycler_view" | |
25 | + android:scrollbars="vertical" | |
26 | + android:layout_width="match_parent" | |
27 | + android:layout_height="match_parent" | |
28 | + android:layout_above="@+id/mensagem"/> | |
29 | + | |
30 | + <ProgressBar | |
31 | + android:layout_width="wrap_content" | |
32 | + android:layout_height="wrap_content" | |
33 | + android:id="@+id/progressBar" | |
34 | + android:layout_gravity="center" | |
35 | + android:layout_centerHorizontal="true" | |
36 | + android:layout_centerVertical="true" | |
37 | + android:indeterminate="false" /> | |
38 | + | |
39 | + | |
40 | + <Button | |
41 | + style="?android:attr/buttonStyleSmall" | |
42 | + android:layout_width="wrap_content" | |
43 | + android:layout_height="wrap_content" | |
44 | + android:id="@+id/btnEnviar" | |
45 | + android:layout_alignParentBottom="true" | |
46 | + android:layout_alignParentRight="true" | |
47 | + android:layout_alignParentEnd="true" | |
48 | + android:background="@drawable/ic_action_send" /> | |
49 | + | |
50 | + <EditText | |
51 | + android:layout_width="match_parent" | |
52 | + android:layout_height="wrap_content" | |
53 | + android:hint="Envie seu comentário" | |
54 | + android:id="@+id/mensagem" | |
55 | + android:textColorHint="@color/hint_text" | |
56 | + android:textColorLink="@color/hint_text" | |
57 | + android:textColor="@color/colorPrimarytext" | |
58 | + android:layout_alignParentBottom="true" | |
59 | + android:layout_alignParentLeft="true" | |
60 | + android:layout_alignParentStart="true" | |
61 | + android:layout_toLeftOf="@+id/btnEnviar" | |
62 | + android:layout_toStartOf="@+id/btnEnviar" /> | |
63 | + | |
64 | + | |
65 | + </RelativeLayout> | |
70 | 66 | |
71 | - </RelativeLayout> | |
72 | - | |
73 | - </LinearLayout> | |
74 | - | |
75 | - </android.support.v4.widget.NestedScrollView> | |
76 | 67 | |
77 | 68 | <android.support.design.widget.FloatingActionButton |
78 | - android:id="@+id/fabBtn" | |
79 | - android:layout_width="wrap_content" | |
80 | - android:layout_height="wrap_content" | |
81 | - android:layout_gravity="bottom|right" | |
82 | - android:layout_marginBottom="@dimen/fab_margin_bottom" | |
83 | - android:layout_marginRight="@dimen/fab_margin_right" | |
84 | - android:src="@drawable/ic_done" | |
85 | - app:borderWidth="0dp" | |
86 | - app:fabSize="normal" /> | |
87 | - | |
88 | - </android.support.design.widget.CoordinatorLayout> | |
89 | - | |
90 | -</android.support.v4.widget.DrawerLayout> | |
91 | 69 | \ No newline at end of file |
70 | + android:id="@+id/fabBtn" | |
71 | + android:layout_width="wrap_content" | |
72 | + android:layout_height="wrap_content" | |
73 | + android:layout_gravity="bottom|right" | |
74 | + android:layout_marginBottom="@dimen/fab_margin_bottom" | |
75 | + android:layout_marginRight="@dimen/fab_margin_right" | |
76 | + android:src="@drawable/ic_done" | |
77 | + app:borderWidth="0dp" | |
78 | + app:fabSize="normal" /> | |
79 | + | |
80 | + </LinearLayout> | |
92 | 81 | \ No newline at end of file | ... | ... |
... | ... | @@ -0,0 +1,27 @@ |
1 | +<?xml version="1.0" encoding="utf-8"?> | |
2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | |
3 | + android:orientation="vertical" android:layout_width="match_parent" | |
4 | + android:layout_height="match_parent" | |
5 | + android:paddingTop="3dp" | |
6 | + android:paddingBottom="3dp"> | |
7 | + | |
8 | + <TextView | |
9 | + android:layout_width="wrap_content" | |
10 | + android:layout_height="wrap_content" | |
11 | + android:text="Nome" | |
12 | + android:id="@+id/txtUser" | |
13 | + android:textSize="16dp" | |
14 | + android:textColor="@color/black" | |
15 | + android:textStyle="bold" | |
16 | + android:layout_marginLeft="@dimen/activity_horizontal_margin" | |
17 | + android:layout_marginTop="3dp" /> | |
18 | + | |
19 | + <TextView | |
20 | + android:layout_width="wrap_content" | |
21 | + android:layout_height="wrap_content" | |
22 | + android:textSize="15dp" | |
23 | + android:text="Partido" | |
24 | + android:id="@+id/txtComentario" | |
25 | + android:layout_marginLeft="20dp" | |
26 | + android:textColor="@color/colorPrimarytext" /> | |
27 | +</LinearLayout> | |
0 | 28 | \ No newline at end of file | ... | ... |
app/src/main/res/values/strings.xml