340 lines
15 KiB
Plaintext
340 lines
15 KiB
Plaintext
<%@ Page Title="" Language="C#" MasterPageFile="~/Security/Security.master" AutoEventWireup="true" CodeFile="AddCurfew.aspx.cs" Inherits="AddCurfew" %>
|
|
|
|
|
|
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="Server">
|
|
<style type="text/css">
|
|
::-ms-clear, ::-ms-reveal {
|
|
display: none;
|
|
}
|
|
|
|
.a {
|
|
text-decoration: none;
|
|
color: #2140fb;
|
|
}
|
|
|
|
.subtitle {
|
|
margin: 20px 40px 5px 0px;
|
|
font-size: 16px;
|
|
color: gray;
|
|
}
|
|
|
|
.subtitle span {
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.subtitle hr {
|
|
background-color: #d8d8d8;
|
|
border: none;
|
|
height: 1px;
|
|
}
|
|
|
|
|
|
.machinetd {
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.timespan {
|
|
margin-left: 26px;
|
|
margin-right: 8px;
|
|
}
|
|
</style>
|
|
|
|
<script src="<%=GetFileUrlWithVersion("js/controls.js")%>" type="text/javascript"></script>
|
|
<script type="text/javascript">
|
|
var IsDealer = <%=IsDealer ?"true":"false"%>;
|
|
var contractorid;
|
|
|
|
curfewquery = function (method, param, callback, error, nolog) {
|
|
_network.request("Security/AddCurfew.aspx", -1, method, param, callback, error || function (e) {
|
|
showAlert('Failed to load data: ' + e.statusText, GetTextByKey("P_CM_SCHEDULEASSETS", 'Schedule Assets'));
|
|
});
|
|
}
|
|
|
|
function setDays(days) {
|
|
$("#tdDays input").prop("checked", false);
|
|
if (days.indexOf(daysArray[0]) >= 0)
|
|
$("#chkSu").prop("checked", true);
|
|
if (days.indexOf(daysArray[1]) >= 0)
|
|
$("#chkMo").prop("checked", true);
|
|
if (days.indexOf(daysArray[2]) >= 0)
|
|
$("#chkTu").prop("checked", true);
|
|
if (days.indexOf(daysArray[3]) >= 0)
|
|
$("#chkWe").prop("checked", true);
|
|
if (days.indexOf(daysArray[4]) >= 0)
|
|
$("#chkTh").prop("checked", true);
|
|
if (days.indexOf(daysArray[5]) >= 0)
|
|
$("#chkFr").prop("checked", true);
|
|
if (days.indexOf(daysArray[6]) >= 0)
|
|
$("#chkSa").prop("checked", true);
|
|
}
|
|
|
|
var daysArray = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"];
|
|
function getDays() {
|
|
var days = "";
|
|
if ($("#chkSu").prop("checked"))
|
|
days += daysArray[0] + ",";
|
|
if ($("#chkMo").prop("checked"))
|
|
days += daysArray[1] + ",";
|
|
if ($("#chkTu").prop("checked"))
|
|
days += daysArray[2] + ",";
|
|
if ($("#chkWe").prop("checked"))
|
|
days += daysArray[3] + ",";
|
|
if ($("#chkTh").prop("checked"))
|
|
days += daysArray[4] + ",";
|
|
if ($("#chkFr").prop("checked"))
|
|
days += daysArray[5] + ",";
|
|
if ($("#chkSa").prop("checked"))
|
|
days += daysArray[6] + ",";
|
|
|
|
if (days.length > 0)
|
|
days = days.substr(0, days.length - 1);
|
|
return days;
|
|
}
|
|
|
|
function initControl(index) {
|
|
var c = $('#starttimehour_' + index);
|
|
for (var i = 0; i < 24; i++) {
|
|
if (i < 10)
|
|
c.append($("<option></option>").val("0" + i).text("0" + i))
|
|
else
|
|
c.append($("<option></option>").val(i).text(i))
|
|
}
|
|
c = $('#starttimeminute_' + index);
|
|
for (var i = 0; i < 60; i++) {
|
|
if (i < 10)
|
|
c.append($("<option></option>").val("0" + i).text("0" + i))
|
|
else
|
|
c.append($("<option></option>").val(i).text(i))
|
|
}
|
|
c = $('#endtimehour_' + index);
|
|
for (var i = 0; i < 24; i++) {
|
|
if (i < 10)
|
|
c.append($("<option></option>").val("0" + i).text("0" + i))
|
|
else
|
|
c.append($("<option></option>").val(i).text(i))
|
|
}
|
|
c = $('#endtimeminute_' + index);
|
|
for (var i = 0; i < 60; i++) {
|
|
if (i < 10)
|
|
c.append($("<option></option>").val("0" + i).text("0" + i))
|
|
else
|
|
c.append($("<option></option>").val(i).text(i))
|
|
}
|
|
|
|
}
|
|
var timeindex = 0;
|
|
function AddTimePeriod(type, time) {
|
|
timeindex++;
|
|
var tr_add = $('#tr_addtimepreiod');
|
|
var tr = $('<tr id="trtime_' + timeindex + '" class="trtimeperiod"></tr>');
|
|
var td1 = $('<td class="label" style="line-height: unset;">' + GetTextByKey("P_CM_STARTTIME_COLON", "Start Time:") + '</td>"');
|
|
var td2 = $('<td></td>');
|
|
var s_sel = $('<select id="starttimehour_' + timeindex + '" style="width: 48px;"></select><span style="font-weight: bold;"> : </span><select id="starttimeminute_' + timeindex + '" style="width: 48px;"></select>')
|
|
var e_sel = $('<span class="timespan">' + GetTextByKey("P_CM_ENDTIME_COLON", "End Time:") + '</span><select id="endtimehour_' + timeindex + '" style="width: 48px;"></select><span style="font-weight: bold;"> : </span><select id="endtimeminute_' + timeindex + '" style="width: 48px;"></select>');
|
|
var s_del = $('<span class="sbutton icondelete" onclick="DeleteTimePeriod(' + timeindex + ');"></span>');
|
|
td2.append(s_sel).append(e_sel).append(s_del);
|
|
tr.append(td1).append(td2);
|
|
tr_add.before(tr);
|
|
initControl(timeindex);
|
|
if (type == 1) {
|
|
$('#starttimehour_' + timeindex).val(time.BeginHours);
|
|
$('#starttimeminute_' + timeindex).val(time.BeginMinutes);
|
|
$('#endtimehour_' + timeindex).val(time.EndHours);
|
|
$('#endtimeminute_' + timeindex).val(time.EndMinutes);
|
|
}
|
|
}
|
|
|
|
function DeleteTimePeriod(index) {
|
|
var trs = $('.trtimeperiod');
|
|
if (trs && trs.length == 1) {
|
|
showAlert(GetTextByKey("P_CM_PERIODCANNOTBEEMPTY", "Period cannot be empty."), GetTextByKey("P_CM_DELETEPERIOD", 'Delete Period'));
|
|
return;
|
|
}
|
|
$('#trtime_' + index).remove();
|
|
}
|
|
|
|
function OnAdd() {
|
|
$('#dialog_title').val('');
|
|
$("#tdDays input").prop("checked", false);
|
|
$('#dialog_starttimehour').val('00');
|
|
$('#dialog_starttimeminute').val('00');
|
|
$('#dialog_endtimehour').val('00');
|
|
$('#dialog_endtimeminute').val('00');
|
|
$('#dialog_urlkey').focus();
|
|
$('.trtimeperiod').remove();
|
|
AddTimePeriod(2);
|
|
}
|
|
|
|
var curfewid;
|
|
function getCurfewInfo() {
|
|
curfewquery("GetCurfewInfo", contractorid + String.fromCharCode(170) + curfewid, function (data) {
|
|
if (typeof (data) === "string") {
|
|
showAlert(data, GetTextByKey("P_CM_ERROR", 'Error'));
|
|
return;
|
|
}
|
|
var curfew = data;
|
|
$('#dialog_title').val(curfew.Title);
|
|
setDays(curfew.Day);
|
|
|
|
var times = curfew.TimePeriods;
|
|
if (times) {
|
|
$('.trtimeperiod').remove();
|
|
for (var i = 0; i < times.length; i++) {
|
|
AddTimePeriod(1, times[i]);
|
|
}
|
|
}
|
|
|
|
}, function (err) {
|
|
console.log(err);
|
|
});
|
|
}
|
|
|
|
|
|
function OnEdit() {
|
|
getCurfewInfo();
|
|
}
|
|
|
|
function OnSave(exit) {
|
|
var item = {
|
|
'Title': $('#dialog_title').val().trim(),
|
|
'Day': getDays()
|
|
};
|
|
|
|
var alerttitle;
|
|
if (curfewid) {
|
|
item.Id = curfewid;
|
|
alerttitle = GetTextByKey("P_CM_EDITCURFEWCONFIGURATION", "Edit Curfew Configuration");
|
|
} else {
|
|
item.Id = "";
|
|
alerttitle = GetTextByKey("P_CM_ADDCURFEWCONFIGURATION", "Add Curfew Configuration");
|
|
}
|
|
if (!item.Title || item.Title.length == 0) {
|
|
showAlert(GetTextByKey("P_CM_TITLECANNOTBEEMPTY", 'Title cannot be empty.'), alerttitle);
|
|
return;
|
|
}
|
|
if (!item.Day || item.Day.length == 0) {
|
|
showAlert(GetTextByKey("P_CM_PLEASESELECTATLEASTONEDAY", 'Please select at least one day.'), alerttitle);
|
|
return;
|
|
}
|
|
|
|
var times = [];
|
|
var trs = $('.trtimeperiod');
|
|
if (trs.length == 0) {
|
|
showAlert(GetTextByKey("P_CM_PERIODCANNOTBEEMPTY", "Period cannot be empty."), alerttitle);
|
|
return;
|
|
}
|
|
for (var i = 0; i < trs.length; i++) {
|
|
var sels = $(trs[i]).find('select');
|
|
var time = {
|
|
'BeginHours': $(sels[0]).val(),
|
|
'BeginMinutes': $(sels[1]).val(),
|
|
'EndHours': $(sels[2]).val(),
|
|
'EndMinutes': $(sels[3]).val()
|
|
};
|
|
times.push(time);
|
|
}
|
|
|
|
item.TimePeriods = times;
|
|
|
|
showloading(true);
|
|
var param = JSON.stringify(item);
|
|
param = htmlencode(param);
|
|
curfewquery("SaveCurfew", contractorid + String.fromCharCode(170) + param, function (data) {
|
|
showloading(false);
|
|
if (typeof (data) === "string") {
|
|
var msg = data;
|
|
if (data === "The curfew title must be unique.")
|
|
msg = GetTextByKey("P_CM_THECURFEWTITLEMUSTBEUNIQUE", 'The curfew title must be unique.');
|
|
else if (data === "Period cannot be empty.")
|
|
msg = GetTextByKey("P_CM_PERIODCANNOTBEEMPTY", 'Period cannot be empty.');
|
|
else if (data === "End Time must be later than Start Time.")
|
|
msg = GetTextByKey("P_CM_ENDTIMEMUSTBELATERTHANSTARTTIME", 'End Time must be later than Start Time.');
|
|
|
|
showAlert(msg, GetTextByKey("P_CM_SAVECURFEWCONFIGURATION", 'Save Curfew Configuration'));
|
|
} else {
|
|
curfewid = data[0];
|
|
if (exit == 0)
|
|
showAlert(GetTextByKey("P_CM_SAVSUCCESSFULLY", "Saved successfully."), GetTextByKey("P_CM_SAVECURFEWCONFIGURATION", 'Save Curfew Configuration'));
|
|
if (exit == 1)
|
|
OnExit(exit);
|
|
}
|
|
}, function (err) {
|
|
showloading(false);
|
|
showAlert(GetTextByKey("P_CM_FAILEDTOSAVECURFEWCONFIGURATION", 'Failed to save curfew configuration.'), GetTextByKey("P_CM_SAVECURFEWCONFIGURATION", 'Save Curfew Configuration'));
|
|
});
|
|
}
|
|
|
|
function OnExit(type) {
|
|
window.parent.CloseDialog(type);
|
|
}
|
|
|
|
function init(cid, id) {
|
|
curfewid = id;
|
|
contractorid = cid;
|
|
OnAdd();
|
|
|
|
if (curfewid !== undefined && curfewid !== '') {
|
|
OnEdit();
|
|
}
|
|
}
|
|
|
|
$(function () {
|
|
init();
|
|
|
|
function resizeContent() {
|
|
$('#divcontent').css('height', $(window).height() - $('#divcontent').offset().top - 4);
|
|
}
|
|
|
|
window.onresize = resizeContent;
|
|
resizeContent();
|
|
});
|
|
|
|
</script>
|
|
</asp:Content>
|
|
<asp:Content ID="Content3" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
|
<div id="mask_bg" style="display: none;">
|
|
<div class="loading c-spin"></div>
|
|
</div>
|
|
<div>
|
|
<div class="function_title">
|
|
<span class="sbutton iconsave" onclick="OnSave(0);" data-lgid="P_CM_SAVE">Save</span>
|
|
<span class="sbutton iconsave" onclick="OnSave(1);" data-lgid="P_CM_SAVE1">Save and Exit</span>
|
|
<span class="sbutton iconexit" onclick="OnExit(0);" data-lgid="P_CM_SAVE2">Exit Without Saving</span>
|
|
</div>
|
|
<div class="clear"></div>
|
|
<div class="content_main" id="divcontent" style="overflow: auto;">
|
|
<div class="edit-content">
|
|
<div class="subtitle">
|
|
<span data-lgid="P_CM_CURFEWINFORMATION">Curfew Information</span>
|
|
<hr />
|
|
</div>
|
|
<table style="line-height: 40px;">
|
|
<tr>
|
|
<td class="label" style="line-height: unset;" data-lgid="P_CM_TITLE_COLON">Title:</td>
|
|
<td>
|
|
<input id="dialog_title" tabindex="2" maxlength="200" style="width: 280px;" /></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="label" style="line-height: unset;" data-lgid="P_CM_DAYS_COLON">Day(s):</td>
|
|
<td id="tdDays">
|
|
<input type="checkbox" id="chkSu" tabindex="3" style="width: auto; margin-left: 0px; margin-right: 2px;" class="middlechk" /><label for="chkSu" data-lgid="P_CM_SUNDAY">Sunday</label>
|
|
<input type="checkbox" id="chkMo" tabindex="4" style="width: auto; margin-left: 26px; margin-right: 2px;" class="middlechk" /><label for="chkMo" data-lgid="P_CM_MONDAY">Monday</label>
|
|
<input type="checkbox" id="chkTu" tabindex="5" style="width: auto; margin-left: 26px; margin-right: 2px;" class="middlechk" /><label for="chkTu" data-lgid="P_CM_TUESDAY">Tuesday</label>
|
|
<input type="checkbox" id="chkWe" tabindex="6" style="width: auto; margin-left: 26px; margin-right: 2px;" class="middlechk" /><label for="chkWe" data-lgid="P_CM_WEDNESDAY">Wednesday</label>
|
|
<input type="checkbox" id="chkTh" tabindex="7" style="width: auto; margin-left: 26px; margin-right: 2px;" class="middlechk" /><label for="chkTh" data-lgid="P_CM_THURSDAY">Thursday</label>
|
|
<input type="checkbox" id="chkFr" tabindex="8" style="width: auto; margin-left: 26px; margin-right: 2px;" class="middlechk" /><label for="chkFr" data-lgid="P_CM_FRIDAY">Friday</label>
|
|
<input type="checkbox" id="chkSa" tabindex="9" style="width: auto; margin-left: 26px; margin-right: 2px;" class="middlechk" /><label for="chkSa" data-lgid="P_CM_SATURDAY">Saturday</label>
|
|
</td>
|
|
</tr>
|
|
<tr id="tr_addtimepreiod">
|
|
<td class="label" style="line-height: unset;"></td>
|
|
<td><span class="sbutton iconadd" onclick="AddTimePeriod();" style="background-color: #f0f0f0;" data-lgid="P_CM_ADDPERIOD">Add Period</span></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</asp:Content>
|