implement Event editing

This commit is contained in:
tibbi 2016-07-04 22:31:07 +02:00
parent 128eab6840
commit 4846c6964d
11 changed files with 151 additions and 43 deletions

View File

@ -34,7 +34,7 @@
android:screenOrientation="portrait"/>
<activity
android:name=".activities.DetailsActivity"
android:name=".activities.DayActivity"
android:label="@string/details"
android:screenOrientation="portrait"/>

View File

@ -22,7 +22,7 @@ public class CalendarImpl implements DBHelper.DBOperationsListener {
private List<Event> mEvents;
public CalendarImpl(Calendar callback, Context context) {
this.mCallback = callback;
mCallback = callback;
mContext = context;
mToday = new DateTime().toString(Formatter.DAYCODE_PATTERN);
}
@ -80,8 +80,8 @@ public class CalendarImpl implements DBHelper.DBOperationsListener {
}
private boolean hasEvent(String dayCode) {
for (Event e : mEvents) {
if (Formatter.getDayCodeFromTS(e.getStartTS()).equals(dayCode)) {
for (Event event : mEvents) {
if (Formatter.getDayCodeFromTS(event.getStartTS()).equals(dayCode)) {
return true;
}
}
@ -111,6 +111,11 @@ public class CalendarImpl implements DBHelper.DBOperationsListener {
}
@Override
public void eventUpdated() {
}
@Override
public void gotEvents(List<Event> events) {
mEvents = events;

View File

@ -10,4 +10,5 @@ public class Constants {
public static final String WIDGET_TEXT_COLOR = "widget_text_color";
public static final String DAY_CODE = "day_code";
public static final String EVENT = "event";
}

View File

@ -52,13 +52,26 @@ public class DBHelper extends SQLiteOpenHelper {
}
public void insert(Event event) {
final ContentValues values = fillContentValues(event);
mDb.insert(TABLE_NAME, null, values);
mCallback.eventInserted();
}
public void update(Event event) {
final ContentValues values = fillContentValues(event);
final String selection = COL_ID + " = ?";
final String[] selectionArgs = {String.valueOf(event.getId())};
mDb.update(TABLE_NAME, values, selection, selectionArgs);
mCallback.eventUpdated();
}
private ContentValues fillContentValues(Event event) {
final ContentValues values = new ContentValues();
values.put(COL_START_TS, event.getStartTS());
values.put(COL_END_TS, event.getEndTS());
values.put(COL_TITLE, event.getTitle());
values.put(COL_DESCRIPTION, event.getDescription());
mDb.insert(TABLE_NAME, null, values);
mCallback.eventInserted();
return values;
}
public void getEvents(int fromTS, int toTS) {
@ -86,6 +99,8 @@ public class DBHelper extends SQLiteOpenHelper {
public interface DBOperationsListener {
void eventInserted();
void eventUpdated();
void gotEvents(List<Event> events);
}
}

View File

@ -27,13 +27,18 @@ public class Formatter {
return dateTimeFormatter.parseDateTime(dayCode);
}
public static DateTime getLocalDateTimeFromCode(String dayCode) {
final DateTimeFormatter dateTimeFormatter = DateTimeFormat.forPattern(DAYCODE_PATTERN).withZone(DateTimeZone.getDefault());
return dateTimeFormatter.parseDateTime(dayCode);
}
public static String getTime(int ts) {
final DateTime dateTime = new DateTime(ts * 1000L, DateTimeZone.UTC);
final DateTime dateTime = new DateTime(ts * 1000L, DateTimeZone.getDefault());
return getEventTime(dateTime);
}
public static int getDayStartTS(String dayCode) {
final DateTime dateTime = getDateTimeFromCode(dayCode);
final DateTime dateTime = getLocalDateTimeFromCode(dayCode);
return (int) (dateTime.getMillis() / 1000);
}

View File

@ -4,6 +4,7 @@ import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.TextView;
@ -20,27 +21,28 @@ import butterknife.BindView;
import butterknife.ButterKnife;
import butterknife.OnClick;
public class DetailsActivity extends AppCompatActivity implements DBHelper.DBOperationsListener {
@BindView(R.id.details_date) TextView mDateTV;
@BindView(R.id.details_events) ListView mEventsList;
public class DayActivity extends AppCompatActivity implements DBHelper.DBOperationsListener, AdapterView.OnItemClickListener {
@BindView(R.id.day_date) TextView mDateTV;
@BindView(R.id.day_events) ListView mEventsList;
private String dayCode;
private static String mDayCode;
private static List<Event> mEvents;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_details);
setContentView(R.layout.activity_day);
ButterKnife.bind(this);
final Intent intent = getIntent();
if (intent == null)
return;
dayCode = intent.getStringExtra(Constants.DAY_CODE);
if (dayCode == null || dayCode.isEmpty())
mDayCode = intent.getStringExtra(Constants.DAY_CODE);
if (mDayCode == null || mDayCode.isEmpty())
return;
final String date = Formatter.getEventDate(dayCode);
final String date = Formatter.getEventDate(mDayCode);
mDateTV.setText(date);
}
@ -50,22 +52,30 @@ public class DetailsActivity extends AppCompatActivity implements DBHelper.DBOpe
checkEvents();
}
@OnClick(R.id.details_fab)
@OnClick(R.id.day_fab)
public void fabClicked(View view) {
final Intent intent = new Intent(getApplicationContext(), EventActivity.class);
intent.putExtra(Constants.DAY_CODE, dayCode);
intent.putExtra(Constants.DAY_CODE, mDayCode);
startActivity(intent);
}
private void editEvent(Event event) {
final Intent intent = new Intent(getApplicationContext(), EventActivity.class);
intent.putExtra(Constants.EVENT, event);
startActivity(intent);
}
private void checkEvents() {
final int startTS = Formatter.getDayStartTS(dayCode);
final int endTS = Formatter.getDayEndTS(dayCode);
final int startTS = Formatter.getDayStartTS(mDayCode);
final int endTS = Formatter.getDayEndTS(mDayCode);
DBHelper.newInstance(getApplicationContext(), this).getEvents(startTS, endTS);
}
private void updateEvents(List<Event> events) {
final EventsAdapter adapter = new EventsAdapter(this, events);
mEventsList.setAdapter(adapter);
mEventsList.setOnItemClickListener(this);
mEvents = events;
}
@Override
@ -73,8 +83,18 @@ public class DetailsActivity extends AppCompatActivity implements DBHelper.DBOpe
}
@Override
public void eventUpdated() {
}
@Override
public void gotEvents(List<Event> events) {
updateEvents(events);
}
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
editEvent(mEvents.get(position));
}
}

View File

@ -21,6 +21,7 @@ import com.simplemobiletools.calendar.Utils;
import com.simplemobiletools.calendar.models.Event;
import org.joda.time.DateTime;
import org.joda.time.DateTimeZone;
import java.util.List;
@ -38,6 +39,7 @@ public class EventActivity extends AppCompatActivity implements DBHelper.DBOpera
private DateTime mEventStartDateTime;
private DateTime mEventEndDateTime;
private Event mEvent;
@Override
protected void onCreate(Bundle savedInstanceState) {
@ -49,19 +51,37 @@ public class EventActivity extends AppCompatActivity implements DBHelper.DBOpera
if (intent == null)
return;
final String dayCode = intent.getStringExtra(Constants.DAY_CODE);
if (dayCode == null || dayCode.isEmpty())
return;
final Event event = (Event) intent.getSerializableExtra(Constants.EVENT);
if (event != null) {
mEvent = event;
setupEditEvent();
} else {
mEvent = new Event();
final String dayCode = intent.getStringExtra(Constants.DAY_CODE);
if (dayCode == null || dayCode.isEmpty())
return;
setupNewEvent(dayCode);
}
mEventStartDateTime = Formatter.getDateTimeFromCode(dayCode).withHourOfDay(13);
updateStartDate();
updateStartTime();
mEventEndDateTime = Formatter.getDateTimeFromCode(dayCode).withHourOfDay(14);
updateEndDate();
updateEndTime();
}
private void setupEditEvent() {
mEventStartDateTime = new DateTime(mEvent.getStartTS() * 1000L, DateTimeZone.getDefault());
mEventEndDateTime = new DateTime(mEvent.getEndTS() * 1000L, DateTimeZone.getDefault());
mTitleET.setText(mEvent.getTitle());
mDescriptionET.setText(mEvent.getDescription());
}
private void setupNewEvent(String dayCode) {
mEventStartDateTime = Formatter.getDateTimeFromCode(dayCode).withZone(DateTimeZone.getDefault()).withHourOfDay(13);
mEventEndDateTime = Formatter.getDateTimeFromCode(dayCode).withZone(DateTimeZone.getDefault()).withHourOfDay(14);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_event, menu);
@ -95,9 +115,17 @@ public class EventActivity extends AppCompatActivity implements DBHelper.DBOpera
return;
}
final DBHelper dbHelper = DBHelper.newInstance(getApplicationContext(), this);
final String description = mDescriptionET.getText().toString().trim();
final Event event = new Event(0, startTS, endTS, title, description);
DBHelper.newInstance(getApplicationContext(), this).insert(event);
mEvent.setStartTS(startTS);
mEvent.setEndTS(endTS);
mEvent.setTitle(title);
mEvent.setDescription(description);
if (mEvent.getId() == 0) {
dbHelper.insert(mEvent);
} else {
dbHelper.update(mEvent);
}
}
private void updateStartDate() {
@ -193,6 +221,12 @@ public class EventActivity extends AppCompatActivity implements DBHelper.DBOpera
finish();
}
@Override
public void eventUpdated() {
Utils.showToast(getApplicationContext(), R.string.event_updated);
finish();
}
@Override
public void gotEvents(List<Event> events) {

View File

@ -137,17 +137,17 @@ public class MainActivity extends AppCompatActivity implements Calendar {
dayTV.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
openDetails(day.getCode());
openDay(day.getCode());
}
});
}
}
private void openDetails(String code) {
private void openDay(String code) {
if (code.isEmpty())
return;
final Intent intent = new Intent(getApplicationContext(), DetailsActivity.class);
final Intent intent = new Intent(getApplicationContext(), DayActivity.class);
intent.putExtra(Constants.DAY_CODE, code);
startActivity(intent);
}

View File

@ -1,11 +1,22 @@
package com.simplemobiletools.calendar.models;
public class Event {
import java.io.Serializable;
public class Event implements Serializable {
private static final long serialVersionUID = -32456795132354616L;
private final int mId;
private final int mStartTS;
private final int mEndTS;
private final String mTitle;
private final String mDescription;
private int mStartTS;
private int mEndTS;
private String mTitle;
private String mDescription;
public Event() {
mId = 0;
mStartTS = 0;
mEndTS = 0;
mTitle = "";
mDescription = "";
}
public Event(int id, int startTS, int endTS, String title, String description) {
mId = id;
@ -23,18 +34,34 @@ public class Event {
return mStartTS;
}
public void setStartTS(int startTS) {
mStartTS = startTS;
}
public int getEndTS() {
return mEndTS;
}
public void setEndTS(int endTS) {
mEndTS = endTS;
}
public String getTitle() {
return mTitle;
}
public void setTitle(String title) {
mTitle = title;
}
public String getDescription() {
return mDescription;
}
public void setDescription(String description) {
mDescription = description;
}
@Override
public String toString() {
return "Event {" +

View File

@ -1,18 +1,18 @@
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
android:id="@+id/details_coordinator"
android:id="@+id/day_coordinator"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="@dimen/activity_margin">
<RelativeLayout
android:id="@+id/details_holder"
android:id="@+id/day_holder"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/details_date"
android:id="@+id/day_date"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="@dimen/activity_margin"
@ -21,14 +21,14 @@
android:textSize="@dimen/month_text_size"/>
<ListView
android:id="@+id/details_events"
android:id="@+id/day_events"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/details_date"/>
android:layout_below="@+id/day_date"/>
</RelativeLayout>
<android.support.design.widget.FloatingActionButton
android:id="@+id/details_fab"
android:id="@+id/day_fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|end"

View File

@ -7,8 +7,9 @@
<string name="title_empty">Title cannot be empty</string>
<string name="end_before_start">The event cannot end earlier than it starts</string>
<string name="event_added">Event added successfully</string>
<string name="event_updated">Event updated successfully</string>
<!-- Details -->
<!-- Day details -->
<string name="details">Details</string>
<string name="title">Title</string>
<string name="start">Start</string>