internal static int Add(IEntity entity)
{
Menu menuEntity = (Menu)(entity);
using (SqlConnection sqlConnection = new SqlConnection(CMSCoreBase.CMSCoreConnectionString))
{
SqlCommand sqlCommand = new SqlCommand(SN_MENU_ADD, sqlConnection);
sqlCommand.CommandType = System.Data.CommandType.StoredProcedure;
SqlParameter sqlParameter = null;
sqlParameter = new SqlParameter(PN_MENU_CATEGORY_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.CategoryID;
sqlCommand.Parameters.Add(sqlParameter);
double days = 0;
double seconds = 0;
CMSCoreHelper.GetDaySecondsNumber(menuEntity.CreationDate, out days, out seconds);
sqlParameter = new SqlParameter(PN_MENU_CREATION_DAY, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = (int)days;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_CREATION_SEC, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = (int)seconds;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_DESCRIPTION, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.Description;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_DETAILS, System.Data.SqlDbType.NText);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.Details;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Output;
sqlParameter.Value = 0;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_IMAGE, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.Image;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_IS_DELETED, System.Data.SqlDbType.Bit);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.IsDeleted;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_KEYWORDS, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.KeyWords;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_LANGUAGE_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.LanguageID;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_NAME, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.Name;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_PAGE_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.PageID;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_PARENT_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.ParentID;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_PORTAL_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.PortalID;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_SEO_NAME, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.SEOName;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_URL, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.URL;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_TYPE, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = (int)menuEntity.MenuType;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_ORDER, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.Order;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_CREATED_BY, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.CreatedBy;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_PARENT_OBJ_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.ParentObjectID;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_GALLERY_CATEGORY_ID, System.Data.SqlDbType.Int);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.GalleryCategoryID;
sqlCommand.Parameters.Add(sqlParameter);
sqlParameter = new SqlParameter(PN_MENU_PAGE_TITLE, System.Data.SqlDbType.NVarChar);
sqlParameter.Direction = System.Data.ParameterDirection.Input;
sqlParameter.Value = menuEntity.PageTitle;
sqlCommand.Parameters.Add(sqlParameter);
try
{
sqlCommand.Connection.Open();
sqlCommand.ExecuteNonQuery();
sqlCommand.Connection.Close();
menuEntity.ID = Convert.ToInt32(sqlCommand.Parameters[PN_MENU_ID].Value);
}
catch (Exception ex)
{
throw ex;
}
}
return menuEntity.ID;
}