fleet-contractor/Site/IronIntelMasterPage.master
2024-03-26 15:56:31 +08:00

1229 lines
51 KiB
Plaintext

<%@ Master Language="C#" AutoEventWireup="true" CodeFile="IronIntelMasterPage.master.cs" Inherits="IronIntelMasterPage" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<title>Iron Intel</title>
<link rel="shortcut icon" href="<%=GetUrl("favicon.ico") %>" />
<link type="text/css" href="<%=GetUrl("js/lib/ui.min.css") %>" rel="stylesheet" />
<link rel="stylesheet" href="<%=GetUrl("css/default.css")%>" type="text/css" />
<link rel="stylesheet" href="<%=GetUrl("css/split_sub.css")%>" type="text/css" />
<style type="text/css" runat="server" id="materStyle">
/*table {
font-size: 12px;
}*/
.smaller {
font-size: 0.9em;
}
a {
text-decoration: none;
color: #2140fb;
}
a:hover {
text-decoration: underline;
}
a:visited {
color: #2140fb;
}
.lefttitle_title {
width: 96%;
height: 40px;
font-size: 20px;
line-height: 40px;
padding-left: 10px;
/*background-color: #0079c1;*/
background: <%=MenuBackgroundColor %>;
text-align: center;
}
#host_header {
background: var(--title-bg-color);
color: #000;
height: 60px;
min-width: 1280px;
text-align: center;
position: relative;
/*box-shadow: 0 0 10px rgba(0,0,0,.4);*/
}
#host_header .logo {
float: left;
height: 60px;
font-weight: bold;
font-size: 1.7em;
font-family: "Open Sans", Arial, sans-serif;
/*max-width: 200px;*/
}
#host_header .logocenter {
height: 60px;
line-height: 60px;
font-weight: bold;
font-size: 2em;
font-family: "Open Sans", Arial, sans-serif;
/*max-width: 200px;*/
}
#host_header .logoright {
float: right;
height: 60px;
margin: 0px 5px;
font-weight: bold;
font-size: 1.7em;
font-family: "Open Sans", Arial, sans-serif;
/*max-width: 200px;*/
}
#host_header .company_name {
float: left;
height: 60px;
line-height: 60px;
margin-left: 24px;
font-weight: bold;
font-size: 1.7em;
font-family: "Open Sans", Arial, sans-serif;
}
#host_header .headernote {
float: left;
height: 59px;
max-width: 300px;
overflow: hidden;
}
#preheadernote {
margin: 4px 10px;
font-size: 14px;
line-height: 14px;
text-align: left;
font-family: Calibri;
position: absolute;
height: 95%;
overflow: hidden;
}
#host_header .user {
float: left;
line-height: 58px;
max-width: 160px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
#host_header .button button {
background-color: var(--title-bg-color);
}
/*#host_header .button button:hover,
#host_header .button button.selected {
background-color: <%=MenuBackgroundColor %>;
}
*/
.dialog-content .gridchartcontainer {
border: 1px solid #A2ADB8;
/*height: 100%;*/
}
#divTitleBorder {
width: 100%;
height: 2px;
border: solid 0px;
background-color: <%=TitleBarBorderColor %>;
border-color: <%=TitleBarBorderColor %>;
}
#button_home:before {
content: "\f015";
}
#button_sites:before {
content: '\f0c9';
}
#userbutton_down:before {
font-weight: 600;
content: '\f0d7';
}
.fav {
font-weight: 900;
color: #1a73e8;
cursor: pointer;
}
.unfav {
font-weight: 200;
color: black;
cursor: pointer;
}
.nofav {
font-weight: 200;
color: lightgray;
cursor: default;
}
.favicon {
margin-left: 5px;
}
.favicon:before {
content: '\f005';
}
.favmenu {
line-height: 40px;
font-family: CalciteWebCoreIcons, FontAwesome;
padding: 0;
font-size: 1.5em;
}
.favmenudown {
font-weight: 600;
}
.favmenudown:before {
content: '\f0da';
}
.setting:before {
content: '\f013';
}
#version_info {
text-wrap: none;
font-size: 10px;
height: 20px;
}
#divLeftTitle {
background-color: #cbcbcb;
height: 100%;
width: 48px;
float: left;
top: 60px;
bottom: 0;
margin: 0;
position: fixed;
}
#content {
/*width: 100%;*/
top: 60px;
bottom: 0;
left: 0;
right: 0;
margin: 0;
margin-left: 48px;
position: fixed;
/*color: #6b6b6b;*/
overflow: auto;
}
#content > h3 {
margin: 16px 0 16px 18px;
}
.clear {
display: block;
clear: both;
height: 0;
}
/*#button_changepass {
font-size: 16px;
cursor: pointer;
margin-top: 2px;
font-weight: 900;
}*/
#button_changepass:before {
content: '\f084'; /*font-family: 'FontAwesome';*/
}
/*#button_logout {
font-size: 16px;
cursor: pointer;
font-weight: 900;
}*/
#button_logout:before {
content: '\f08b';
/*font-family: 'FontAwesome';*/
}
.item_header {
font-family: Arial;
font-size: 1.1em;
font-weight: bold;
line-height: 24px;
margin-top: 8px;
}
.item_label {
line-height: 18px;
}
.item_text {
line-height: 22px;
}
.item_text input {
width: 286px;
border: 1px solid #a9a9a9;
padding: 2px;
}
.item_error {
padding: 5px;
margin-top: 5px;
border: 1px solid #f00;
color: #f00;
width: 280px;
}
.item_strong {
width: 292px;
line-height: 17px;
}
#pass_progress label {
margin: 2px 4px;
}
.non {
background: none;
color: rgb(115, 124, 133);
}
.weak {
background: #f00;
color: white;
width: 33%;
}
.normal {
background: #ec6b00;
color: white;
width: 66%;
}
.strong {
background: #579705;
color: white;
width: 100%;
}
</style>
<link type="text/css" href="<%=GetUrl("css/override.css") %>" rel="stylesheet" />
<style type="text/css">
:root {
<%=StyleVariables%>
}
</style>
<link href="<%=GetUrl("css/panel.css")%>" rel="stylesheet" type="text/css" />
<script src="<%=GetUrl("js/lib/utility.min.js")%>" type="text/javascript"></script>
<script src="<%=GetUrl("js/lib/ui.min.js")%>" type="text/javascript"></script>
<script src="<%=GetUrl("js/vue.min.js")%>"></script>
<script>Vue.config.productionTip = false; Vue.config.silent = true;</script>
<script src="<%=GetUrl("js/jquery-" + (JQueryVersion ?? "3.6.0") + ".min.js")%>" type="text/javascript"></script>
<script type="text/javascript" src="<%=GetUrl("js/sitebase.min.js") %>"></script>
<%--sitebase.min.js 包含cookie.js, utility.js, language.js, favorite.js, modulelang.js, usermessage.js--%>
<script type="text/javascript">
_network.root = '<%=Page.ResolveUrl("~/")%>';
var isReadonlyUser =<%=IsReadonlyUser?"true":"false"%>;
var canExport = <%= CanExportFile %>;
var userData;
var GridView = window['lib-ui'].Grid;
var appmoudulesdata;
function doLogout() {
$('#txtAction').val('logout');
$('#formAction').submit();
setCookie("ShowDealerLocations", "");
setCookie("ShowTraffic", "");
setCookie("ShowDealerLocations", "");
setCookie("WorkOrderFilters_" + '<%=CompanyID%>', "", -1);
}
function logout() {
if (typeof (_workspace) !== 'undefined') {
if (_workspace.changed && _utility.CanSaveAccessByPersonalIsVisableWhenLogout()) {
$alertdialog.showConfirm(DEFAULT_LANG.FIC,
GetLanguageByKey("LHBIS_FIC_SILVERLIGHT_WSP_WORKSPACEPAGE_A004", 'The Workspace setting defaults have changed, do you want to save the changes?'), [
[DEFAULT_LANG.cancel],
[DEFAULT_LANG.no, LogoutSaveLayout],
[DEFAULT_LANG.yes, LogoutSaveWorkspace]
]);
} else {
LogoutSaveLayout();
}
}
else {
doLogout();
}
}
function LogoutSaveWorkspace() {
_utility.doSaveWorkspace(doLogout);
}
function LogoutSaveLayout() {
_workspace.saveWorkspaceLayout(doLogout);
}
function changepassQuery(method, param, callback, error) {
_network.request("ChangePassword.aspx?tp=ashx", -1, method, param, callback, error);
}
//******************************Start Change Password********************************//
var iswrong = false;
function openChangePassword() {
iswrong = false;
$('#txt_old_pass').val('');
$('#txt_new_pass').val('');
$('#txt_new_pass2').val('');
$('#mask_bg').show();
$('#dialog_changepassword .dialog-title span.title').text(GetTextByKey("P_CHANGEPASSWORD", 'Change Password'));
//$('#mask_bg').show();
$('#dialog_changepassword')
.attr('act', 'edit')
.css({
'width': 400,
'top': (document.documentElement.clientHeight - $('#dialog_changepassword').height()) / 4,
'left': (document.documentElement.clientWidth - $('#dialog_changepassword').width()) / 2
})
.showDialogfixed(false);//参数为了兼容inspection页面
}
function CheckIfEmpty(val, errid) {
if (typeof val !== 'string' || val.length == 0) {
$(errid).text(GetTextByKey("P_CP_PLEASEENTERTHEPASSWORD", 'Please enter the password.')).show();
iswrong = true;
return false;
} else if (val[0] == ' ' || val[val.length - 1] == ' ') {
$(errid).text(GetTextByKey("P_CP_THEHEADANDTAILOFTHEPASSWORDCANNOTBESPACES", 'The head and tail of the password cannot be spaces.')).show();
iswrong = true;
return false;
} else {
$(errid).hide();
}
iswrong = false;
return true;
}
function CheckIfEmptyOrDismatch(val, v, errid) {
if (typeof val !== 'string' || val.length == 0) {
$(errid).text(GetTextByKey("P_CP_PLEASEENTERTHEPASSWORD", 'Please enter the password.')).show();
iswrong = true;
return false;
} else if (val != v) {
$(errid).text(GetTextByKey("P_CP_THEPASSWORDSYOUENTEREDDONOTMATCHCHECKYOURTYPINGANDTRYAGAIN", 'The passwords you entered do not match. Check your typing and try again.')).show();
iswrong = true;
return false;
} else {
$(errid).hide();
}
iswrong = false;
return true;
}
function CheckInfo(e) {
if (iswrong) {
// has errors;
return;
}
var oldpass = $('#txt_old_pass').val();
if (oldpass.length == 0) {
$('#old_pass_error').show();
$('#txt_old_pass').focus();
return false;
} else {
$('#old_pass_error').hide();
}
var newpass = $('#txt_new_pass').val();
if (!CheckIfEmpty(newpass, '#pass_error')) {
$('#txt_new_pass').focus();
return false;
}
var newpass2 = $('#txt_new_pass2').val();
if (!CheckIfEmptyOrDismatch(newpass2, newpass, '#pass_error2')) {
$('#txt_new_pass2').focus();
return false;
}
// strong test
if (newpass.length < 8) {
$('#pass_error').text(GetTextByKey("P_CP_PASSWORDTIPS", 'The password must be at least 8 characters.')).show();
iswrong = true;
}
if (!iswrong && getStrength(newpass) < 2) {
$('#pass_error').text(GetTextByKey("P_CP_PASSWORDTIPS1", 'The password must contain both uppercase and lowercase characters and at lease one number.')).show();
iswrong = true;
}
if (iswrong) {
$('#txt_new_pass').focus();
return false;
}
DoChangePassword(htmlencode(oldpass), htmlencode(newpass));
return true;
}
function enableUI(flag) {
$('#txt_old_pass').prop('disabled', !flag);
$('#txt_new_pass').prop('disabled', !flag);
$('#txt_new_pass2').prop('disabled', !flag);
$('#button_submit').prop('disabled', !flag);
}
function DoChangePassword(oldpass, newpass) {
enableUI(false);
changepassQuery('ChangePassword', oldpass + String.fromCharCode(170) + newpass, function (data) {
if (!data || data.length == 0) {
$('#old_pass_error').hide();
$('#txt_old_pass').val('');
$('#txt_new_pass').val('');
$('#txt_new_pass2').val('');
$('#pass_progress').attr('class', 'non').children('label').text(GetTextByKey("P_CP_PASSWORDSTRENGTH", 'Password strength'));
alert(GetTextByKey("P_CP_PASSWORDSUCCESSFULLYCHANGED", 'Password successfully changed.'));
enableUI(true);
$('#dialog_changepassword').hideDialog();
$('#mask_bg').hide();
} else {
enableUI(true);
//$('#pass_error2').text(data).show();
$('#old_pass_error').show();
$('#txt_old_pass').focus();
}
}, function (err) {
$('#pass_error2').text(GetTextByKey("P_CP_UNKNOWNERROROCCURS", 'Unknown error occurs.')).show();
enableUI(true);
});
}
function ChangeStrength() {
var pass = $(this).val();
if (typeof pass !== 'string' || pass.length == 0) {
$('#pass_progress').attr('class', 'non').children('label').text(GetTextByKey("P_CP_PASSWORDSTRENGTH", 'Password strength'));
} else if (pass.length < 6) {
$('#pass_progress').attr('class', 'weak').children('label').text(GetTextByKey("P_CP_WEAK", 'weak'));
} else {
var strength = getStrength(pass);
if (strength == 2) {
$('#pass_progress').attr('class', 'strong').children('label').text(GetTextByKey("P_CP_STRONG", 'strong'));
} else if (strength == 1) {
$('#pass_progress').attr('class', 'normal').children('label').text(GetTextByKey("P_CP_MEDIUM", 'medium'));
} else {
$('#pass_progress').attr('class', 'weak').children('label').text(GetTextByKey("P_CP_WEAK", 'weak'));
}
}
}
//***********************************End Change Password****************************************//
function GetLanguageByCookie() {
var lang = getCookie('<%=Common.LanguageCookieName%>');
if (lang == null) {
return "en-us";
} else {
return lang;
}
}
_fleet.currentLang = GetLanguageByCookie();
var UserMessageObj;
$(function () {
InitDBGridData();
if (typeof $.fn.applyFleetLanguageText === "function") {
$("#content").applyFleetLanguageText(true);
$("#host_main").applyFleetLanguageText(true);
$(".panel_holder").applyFleetLanguageText(true);
$("#dialog_favorite").applyFleetLanguageText(true);
$("#dialog_dashboards").applyFleetLanguageText(true);
$("#dialog_chartnotes").applyFleetLanguageText(true);
$("#divLeftTitle").applyFleetLanguageText(true);
}
$('#dialog_changepassword').dialog(function () {
$('#mask_bg').hide();
});
$('#dialog_dashboards').dialog(function () {
showmaskbg(false);
});
$('#dialog_chartnotes').dialog(function () {
$('#mask_bgcn').hide();
});
$('#txt_new_pass')
.bind('propertychange', ChangeStrength)
.bind('input', ChangeStrength)
.blur(function () {
var newpass = $(this).val();
CheckIfEmpty(newpass, '#pass_error');
});
$('#txt_new_pass2').blur(function () {
var newpass = $('#txt_new_pass').val();
var newpass2 = $(this).val();
CheckIfEmptyOrDismatch(newpass2, newpass, '#pass_error2');
});
$('#txt_old_pass').val('');
$('#button_submit').click(CheckInfo);
var failcount = 0;
function IAmAlive() {
_network.commonpagequery(0, '', function (data) {
failcount = 0;
setTimeout(IAmAlive, 5 * 60 * 1000);
}, function (err) {
if (err.status >= 400) {
failcount++;
if (failcount > 20) {
// logged out, refresh then it will go to the login page.
window.location = window.location;
} else {
//console.log(err);
setTimeout(IAmAlive, 15000);
}
}
}, true);
}
function getAppModules() {
var userid = '<%=UserID%>';
var companyid = '<%=CompanyID%>';
var modules = window.localStorage[companyid + "_" + userid + "_modules"];
if (modules && modules != '')
applyAppModules(JSON.parse(modules));
_network.mainpagequery("GetAppModules", "", function (data) {
if (typeof data === 'string') {
_dialog.showAlert(data, GetTextByKey("P_MODULE_GETAPPMODULES", 'Get AppModules'));
} else {
applyAppModules(data);
window.localStorage[companyid + "_" + userid + "_modules"] = JSON.stringify(data);
}
});
}
function applyAppModules(modules) {
setAppModulesLang(modules);
onInitSites(modules);
appmoudulesdata = modules;
onInitTitleSites();
refreshFavorites();
if (typeof showAppModules === 'function') {
showAppModules(modules);
}
if (typeof initMapMenuItems === 'function') {//map menu
initMapMenuItems(modules);
}
}
function getVersions() {
_network.mainpagequery("GetVersions", "", function (data) {
if (typeof data === 'string') {
//_dialog.showAlert(data, 'Get Versions');
} else {
if (data[0] && data[0] != "") {
$("#liVersion").show();
$("#aVersion").text(GetTextByKey("P_MAIN_VERSION_COLON", "Version: ") + data[0]);
}
if (data[0] && data[1] != "") {
$("#liFICVersion").show();
$("#aFICVersion").text(GetTextByKey("P_MAIN_FICVERSION_COLON", "FIC Version: ") + data[1]);
}
}
});
}
// init load sites panel
function onInitSites(data) {
if (data) {
var syspanel = $('<div class="panel_modules"></div>')
.css("max-height", $(window).height() - 120)
.css("float", 'left')
.mouseup(onopen);
var wsppanel = $('<div class="panel_modules"></div>')
.css("max-height", $(window).height() - 120)
.css("padding-left", 10)
.mouseup(onopen);
var titleFeatures = $("<div>" + GetTextByKey("P_MAIN_FEATURES", "Features") + "</div>").addClass("lefttitle_title").appendTo(syspanel);
var sysModules = $("<div class='div_modules'></div>").appendTo(syspanel);
var titleWSP = $("<div>" + GetTextByKey("P_MAIN_DASHBOARDS", "Dashboards") + "</div>").addClass("lefttitle_title").css("display", "none").appendTo(wsppanel);
var wspModules = $("<div class='div_modules'></div>").appendTo(wsppanel);
$('#sites_panel').empty().append(syspanel).append(wsppanel);
var ulFeatures = $('<ul class="lefttitlemenu_ul" style="line-height:32px;"></ul>');
sysModules.append(ulFeatures);
var ulWSP = $('<ul class="lefttitlemenu_ul" style="line-height:32px;"></ul>');
wspModules.append(ulWSP);
for (var i = 0; i < data.length; i++) {
var m = data[i];
if (!m.Visible) continue;
createMenuItem(m, (m.ModuleType == 0) ? ulFeatures : ulWSP);
if (m.ModuleType == 0) {
titleFeatures.show();
}
else if (m.ModuleType == 1) {
titleWSP.show();
}
}
//panel.append($('<div class="clear"></div>'))
$('#sites_panel')
.append('<div class="clear"></div>') // trigle
.append('<div class="trigle"></div>') // trigle
.append('<div class="trigle white"></div>');
}
}
function onopen(e) {
var etarget = $(e.target);
if (!etarget.is('.module')) {
etarget = etarget.parents('.module');
}
if (!etarget.length) {
return;
}
var m = etarget.data('m');
if (!m) {
return;
}
var url = m.Url.toLowerCase();
if (url.length > 4 && url.substring(0, 4) == 'http') {
} else if (url.length > 0 && url[0] == '/') {
} else {
url = _network.root + url;
}
if (m.OpenInNewWindow) {
window.open(url, "_blank");
} else {
window.location = url;
}
}
$(window).resize(null, function () {
$('#sites_panel .panel_modules').css("max-height", $(window).height() - 120);
$('#favorite_panel .panel_favorites').css("max-height", $(window).height() - 180);
})
function getUserInfo() {
$(".user").attr("src", _network.root + "titlelogo.ashx?tp=avatar&sn=" + Math.random());
_network.mainpagequery("GetUserData", "", function (data) {
//$("#spanUserName").text(GetTextByKey("P_MAIN_WELCOME", "Welcome, ") + data);
userData = data;
$("#btnuser").attr("title", userData.UserName);
$("#spanusername").text(userData.UserName);
});
}
getAppModules();
getUserInfo();
GetSiteHeaderNote();
getVersions();
$('#sites_panel').empty().html('<div class="panel_loading"></div>');
$("body").applyFleetLanguageText(true);
$('#button_sites').click(function () {
if ($('.panel_holder.sites').is(':visible')) {
return;
}
hidePanels();
$('.panel_holder.sites').css({
'opacity': 0,
'left': 60,
'right': 'auto'
}).show().animate({ 'opacity': 1 }, 100);
var left = $(this).offset().left;
var top = $(this).offset().top;
$('.panel_holder.sites .trigle').css({
'left': left + 48 - $('.panel_holder.sites').offset().left,
'right': 'auto',
'top': top - 60
});
$('.panel_holder.sites .white').css('left', left + 50 - $('.panel_holder.sites').offset().left);
$('#button_sites').addClass('selected');
return false;
});
//$('#button_fav').hide();
$('#button_fav').click(function () {
if (!navigate)
return;
setFavorate();
return false;
});
$('#button_favlist').click(function (ev) {
if ($('.panel_holder.favorites').is(':visible')) {
return;
}
hidePanels();
var left = $(this).offset().left;
var top = $(ev.target).offset().top;
$('.panel_holder.favorites').css({
'opacity': 0,
'left': 60,
'right': 'auto'
}).show().animate({ 'opacity': 1 }, 100);
$('.panel_holder.favorites .trigle').css({
'left': left + 48 - $('.panel_holder.favorites').offset().left,
'right': 'auto',
'top': top - 70
});
$('.panel_holder.favorites .white').css('left', left + 50 - $('.panel_holder.favorites').offset().left);
$('#button_favlist').addClass('selected');
return false;
});
$('#btnuser').click(function (ev) {
if ($('.panel_holder.usermenus').is(':visible')) {
return;
}
hidePanels();
var left = $(this).offset().left;
$('.panel_holder.usermenus').css({
'opacity': 0,
'left': left + $(this).width() - $('.panel_holder.usermenus').width(),
'right': 'auto'
}).show().animate({ 'opacity': 1 }, 100);
$('.panel_holder.usermenus .trigledown').css({
'left': left + $(this).width() - $('.panel_holder.usermenus').offset().left - 40,
'right': 'auto',
});
$('#userbutton_down').addClass('selected');
return false;
});
$('#button_menu').click(function () {
if ($('.panel_holder.menus').is(':visible')) {
return;
}
hidePanels();
var left = $(this).offset().left;
var top = $(this).offset().top;
$('.panel_holder.menus').css({
'opacity': 0,
'right': 'auto',
'left': 60//left - 71
}).show().animate({ 'opacity': 1 }, 100);
$('.panel_holder.menus .trigle').css({
'left': left + 48 - $('.panel_holder.menus').offset().left,
'right': 'auto',
'top': top - 60
});
$('.panel_holder.menus .white').css('left', left + 50 - $('.panel_holder.menus').offset().left);
$('#button_menu').addClass('selected');
return false;
});
$(document.body).click(function (e) {
var etarget = $(e.target);
//if (etarget.is('.button') || etarget.parent('.button').length)
// return;
hidePanels();
});
// I am alive.
var loc = window.location.href.toLowerCase();
if (loc.indexOf('/mapview.aspx') < 0 &&
loc.indexOf('/errorpage.aspx') < 0) {
setTimeout(IAmAlive, 30000);
}
function GetSiteHeaderNote() {
_network.mainpagequery("GetSiteHeaderNote", "", function (data) {
$("#preheadernote").text(data);
//$("#preheadernote").html(replaceHtmlText(data))
});
}
$('#ipt_dashboardfilter').keydown(function (e) {
if (e.keyCode == 13 || e.keyCode == 9) {
getDashboardList();
}
});
$(window).resize(function () {
$("#dashboardslist").css("height", 460 - $("#dashboardslist").offset().top - 4);
grid_dbdt && grid_dbdt.resize();
}).resize();
UserMessageObj = new UserMessage();
});
function openFleetChart(chartiid, chartname) {
if (!chartiid || chartiid == "")
return;
if (!$("#iffleetchart").attr("src")) {
$("#iffleetchart").attr("src", _network.root + "chart.aspx?iid=" + chartiid + "&n=" + htmlencode(chartname));
}
else {
execIframeFunc("changeChart", [chartiid, chartname], "iffleetchart");
}
$("#fleetchart").show();
}
function hideChartContainer() {
$("#fleetchart").hide();
}
function setChartFavorite(isFavorite, navigate) {
setFavoritesData(!isFavorite, navigate)
}
function UploadUserAvatar() {
var filectrl = $('<input type="file" style="display: none;" accept="image/png,image/jpg,image/jpeg" />');
filectrl.change(function () {
var files = this.files;
var img = files[0];
if (img.size == 0) {
alert(GetTextByKey("P_IPT_FILETIPS", "File size is 0kb, uploading failed."));
return false;
}
if (img.size > 1024 * 1024 * 2) {
alert(GetTextByKey("P_IPT_FILETIPS1", "File is too large. Maximum size is 2MB."));
return false;
}
$(".user").attr('src', window.URL.createObjectURL(img));
doUploadUserAvatar(img);
}).click();
}
function doUploadUserAvatar(avatarFile) {
var formData = new FormData();
formData.append("iconFile", avatarFile);
formData.append("MethodName", "UploadUserAvatar");
var url = _network.root + 'IronIntelMain.aspx?tp=ashx';
$.ajax({
url: url,
type: 'POST',
dataType: 'json',
processData: false,
contentType: false,
data: formData,
async: true,
success: function (data) {
},
error: function (err) {
_dialog.showAlert(GetTextByKey("P_MAIN_FAILEDTOUPLOADAVATAR", 'Failed to upload avatar.'), GetTextByKey("P_MAIN_UPLOADAVATAR", 'Upload avatar'));
}
});
}
</script>
<asp:ContentPlaceHolder ID="holder_head" runat="server"></asp:ContentPlaceHolder>
</head>
<body>
<div id="host_main">
<div id="host_header">
<%=Logo1 %>
<div class="headernote">
<pre id="preheadernote"></pre>
</div>
<%=Logo2 %>
<%=Logo3 %>
<div style="float: right;">
<%if (CanSeeUserMessage)
{
%>
<div id="iconmessage" class="spanbtn iconmessage" style="display: none; position: relative; float: left; margin-right: 5px; line-height: 55px; font-size: 20px;">
<div id="divunreadcount" style="position: absolute; right: 0; top: 8px; border-radius: 50%; line-height: 18px; width: 18px; height: 18px; background-color: #45b854; font-size: 12px;"></div>
</div>
<%} %>
<img class="user" id="btnuser" style="font-size: 16px; cursor: pointer; border-radius: 60px; width: 60px; height: 60px;" />
<%--<div class="button" style="line-height: 60px;">
<button id="userbutton_down" style="width: unset;"></button>
</div>--%>
</div>
</div>
</div>
<div id="divTitleBorder"></div>
<div id="divLeftTitle">
<div id="divhome" class="button" style="margin-top: 10px;" data-title-lgid="P_MAIN_HOME">
<a href="<%=ResolveUrl("~/IronIntelMain.aspx")%>" target="_self" style="color: black; text-decoration: none;">
<div class="titleicon">
<img id="button_home" class="titleimgicon" src="<%=ResolveUrl("~/img/modules/home.png?t=8")%>" />
</div>
</a>
</div>
<div id="divfav" class="button" style="width: 48px; display: none;" onclick="setFavorate(true)" data-title-lgid="P_MAIN_FAVORITE">
<div class="titleicon">
<img class="titleimgicon" src="<%=ResolveUrl("~/img/modules/favorites.png?t=0")%>" />
</div>
<%-- <span id="button_fav" class="favicon favmenu nofav"></span>
<span id="button_down" class="favmenu favmenudown" style="font-size: 1.8em; margin-left: 5px;"></span>--%>
</div>
<div id="divfavadd" class="button" style="width: 48px; display: none;" onclick="setFavorate(false)" data-title-lgid="P_MAIN_ADDFAVORITE">
<div class="titleicon">
<img class="titleimgicon" src="<%=ResolveUrl("~/img/modules/favoriteadd.png?t=0")%>" />
</div>
</div>
<div id="divfavmenu" class="button" style="width: 48px;" data-title-lgid="P_MYFAVORITES">
<div id="button_favlist" class="titleicon">
<img class="titleimgicon" src="<%=ResolveUrl("~/img/modules/favoritelist.png?t=0")%>" />
</div>
</div>
<div class="button" data-title-lgid="P_MAIN_FULLMENU">
<button id="button_sites" class="titleicon"></button>
</div>
<div class="button" data-title-lgid="P_MAIN_SETTINGS">
<button id="button_menu" class="titleicon setting"></button>
</div>
</div>
<div id="content" style="margin-top: 2px;">
<asp:ContentPlaceHolder ID="holder_content" runat="server"></asp:ContentPlaceHolder>
</div>
<div class="panel_holder favorites">
<div class="lefttitle_title" data-lgid="P_MYFAVORITES">My Favorites</div>
<div id="favorite_panel" class="panel" style="min-width: 250px;">
</div>
</div>
<div class="panel_holder sites">
<div id="sites_panel" class="menupanel panel"></div>
</div>
<div class="panel_holder menus">
<div class="lefttitle_title" data-lgid="P_MAIN_SETTINGS">Settings</div>
<div id="menu_panel" class="menupanel panel" style="min-width: 250px;">
<ul class="lefttitlemenu_ul">
<li class="flex" id="lisyssetting" data-url="<%=ResolveUrl("~/SystemSettings/SystemSettings.aspx")%>">
<div class="button setting" style="font-size: 24px"></div>
<span data-lgid="P_MAIN_SYSTEMSETTINGS">System Settings</span></li>
<li class="flex" id="liVersion" style="display: none; cursor: default; padding-left: 0">
<div></div>
<span id="aVersion"></span></li>
<li class="flex" id="liFICVersion" style="display: none; cursor: default; padding-left: 0">
<div></div>
<span id="aFICVersion"></span></li>
</ul>
<div class="trigle"></div>
<div class="trigle white"></div>
</div>
</div>
<div class="panel_holder usermenus">
<div id="usermenu_panel" class="panel" style="min-width: 200px;">
<ul class="lefttitlemenu_ul">
<li style="height: 70px; cursor: default;">
<table>
<tr>
<td>
<img class="user" style="font-size: 16px; cursor: pointer; border-radius: 60px; width: 60px; height: 60px;" onclick="UploadUserAvatar()" /></td>
<td style="vertical-align: bottom;"><span id="spanusername" style="margin-left: 10px;"></span></td>
</tr>
</table>
</li>
<li onclick="openChangePassword();" class="dynamicmenu flex">
<div>
<img style="width: 32px; height: 32px;" src='<%=ResolveUrl("~/img/modules/changepassword.png?t=0")%>' />
</div>
<span data-lgid="P_MAIN_CHANGEPASSWORD">Change Password</span>
</li>
<li onclick="logout();" class="dynamicmenu flex">
<div>
<img style="width: 32px; height: 32px;" src='<%=ResolveUrl("~/img/modules/logout.png?t=0")%>' />
</div>
<span data-lgid="P_MAIN_LOGOUT">Logout</span>
</li>
</ul>
<div class="trigledown"></div>
<div class="trigledown white"></div>
</div>
</div>
<%--<div class="maskbg" style="display: none;"></div>--%>
<form id="formAction" action="<%=ResolveUrl("~/commonpage.aspx")%>" method="post" style="display: none;">
<input type="hidden" id="txtAction" name="action" />
</form>
<div id="divmsgs" style="display: none; position: absolute; top: 60px; bottom: 0; right: 0; width: 400px; background-color: #f4f4f4; box-shadow: #CECACA -6px 0px 6px;">
<div style="padding: 5px 0 5px 10px;">
<span data-lgid="P_MAIN_MESSAGES" style="font-size: 18px; font-weight: bold;">Messages</span>
<em class="spanbtn icondelete" style="float: right; margin-right: 5px; margin-top: 0; font-size: 16px;" v-on:click="closeMessage()" data-title-lgid="P_MAIN_CLOSE"></em>
<em class="spanbtn icontrash" style="float: right; margin-right: 5px; margin-top: 0; font-size: 14px;" v-on:click="deleteMessage()" data-title-lgid="P_MAIN_REMOVE"></em>
<em class="spanbtn iconopentext" style="float: right; margin-right: 5px; margin-top: 0; font-size: 14px;" v-on:click="readMessage(null,$event)" data-title-lgid="P_MAIN_MARKASREAD"></em>
<em class="spanbtn iconrefresh" style="float: right; margin-right: 5px; margin-top: 0; font-size: 14px; display: none;" v-on:click="refreshMessage()" data-title-lgid="P_MAIN_REFRESHMESSAGES"></em>
</div>
<div style="clear: both;"></div>
<div style="line-height: 30px;">
<div style="margin-left: 10px;">
<input type="checkbox" id="chk_selallmessage" style="height: 26px;" v-on:change="selectAll($event)" /><label for="chk_selallmessage" data-lgid="P_MAIN_SELECTALL">Select All</label>
</div>
<div id="divmsgcontainer" style="overflow: auto; position: absolute; top: 60px; bottom: 0; width: 100%;">
<div v-bind:style="bodyContainerStyle" style="position: relative">
<div v-bind:style="bodyContentStyle" style="position: absolute; width: 100%;">
<div class='msgitem' v-for="msg in innerMessages" v-bind:class="msg.Readed ?'': 'unreadmsg'" v-on:click="readMessage(msg,$event)">
<div style="overflow: hidden; white-space: nowrap; text-overflow: ellipsis;">
<input type='checkbox' v-model="msg.Selected" /><a href='javascript:void(0);' v-on:click="linkClick(msg)" style="margin-left: 5px;">{{msg.LinkText}}</a>
</div>
<div style="margin-left: 26px; word-break: break-word;">
<div v-html="msg.Message"></div>
</div>
<div style="text-align: right;">
<span style="margin-left: 10px; font-size: 12px; float: left;">{{msg.CreatedTimeStr}}</span>
<em class="spanbtn iconopentext" style="display: none; margin-right: 5px; margin-top: 0; font-size: 12px;" v-on:click="readMessage(msg)"></em>
<em class="spanbtn icondelete" style="margin-right: 5px; margin-top: 0; font-size: 14px;" v-on:click="deleteMessage(msg)"></em>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div id="mask_bg" style="display: none;">
<div class="loading c-spin"></div>
</div>
<div class="dialog" id="dialog_favorite" style="display: none;">
<div class="dialog-title"><span class="title" data-lgid="P_FAV_EDITFAVORITES">Edit Favorites</span><em class="dialog-close"></em></div>
<div class="dialog-content">
<div id="favoritelist" style="height: 350px; width: 520px;"></div>
</div>
<div class="dialog-func">
<input type="button" value="Cancel" data-lgid="P_FAV_CANCEL" class="dialog-close" tabindex="12" style="height: unset;" />
<input type="button" id="btnfavsave" onclick="onSaveFavoriteSort();" value="Save" data-lgid="P_FAV_SAVE" tabindex="11" />
<div class="clear"></div>
</div>
<div id="favorites_mask_bg" class="maskbg" style="display: none;"></div>
</div>
<div class="dialog" id="dialog_changepassword" style="display: none; border-bottom: 0; border-top: 0;">
<div class="dialog-title"><span class="title" data-lgid="P_CHANGEPASSWORD">Change Password</span><em class="dialog-close"></em></div>
<div class="dialog-content" style="height: 340px;">
<div class="cp_form" style="margin-left: 30px;">
<div class="item_header" data-lgid="P_CP_USERID">User ID</div>
<div class="item_label"><%=HttpUtility.HtmlEncode(UserID)%></div>
<div class="item_header" data-lgid="P_CP_OLDPASSWORD">Old Password</div>
<div class="item_text">
<input type="password" id="txt_old_pass" name="oldpass" autocomplete="off" />
</div>
<div id="old_pass_error" class="item_error" style="display: none;" data-lgid="P_CP_THEOLDPASSWORDISWRONG">The old password is wrong.</div>
<div class="item_header" data-lgid="P_CP_NEWPASSWORD">New Password</div>
<div class="item_text">
<input type="password" id="txt_new_pass" name="newpass" autocomplete="off" />
</div>
<div class="item_strong">
<div id="pass_progress" class="non">
<label data-lgid="P_CP_PASSWORDSTRENGTH">Password strength</label>
</div>
</div>
<div id="pass_error" class="item_error" style="display: none;"></div>
<div class="item_header" data-lgid="P_CP_CONFIRMNEWPASSWORD">Confirm New Password</div>
<div class="item_text">
<input type="password" id="txt_new_pass2" name="newpass2" autocomplete="off" />
</div>
<div id="pass_error2" class="item_error" style="display: none;"></div>
</div>
</div>
<div class="dialog-func">
<input type="button" value="Cancel" data-lgid="P_MV_CANCEL" class="dialog-close" tabindex="12" />
<input type="button" id="button_submit" value="OK" data-lgid="P_CP_OK" tabindex="11" />
<div class="clear"></div>
</div>
</div>
<div class="dialog" id="dialog_dashboards" style="display: none; border-bottom: 0; border-top: 0;">
<div class="dialog-title"><span class="title" data-lgid="P_MAIN_REPORTSDASHBOARDS">Reports & Dashboards</span><em class="dialog-close"></em></div>
<div class="dialog-content" style="height: 500px;">
<input id="ipt_dashboardfilter" autocomplete="off" style="width: 300px;" />
<input class="search" type="button" onclick="getDashboardList();" value="" data-lgid="P_MA_SEARCH" />
<input id="ipt_charts_notes" type="radio" name="search_filter" value="charts_notes" checked="checked" /><label for="ipt_charts_notes" data-lgid="P_MAIN_CHARTSANDNOTES">Charts & Notes</label>
<input id="ipt_charts_only" type="radio" name="search_filter" value="charts" /><label for="ipt_charts_only" data-lgid="P_MAIN_CHARTSONLY">Charts Only</label>
<input id="ipt_notes_only" type="radio" name="search_filter" value="notes" /><label for="ipt_notes_only" data-lgid="P_MAIN_NOTESONLY">Notes Only</label>
<div class="clear"></div>
<div id="dashboardslist" style="margin-top: 5px;">
</div>
</div>
<div class="dialog-func">
<input type="button" value="Cancel" data-lgid="P_MV_CANCEL" class="dialog-close" tabindex="12" style="height: unset;" />
<input type="button" value="OK" data-lgid="P_CP_OK" onclick="openDashboard();" tabindex="11" />
<div class="clear"></div>
</div>
</div>
<div id="mask_bgcn" class="maskbg" style="display: none; z-index: 701;"></div>
<div class="dialog" id="dialog_chartnotes" style="display: none; border-bottom: 0; border-top: 0; padding-bottom: 6px; z-index: 702;">
<div class="dialog-title"><span class="title" data-lgid="P_MAIN_CHARTNOTES">Chart Notes</span><em class="dialog-close"></em></div>
<div class="dialog-content" style="padding: 0;">
<pre id="prechartnotes" style="height: 340px; margin: 5px; overflow-y: auto; overflow-wrap: break-word; white-space: pre-line; background-color: rgb(220, 221, 226); line-height: 1.3em;"></pre>
</div>
<div style="float: right;">
<input type="button" value="Close" data-lgid="P_CP_CLOSE" class="dialog-close" tabindex="11" style="width: unset; height: unset; margin-right: 5px;" />
<div class="clear"></div>
</div>
</div>
<div id="mask_bg_ds" class="maskbg" style="display: none; z-index: 100;">
<div class="loading c-spin"></div>
</div>
<div class="form non-select" id="dialog_ds" style="display: none; z-index: 101;">
<div class="form-head">
<div class="form-close fa"></div>
<div class="form-title"><span class="title" data-lgid="LHBIS_FIC_CLIENT_FICCONTROLS_PLUGINCTR_A003">Select Filter/Level Data Source Value</span></div>
</div>
<div class="dialog-content" style="height: 500px; width: 540px;">
<div id="content_flatds">
<table style="line-height: 20px; width: 100%;">
<tr>
<td data-lgid="LHBIS_FIC_CLIENT_FICCONTROLS_PLUGINCTR_A006">Available Values</td>
<td></td>
<td data-lgid="LHBIS_FIC_CLIENT_FICCONTROLS_PLUGINCTR_A007">Selected Values</td>
</tr>
<tr>
<td>
<div id="div_avas" style="height: 465px; width: 220px;"></div>
</td>
<td>
<div style="display: inline-grid;">
<input class="ctl_button" type="button" id="ctl_sel_add" style="margin-top: 5px; width: 70px" value=">" />
<input class="ctl_button" type="button" id="ctl_sel_addall" style="margin-top: 5px; width: 70px" value=">>" />
<input class="ctl_button" type="button" id="ctl_sel_remove" style="margin-top: 5px; width: 70px" value="<" />
<input class="ctl_button" type="button" id="ctl_sel_removeall" style="margin-top: 5px; width: 70px" value="<<" />
</div>
</td>
<td>
<div id="div_sels" style="height: 465px; width: 220px;"></div>
</td>
</tr>
</table>
</div>
<div id="content_treeds" style="height: 100%;">
<div class="treeds_content">
<ul id="ulDataSource"></ul>
</div>
</div>
</div>
<div class="form-func">
<input data-lgid="LHBIS_MultiLanguage_Common_A006" type="button" value="Cancel" class="form-close" tabindex="10" />
<input data-lgid="LHBIS_MULTILANGUAGE_LHBISMESSAGEBOX_A004" type="button" onclick="OnDSSelect();" value="OK" tabindex="9" />
<div class="clear"></div>
</div>
<div class="mask_loading dialog" style="display: none;">
<div class="loading_holder"></div>
</div>
</div>
<div id="fleetchart" style="left: 0; top: 0; right: 0; bottom: 0; position: absolute; display: none; background-color: white; z-index: 500;">
<iframe id="iffleetchart" style="width: 100%; height: 100%; display: block; border: none;"></iframe>
</div>
</body>
</html>