X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=src%2Fro%2Fieval%2Funical%2FAddEventActivity.java;h=512b6895e786523fc597a19e88c6f6ddfc1cdc94;hb=e4fb15ad7fab87f31ae9af7bcfe2d4f71c150125;hp=3971036fc775268264ae1f610cc4cbb20b05bcb8;hpb=245dbc0190839dac5210a2779bd9061636e1d383;p=unical.git diff --git a/src/ro/ieval/unical/AddEventActivity.java b/src/ro/ieval/unical/AddEventActivity.java index 3971036..512b689 100644 --- a/src/ro/ieval/unical/AddEventActivity.java +++ b/src/ro/ieval/unical/AddEventActivity.java @@ -7,24 +7,33 @@ 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.EditText; -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.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)); @@ -34,21 +43,24 @@ public final class AddEventActivity extends Activity implements OnDateSetListene 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); @@ -69,38 +81,36 @@ public final class AddEventActivity extends Activity implements OnDateSetListene finish(); return true; case R.id.save: - Event e = getEvent(this); + //TODO Save event + Toast toast = Toast.makeText(getApplicationContext(),"Event saved!",Toast.LENGTH_LONG); + toast.show(); + finish(); return true; default: return false; } } - private Event getEvent(final Activity v) { - final Fragment basicFragment = v.getFragmentManager().findFragmentById(R.id.basic_tab); - final Fragment detailsFragment = v.getFragmentManager().findFragmentById(R.id.details_tab); - - //TODO get all information - final long _id=22; - final String organizer=""; - final String title=((EditText)basicFragment.getView().findViewById(R.id.eventtitle)).getText().toString(); - final String eventLocation=""; - final String description=((EditText)detailsFragment.getView().findViewById(R.id.description)).getText().toString(); - final int eventColor=0; - final long dtstart=0; - final long dtend=0; - final long calendarID = 0; - System.out.print(title + description); - Event ret = new Event(_id,organizer,title,eventLocation,description,eventColor,dtstart,dtend,calendarID); - return ret; - } - public void showDateTimePickerDialog(final View v) { dateTimeTextView=(TextView) v; - if(v.getId()==R.id.date_start || v.getId()==R.id.date_end || v.getId() == R.id.repeat_until) - 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 @@ -114,7 +124,7 @@ public final class AddEventActivity extends Activity implements OnDateSetListene 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(Utils.formatDate(year, monthOfYear, dayOfMonth)); - calendar.add(Calendar.DAY_OF_MONTH, 1); + //calendar.add(Calendar.DAY_OF_MONTH, 1); if(dateTimeTextView.getId() == R.id.date_start) ((TextView)findViewById(R.id.date_end)).setText(Utils.formatDate(calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH))); }