)>}]
شركة التطبيقات المتكاملة لتصميم وبرمجة البرمجيات الخاصة ش.ش.و.
Integrated Applications Programming Company
Home » Code Library » ServiceExemption (Ia.Ftn.Cl.Models)

Public general use code classes and xml files that we've compiled and used over the years:

ServiceExemption Framework class for Fixed Telecommunications Network (FTN) entity model.

    1: using System;
    2: using System.ComponentModel.DataAnnotations.Schema;
    3: using System.Linq;
    4: using System.Threading;
    5: using System.Threading.Tasks;
    6:  
    7: namespace Ia.Ftn.Cl.Models
    8: {
    9:     ////////////////////////////////////////////////////////////////////////////
   10:  
   11:     /// <summary publish="true">
   12:     /// ServiceExemption Framework class for Fixed Telecommunications Network (FTN) entity model.
   13:     /// </summary>
   14:     /// 
   15:     /// <remarks> 
   16:     /// Copyright © 2006-2021 Jasem Y. Al-Shamlan (info@ia.com.kw), Integrated Applications - Kuwait. All Rights Reserved.
   17:     ///
   18:     /// This library is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by
   19:     /// the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
   20:     ///
   21:     /// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
   22:     /// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
   23:     /// 
   24:     /// You should have received a copy of the GNU General Public License along with this library. If not, see http://www.gnu.org/licenses.
   25:     /// 
   26:     /// Copyright notice: This notice may not be removed or altered from any source distribution.
   27:     /// </remarks> 
   28:     public class ServiceExemption
   29:     {
   30:         /// <summary/>
   31:         public ServiceExemption() { }
   32:  
   33:         /// <summary/>
   34:         public string Id { get; set; }
   35:  
   36:         /// <summary/>
   37:         public string Service { get; set; }
   38:  
   39:         /// <summary/>
   40:         public int ServiceType { get; set; }
   41:  
   42:         /// <summary/>
   43:         public string Note { get; set; }
   44:  
   45:         /// <summary/>
   46:         public DateTime Created { get; set; }
   47:  
   48:         /// <summary/>
   49:         public DateTime Updated { get; set; }
   50:  
   51:         /// <summary/>
   52:         [ForeignKey("StaffIdentityUser_Id")]
   53:         public virtual StaffIdentityUser StaffIdentityUser { get; set; }
   54:  
   55:         ////////////////////////////////////////////////////////////////////////////
   56:  
   57:         /// <summary>
   58:         ///
   59:         /// </summary>
   60:         public static string ServiceServiceExemptionId(string service, int serviceType)
   61:         {
   62:             // below:
   63:             string id;
   64:  
   65:             id = Ia.Ftn.Cl.Models.Business.Service2.ServiceId(service, serviceType);
   66:  
   67:             return id;
   68:         }
   69:  
   70:         ////////////////////////////////////////////////////////////////////////////
   71:  
   72:         /// <summary>
   73:         ///
   74:         /// </summary>
   75:         public bool Update(Ia.Ftn.Cl.Models.ServiceExemption updateServiceExemption)
   76:         {
   77:             // below: this will not update Id, Created
   78:             bool updated;
   79:  
   80:             updated = false;
   81:  
   82:             if (this.Note != updateServiceExemption.Note) { this.Note = updateServiceExemption.Note; updated = true; }
   83:             if (this.StaffIdentityUser.Id != updateServiceExemption.StaffIdentityUser.Id) { this.StaffIdentityUser.Id = updateServiceExemption.StaffIdentityUser.Id; updated = true; }
   84:  
   85:             if (updated) this.Updated = DateTime.UtcNow.AddHours(3);
   86:  
   87:             return updated;
   88:         }
   89:  
   90:         ////////////////////////////////////////////////////////////////////////////
   91:         ////////////////////////////////////////////////////////////////////////////
   92:     }
   93:  
   94:     ////////////////////////////////////////////////////////////////////////////
   95:     ////////////////////////////////////////////////////////////////////////////
   96: }