X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=src%2Fro%2Fieval%2Funical%2FEvent.java;h=6b39cb3ce9722b18f6f0e61860bd4dbbd82b679d;hb=86ad378625e166a5ea5b03614c5926616000bd55;hp=a069a9f0cfa38d39bc9ae0d1758919765ca4f55c;hpb=99658f577dd666fd3b558d5346a5aadb0d9d3a06;p=unical.git diff --git a/src/ro/ieval/unical/Event.java b/src/ro/ieval/unical/Event.java index a069a9f..6b39cb3 100644 --- a/src/ro/ieval/unical/Event.java +++ b/src/ro/ieval/unical/Event.java @@ -1,14 +1,18 @@ package ro.ieval.unical; import java.util.ArrayList; +import java.util.TimeZone; import android.content.ContentResolver; +import android.content.ContentValues; import android.content.Context; import android.database.Cursor; +import android.graphics.Color; import android.net.Uri; import android.os.Parcel; import android.os.Parcelable; import android.provider.BaseColumns; +import android.provider.CalendarContract; import android.provider.CalendarContract.Events; final class Event implements Parcelable{ @@ -37,25 +41,32 @@ final class Event implements Parcelable{ }; /** Event ID */ - public final long _id; + public long _id; /** Event owner */ - public final String organizer; + public String organizer; /** Event title */ - public final String title; + public String title; /** Event location */ - public final String eventLocation; + public String eventLocation; /** Event description */ - public final String description; + public String description; /** Event colour */ - public final int eventColour; - /** Event start time (UTC milliseconds since epoch) */ - public final long dtstart; + public int eventColour; + /** Event start time (UTC milliseconds since epoch) */ + public long dtstart; /** Event end time (UTC milliseconds since epoch) */ - public final long dtend; + public long dtend; /** Calendar ID */ - public final long calendarID; + public long calendarID; - private Event(final long _id, final String organizer, final String title, final String eventLocation, final String description, final int eventColor, final long dtstart, final long dtend, final long calendarID) { + public static Boolean calendarCreated=false; + + public Event() { + dtstart = System.currentTimeMillis(); + dtend = dtstart + 60*60*1000; + } + + public Event(final long _id, final String organizer, final String title, final String eventLocation, final String description, final int eventColor, final long dtstart, final long dtend, final long calendarID) { this._id=_id; this.organizer=organizer; this.title=title; @@ -85,20 +96,60 @@ final class Event implements Parcelable{ cursor.close(); return events; } - + + public static Event getEventById(final Context context, final long id){ + final ContentResolver cr=context.getContentResolver(); + final Cursor cursor = cr.query(Events.CONTENT_URI, + PROJECTION, + BaseColumns._ID+" = ?", + new String[]{Long.toString(id)}, + null); + final Event event; + if(cursor.moveToFirst()){ + int colour=cursor.getInt(5); + colour=colour == 0 ? Calendar.getCalendarById(context, cursor.getLong(8)).colour : colour; + event = new Event(cursor.getLong(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4), colour, cursor.getLong(6), cursor.getLong(7), cursor.getLong(8)); + } else + event = null; + cursor.close(); + return event; + } + public static Event[] getAllEvents(final Context context) { final ArrayList r = new ArrayList(); - for(final Calendar calendar : Calendar.getAllCalendars(context)) + for(final Calendar calendar : Calendar.getAllCalendars(context)) { + if(calendar.name.equals("unical")) calendarCreated=true; for(final Event event : getEventsByCalendar(context, calendar, null)) r.add(event); + } return r.toArray(new Event[r.size()]); } + public static long getUnicalId(final Context context) { + for(final Calendar calendar : Calendar.getAllCalendars(context)) + if(calendar.name.equals("unical")) return calendar._id; + + return 0; + } + + + public void insert(final Context context) { + ContentValues cv = new ContentValues(); + cv.put("calendar_id",calendarID); + cv.put("title",title); + cv.put("description",description); + cv.put("dtstart",dtstart); + cv.put("dtend",dtend); + cv.put("eventTimezone", TimeZone.getDefault().getID()); + + Uri url = context.getContentResolver().insert(Events.CONTENT_URI, cv); + } + public void delete(final Context context){ final ContentResolver cr=context.getContentResolver(); cr.delete(Uri.withAppendedPath(Events.CONTENT_URI, Long.toString(_id)), null, null); } - + @Override public int describeContents() { return 0;