196 lines
7.9 KiB
C#
196 lines
7.9 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using System.Data;
|
|
using Foresight.Data;
|
|
using IronIntel.Contractor.Users;
|
|
using IronIntel.Services;
|
|
|
|
namespace IronIntel.Contractor.Users
|
|
{
|
|
class AppModulesManagement
|
|
{
|
|
private const string FITracker = "FITracker";
|
|
private const string Inspect = "Inspection";
|
|
private const string TeamIntelligence = "TeamIntelligence";
|
|
public static AppModuleInfo[] GetAvailableAppModuleInfos(UserInfo user)
|
|
{
|
|
const string SQL = @"select ID,APPMODULENAME,APPMODULEDESC,URL,ICONPATH,BACKCOLOR,FORECOLOR,OPENINNEWWINDOW from APPMODULES where VISIBLE>0 and (isnull(SITETYPE,'All')='All' or SITETYPE={0}) ";
|
|
|
|
if (user == null)
|
|
{
|
|
return new AppModuleInfo[0];
|
|
}
|
|
|
|
string sql = SQL;
|
|
switch (user.UserType)
|
|
{
|
|
case UserTypes.Readonly:
|
|
sql = SQL + " and SECURITYLEVEL=0";
|
|
break;
|
|
case UserTypes.Common:
|
|
sql = SQL + " and SECURITYLEVEL<=1";
|
|
break;
|
|
case UserTypes.Admin:
|
|
sql = SQL + " and SECURITYLEVEL<=2";
|
|
break;
|
|
case UserTypes.SupperAdmin:
|
|
sql = SQL + " and SECURITYLEVEL<=3";
|
|
break;
|
|
default:
|
|
sql = SQL;
|
|
break;
|
|
}
|
|
|
|
sql = sql + " order by ORDERINDEX ";
|
|
|
|
FIDbAccess db = SystemParams.GetDbInstance();
|
|
DataTable dt = db.GetDataTableBySQL(sql, SystemParams.CustomerDetail.CustomerType);
|
|
|
|
CustUIStyle style = SystemParams.GetUIStyle(user.IID);//获取样式设置
|
|
string moudleBackgroundColor = "#0078D7";
|
|
if (style != null && !string.IsNullOrEmpty(style.MenuBackgroundColor))
|
|
moudleBackgroundColor = style.MenuBackgroundColor;
|
|
|
|
List<AppModuleInfo> list = new List<AppModuleInfo>();
|
|
bool fitracter = SystemParams.HasLicense(FITracker);
|
|
bool inspect = SystemParams.HasLicense(Inspect);
|
|
bool teamintelligence = SystemParams.HasLicense(TeamIntelligence);
|
|
foreach (DataRow dr in dt.Rows)
|
|
{
|
|
AppModuleInfo ami = ConvertToAppModule(dr);
|
|
ami.BackColor = moudleBackgroundColor;
|
|
if (ami.ID.Equals(FITracker, StringComparison.OrdinalIgnoreCase))
|
|
{
|
|
if (fitracter)
|
|
list.Add(ami);
|
|
}
|
|
else if (ami.ID.Equals(Inspect, StringComparison.OrdinalIgnoreCase))
|
|
{
|
|
if (inspect)
|
|
list.Add(ami);
|
|
}
|
|
else if (ami.ID.Equals(TeamIntelligence, StringComparison.OrdinalIgnoreCase))
|
|
{
|
|
if (teamintelligence)
|
|
list.Add(ami);
|
|
}
|
|
else
|
|
list.Add(ami);
|
|
}
|
|
AppModuleInfo[] wsps = GetFICWorkspace(user);
|
|
foreach (AppModuleInfo ap in wsps)
|
|
{
|
|
if (!Exists(ap.Url, list))
|
|
{
|
|
ap.BackColor = moudleBackgroundColor;
|
|
list.Add(ap);
|
|
}
|
|
}
|
|
return list.ToArray();
|
|
}
|
|
|
|
private static bool Exists(string url, IEnumerable<AppModuleInfo> items)
|
|
{
|
|
foreach (AppModuleInfo item in items)
|
|
{
|
|
if (string.Compare(url, item.Url, true) == 0)
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
private static AppModuleInfo ConvertToAppModule(DataRow dr)
|
|
{
|
|
AppModuleInfo ai = new AppModuleInfo();
|
|
ai.ID = FIDbAccess.GetFieldString(dr["ID"], string.Empty);
|
|
ai.Name = FIDbAccess.GetFieldString(dr["APPMODULENAME"], string.Empty);
|
|
ai.Description = FIDbAccess.GetFieldString(dr["APPMODULEDESC"], string.Empty);
|
|
ai.Url = FIDbAccess.GetFieldString(dr["URL"], string.Empty);
|
|
ai.IconPath = FIDbAccess.GetFieldString(dr["ICONPATH"], string.Empty);
|
|
ai.BackColor = FIDbAccess.GetFieldString(dr["BACKCOLOR"], string.Empty);
|
|
ai.ForeColor = FIDbAccess.GetFieldString(dr["FORECOLOR"], string.Empty);
|
|
ai.OpenInNewWindow = FIDbAccess.GetFieldInt(dr["OPENINNEWWINDOW"], 0) == 1;
|
|
ai.Visible = true;
|
|
ai.ModuleType = AppModuleType.System;
|
|
return ai;
|
|
}
|
|
|
|
private static AppModuleInfo[] GetFICWorkspace(UserInfo user)
|
|
{
|
|
if (string.IsNullOrWhiteSpace(SystemParams.FICDbConnectionString))
|
|
{
|
|
return new AppModuleInfo[0];
|
|
}
|
|
|
|
string SQL = @"select w.IID,isnull(l.WorkSpaceName,w.WSPNAME) as WSPNAME,w.WSPDESCRIPTION from WORKSPACE w
|
|
left join WorkSpaceLanguage l on w.IID=l.WorkspaceIID and l.LanguageCode='en-us'
|
|
where (ISPUBLIC=1 or ISPUBLIC>10)";
|
|
|
|
FISqlConnection db = new FISqlConnection(SystemParams.FICDbConnectionString);
|
|
if (user.UserType == UserTypes.Readonly)
|
|
{
|
|
SQL += " and w.IID in( select ObjectValue from UserDefaultInfo where UserID='" + user.IID + "' and UserDefaultType=0)";
|
|
}
|
|
SQL += " order by isnull(l.WorkspaceName,w.WSPNAME)";
|
|
|
|
|
|
|
|
DataTable tb = db.GetDataTableBySQL(SQL);
|
|
List<AppModuleInfo> ls = new List<AppModuleInfo>();
|
|
foreach (DataRow dr in tb.Rows)
|
|
{
|
|
AppModuleInfo ap = new AppModuleInfo();
|
|
ap.ID = dr["IID"].ToString();
|
|
ap.Name = FIDbAccess.GetFieldString(dr["WSPNAME"], string.Empty);
|
|
ap.OpenInNewWindow = false;
|
|
ap.Description = FIDbAccess.GetFieldString(dr["WSPDESCRIPTION"], string.Empty);
|
|
ap.Visible = true;
|
|
if (string.IsNullOrWhiteSpace(ap.Description))
|
|
{
|
|
ap.Description = ap.Name;
|
|
}
|
|
ap.ForeColor = "white";
|
|
ap.Url = @"fic/Workspace.aspx?IID=" + ap.ID;
|
|
ap.IconPath = @"img/modules/pie1.png?t=0";
|
|
ap.ModuleType = AppModuleType.Workspace;
|
|
ls.Add(ap);
|
|
}
|
|
return ls.ToArray();
|
|
}
|
|
|
|
public static SecurityNavigateItem[] GetSecurityNavigateItems(UserInfo user)
|
|
{
|
|
const string SQL = "select * from SECURITYNAVNODE where (isnull(SITETYPE,'All')='All' or SITETYPE={0}) order by ORDERINDEX";
|
|
|
|
if ((user == null) || (user.UserType == UserTypes.Readonly) || (user.UserType == UserTypes.Common))
|
|
{
|
|
return new SecurityNavigateItem[0];
|
|
}
|
|
|
|
FIDbAccess db = SystemParams.GetDbInstance();
|
|
DataTable dt = db.GetDataTableBySQL(SQL, SystemParams.CustomerDetail.CustomerType);
|
|
List<SecurityNavigateItem> ls = new List<SecurityNavigateItem>();
|
|
foreach (DataRow dr in dt.Rows)
|
|
{
|
|
SecurityNavigateItem si = new SecurityNavigateItem();
|
|
si.ID = FIDbAccess.GetFieldString(dr["NODEID"], string.Empty);
|
|
si.Title = FIDbAccess.GetFieldString(dr["TITLE"], string.Empty);
|
|
si.IconPath = FIDbAccess.GetFieldString(dr["ICONPATH"], string.Empty);
|
|
si.Url = FIDbAccess.GetFieldString(dr["TARGETURL"], string.Empty);
|
|
|
|
if ("nav_dts" == si.ID.ToLower())
|
|
si.Url = "../fic/fic/Management/DataTablePermission.aspx";
|
|
if ("nav_filters" == si.ID.ToLower())
|
|
si.Url = "../fic/fic/Management/FiltersManagement.aspx";
|
|
ls.Add(si);
|
|
}
|
|
return ls.ToArray();
|
|
}
|
|
}
|
|
}
|