Пример #1
0
  public void Update(boolean isRefresing) {
    // when we refresh the data from the internet, we load again episodes and we neew to get back
    // to the objects that already exists if the were viewed that is smth we have stored.
    if (IsSaved()) {
      ContentValues values = new ContentValues();
      // Then add the data, along with the corresponding name of the data type,
      // so the content provider knows what kind of value is being inserted.

      values.put(SeriesContract.SeriesEntry.COLUMN_NAME, name);
      values.put(SeriesContract.SeriesEntry.COLUMN_NETWORK, network);
      values.put(SeriesContract.SeriesEntry.COLUMN_POSTER_URL, poster_url);
      values.put(SeriesContract.SeriesEntry.COLUMN_BANNER_URL, image_url);
      values.put(SeriesContract.SeriesEntry.COLUMN_OVERVIEW, overView);
      values.put(SeriesContract.SeriesEntry.COLUMN_RATING, rating);
      values.put(SeriesContract.SeriesEntry.COLUMN_VOTES, votes);
      values.put(SeriesContract.SeriesEntry.COLUMN_REALSED_DATE, dateReleased);
      values.put(SeriesContract.SeriesEntry.COLUMN_GENRE, genre);
      values.put(SeriesContract.SeriesEntry.COLUMN_MODIFYDATE, modify_date.getTime());
      values.put(SeriesContract.SeriesEntry.COLUMN_STATUS, status);

      // Finally, insert serie data into the database.
      MyApplication.getContext()
          .getContentResolver()
          .update(
              SeriesContract.SeriesEntry.CONTENT_URI,
              values,
              SeriesContract.SeriesEntry.COLUMN_ID + "=?",
              new String[] {id});
      // The resulting URI contains the ID for the row.  Extract the locationId from the Uri.
      if (episodes != null && episodes.size() > 0) {
        List<Episode> list = episodes;
        for (Episode episode : list) {
          if (episode.IsSaved()) {
            episode.Update();
            if (isRefresing) {
              // we need to get back the field viewed from database to inflate it properly
              episode.LoadViewed();
            }
          } else episode.Save();
        }
      }
      if (actors != null && actors.size() > 0) {
        List<Actor> list = actors;
        for (Actor actor : list) {
          if (actor.IsSaved()) actor.Update();
          else actor.Save();
        }
      }
    } else {
      Save();
    }
  }
Пример #2
0
 public void Save() {
   if (!IsSaved()) {
     ContentValues values = new ContentValues();
     // Then add the data, along with the corresponding name of the data type,
     // so the content provider knows what kind of value is being inserted.
     values.put(SeriesContract.SeriesEntry.COLUMN_ID, id);
     values.put(SeriesContract.SeriesEntry.COLUMN_NAME, name);
     values.put(SeriesContract.SeriesEntry.COLUMN_NETWORK, network);
     values.put(SeriesContract.SeriesEntry.COLUMN_POSTER_URL, poster_url);
     values.put(SeriesContract.SeriesEntry.COLUMN_BANNER_URL, image_url);
     values.put(SeriesContract.SeriesEntry.COLUMN_OVERVIEW, overView);
     values.put(SeriesContract.SeriesEntry.COLUMN_RATING, rating);
     values.put(SeriesContract.SeriesEntry.COLUMN_VOTES, votes);
     values.put(SeriesContract.SeriesEntry.COLUMN_REALSED_DATE, dateReleased);
     values.put(SeriesContract.SeriesEntry.COLUMN_GENRE, genre);
     values.put(SeriesContract.SeriesEntry.COLUMN_MODIFYDATE, modify_date.getTime());
     values.put(SeriesContract.SeriesEntry.COLUMN_STATUS, status);
     values.put(SeriesContract.SeriesEntry.COLUMN_TYPE, type);
     // Finally, insert serie data into the database.
     Uri insertedUri =
         MyApplication.getContext()
             .getContentResolver()
             .insert(SeriesContract.SeriesEntry.CONTENT_URI, values);
     // The resulting URI contains the ID for the row.  Extract the locationId from the Uri.
     _id = ContentUris.parseId(insertedUri);
     if (episodes != null && episodes.size() > 0) {
       List<Episode> list = episodes;
       for (Episode episode : list) {
         episode.Save();
       }
     }
     if (actors != null && actors.size() > 0) {
       List<Actor> list = actors;
       for (Actor actor : list) {
         actor.Save();
       }
     }
   }
 }