X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=src%2Fro%2Fieval%2Funical%2FAddEventActivity.java;h=512b6895e786523fc597a19e88c6f6ddfc1cdc94;hb=e4fb15ad7fab87f31ae9af7bcfe2d4f71c150125;hp=436d2cab7fb356dee8c1fc5c72c25bea5bcd06d2;hpb=3dd871efed8ef534c16c62a99a011f4f11e54f56;p=unical.git diff --git a/src/ro/ieval/unical/AddEventActivity.java b/src/ro/ieval/unical/AddEventActivity.java index 436d2ca..512b689 100644 --- a/src/ro/ieval/unical/AddEventActivity.java +++ b/src/ro/ieval/unical/AddEventActivity.java @@ -7,82 +7,115 @@ import android.app.Activity; import android.app.DatePickerDialog.OnDateSetListener; import android.app.Fragment; import android.app.TimePickerDialog.OnTimeSetListener; +import android.content.Context; +import android.content.Intent; import android.os.Bundle; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; import android.view.View; -import android.widget.DatePicker; -import android.widget.TextView; -import android.widget.TimePicker; +import android.widget.*; + +//TODO if i want to add a new event after i edit one the fields are being filled with the last event data public final class AddEventActivity extends Activity implements OnDateSetListener, OnTimeSetListener{ private TextView dateTimeTextView; + public static final String EXTRA_EVENT = "event"; + + public static void editEvent(final Context c, final Event e) { + final Intent i = new Intent(c,AddEventActivity.class); + i.putExtra(AddEventActivity.EXTRA_EVENT,e); + c.startActivity(i); + } + @Override protected void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); - setContentView(R.layout.add_event); - setTitle(R.string.addeventtitle); + setTitle(R.string.add_event_title); + final Event event = getIntent().hasExtra(EXTRA_EVENT) ? (Event) getIntent().getParcelableExtra(EXTRA_EVENT) : new Event(); final ActionBar actionBar = getActionBar(); actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS); final ActionBar.Tab t1 = actionBar.newTab().setText(this.getString(R.string.addevtab1)); final ActionBar.Tab t2 = actionBar.newTab().setText(this.getString(R.string.addevtab2)); final ActionBar.Tab t3 = actionBar.newTab().setText(this.getString(R.string.addevtab3)); - + final Fragment f1 = new TrivialFragment(); final Bundle b1=new Bundle(); b1.putInt(TrivialFragment.ARGUMENT_LAYOUT, R.layout.add_event_basic_tab); + b1.putParcelable(TrivialFragment.ARGUMENT_EVENT, event); f1.setArguments(b1); final Fragment f2 = new TrivialFragment(); final Bundle b2=new Bundle(); b2.putInt(TrivialFragment.ARGUMENT_LAYOUT, R.layout.add_event_details_tab); + b2.putParcelable(TrivialFragment.ARGUMENT_EVENT, event); f2.setArguments(b2); final Fragment f3 = new TrivialFragment(); final Bundle b3=new Bundle(); b3.putInt(TrivialFragment.ARGUMENT_LAYOUT, R.layout.add_event_other_tab); + b3.putParcelable(TrivialFragment.ARGUMENT_EVENT, event); f3.setArguments(b3); - - t1.setTabListener(new AddEventTabListener(f1)); - t2.setTabListener(new AddEventTabListener(f2)); - t3.setTabListener(new AddEventTabListener(f3)); - + + t1.setTabListener(new AddEventTabListener(f1, event, 0)); + t2.setTabListener(new AddEventTabListener(f2, event, 1)); + t3.setTabListener(new AddEventTabListener(f3, event, 2)); + actionBar.addTab(t1); actionBar.addTab(t2); actionBar.addTab(t3); } - + @Override public boolean onCreateOptionsMenu(final Menu menu) { final MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.add_event, menu); return true; } - + @Override public boolean onOptionsItemSelected(final MenuItem item) { switch (item.getItemId()) { case R.id.cancel: finish(); return true; + case R.id.save: + //TODO Save event + Toast toast = Toast.makeText(getApplicationContext(),"Event saved!",Toast.LENGTH_LONG); + toast.show(); + finish(); + return true; default: return false; } } - - public void showDateTimePickerDialog(final View v) { + + public void showDateTimePickerDialog(final View v) { dateTimeTextView=(TextView) v; - if(v.getId()==R.id.date_start || v.getId()==R.id.date_end) - new DatePickerFragment().show(getFragmentManager(), "datePicker"); - else - new TimePickerFragment().show(getFragmentManager(), "timePicker"); + if(v.getId()==R.id.date_start || v.getId()==R.id.date_end || v.getId() == R.id.repeat_until){ + final String[] parts = dateTimeTextView.getText().toString().split("-"); + final DatePickerFragment fragment = new DatePickerFragment(); + final Bundle args = new Bundle(); + args.putInt(DatePickerFragment.ARGUMENT_YEAR, Integer.parseInt(parts[0])); + args.putInt(DatePickerFragment.ARGUMENT_MONTH, Integer.parseInt(parts[1])); + args.putInt(DatePickerFragment.ARGUMENT_DAY, Integer.parseInt(parts[2])); + fragment.setArguments(args); + fragment.show(getFragmentManager(), "datePicker"); + } else { + final String[] parts = dateTimeTextView.getText().toString().split(":"); + final TimePickerFragment fragment = new TimePickerFragment(); + final Bundle args = new Bundle(); + args.putInt(TimePickerFragment.ARGUMENT_HOUR, Integer.parseInt(parts[0])); + args.putInt(TimePickerFragment.ARGUMENT_MINUTE, Integer.parseInt(parts[1])); + fragment.setArguments(args); + fragment.show(getFragmentManager(), "timePicker"); + } } @Override public void onTimeSet(final TimePicker picker, final int hour, final int minute) { - dateTimeTextView.setText(String.format("%2d:%2d",hour,minute)); + dateTimeTextView.setText(String.format("%02d:%02d",hour,minute)); if(dateTimeTextView.getId() == R.id.time_start) ((TextView)findViewById(R.id.time_end)).setText(String.format("%2d:%2d",hour,minute)); } @@ -90,9 +123,9 @@ public final class AddEventActivity extends Activity implements OnDateSetListene @Override public void onDateSet(final DatePicker picker, final int year, final int monthOfYear, final int dayOfMonth) { final Calendar calendar=new GregorianCalendar(year, monthOfYear, dayOfMonth); - dateTimeTextView.setText(String.format("%4d-%2d-%2d", calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH))); - calendar.add(Calendar.DAY_OF_MONTH, 1); + dateTimeTextView.setText(Utils.formatDate(year, monthOfYear, dayOfMonth)); + //calendar.add(Calendar.DAY_OF_MONTH, 1); if(dateTimeTextView.getId() == R.id.date_start) - ((TextView)findViewById(R.id.date_end)).setText(String.format("%4d-%2d-%2d", calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH))); + ((TextView)findViewById(R.id.date_end)).setText(Utils.formatDate(calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH))); } }