Мне было поручено создать сменное веб-приложение, которое поможет моим нынешним сотрудникам отслеживать смены рабочих. Они дали мне веб-сайт StaffHub, на котором я должен смоделировать свое веб-приложение в соответствии с ним, в настоящее время работающее над частью календаря.
Календарь имеет три вида:
1. Ежемесячно
2. Еженедельно
3. Ежедневно
Согласно моим текущим навыкам уровня, над которыми я работал еженедельно.
Как только я закончу еженедельно, я перейду на Ежемесячно, а затем Ежедневно
Алгоритм календаря:
Разделите год на недели, в основном каждую неделю начинайте в понедельник с определенной даты. Сегодня 14.01.2009, так что до 20.01.2009 есть диапазон дней. В этом диапазоне дней вместе список пользователей составляет таблицу, в каждой строке таблицы есть 7 дней, которые имеют опцию выбора, которая имеет три варианта: «1-я смена», «2-я смена», «3-я смена» и «Выкл. " (выберите только для демонстрационных целей) . Для этого была создана таблица html, которая выполняет процедуру POST, в которой написано на PHP и Symfony 2.7, выбор опции выбора отправляется в бэкэнд и сохраняется в бэкэнде. Затем GET получает данные из бэкэнда.
Это внешний файл ветки:
calendar.html.twig
<script src="{{ asset('js/jquery.js') }}"></script>
<script src="{{ asset('js/jquery-ui.min.js') }}"></script>
<script src="{{ asset('js/moment.min.js') }}"></script>
<script src="{{ asset('js/moment-range.js') }}"></script>
<link href="{{ asset('css/jquery-ui.css') }}" rel="stylesheet" type="text/css" />
<script type="text/javascript">
$(document).ready(function() {
//GET funksioni
jsonObject = httpGet("http://localhost:8000/users/viewAll").split(',');
for(i=0;i<jsonObject.length;i++){
jsonObject[i]=jsonObject[i].replace('"',' ').replace('"',' ').replace('[',' ').replace(']',' ').trim();
}
testArray = jsonObject;
window['moment-range'].extendMoment(moment);
n = [...Array(7).keys()];
var curr = new Date; // get current date
var first = curr.getTime() - 1000*60*60*24*(curr.getDay()-1);
curr.setTime(first);
var lastDate = new Date;
lastDate.setTime(curr.getTime() + 1000*60*60*24*7);
$('#firstDay').val(moment(curr).format('MMM DD YYYY') + ' ' + moment(lastDate).format('MMM DD YYYY'));
var a = moment(curr);
var b = moment(lastDate);
var range = moment.range(a,b);
var daysOne = daysFromRange(range);
var headerData = [""];
$.each(daysOne,function(index,value){
daysOne[index] = moment(value).format('ddd DD YYYY');
headerData.push(daysOne[index]);
});
var data = [headerData]
for(i=0;i<testArray.length;i++){
data.push(templateArray(testArray,i));
}
$("#arrow-left").click(function () {
$(".container").empty();
$(".container").append("<div></div>");
curr.setTime(curr.getTime() - 1000*60*60*24*7);
lastDate.setTime(lastDate.getTime() - 1000*60*60*24*7);
var p = [];
$.each(daysFromRange(moment.range(curr,lastDate)),function(index,value){
p.push(moment(value).format('ddd DD MM YYYY'));
});
data[0] = [""]
$.each(p,function(index,value){
data[0].push(p[index]);
});
$.each($("table th"), function(i,e){
$(this).html(data[0][i]);
});
$('#firstDay').val(moment(curr).format('MMM DD YYYY') + ' ' + moment(lastDate).format('MMM DD YYYY'));
});
$("#arrow-right").click(function () {
$(".container").empty();
$(".container").append("<div></div>");
curr.setTime(curr.getTime() + 1000*60*60*24*7);
lastDate.setTime(lastDate.getTime() + 1000*60*60*24*7);
var p = [];
$.each(daysFromRange(moment.range(curr,lastDate)),function(index,value){
p.push(moment(value).format('ddd DD MM YYYY'));
});
data[0] = [""];
$.each(p,function(index,value){
data[0].push(p[index]);
});
$.each($("table th"), function(i,e){
$(this).html(data[0][i]);
});
$('#firstDay').val(moment(curr).format('MMM DD YYYY') + ' ' + moment(lastDate).format('MMM DD YYYY'));
});
console.log(data);
var table = makeTable($('#calendar-container'), data);
var firstTable = getTableInfoFromArray(getTableData(table));
var prevTable = firstTable;
$('select').change(function () {
currTable = getTableInfoFromArray(getTableData(table));
$.ajax({
type: 'POST',
url: '/saveCalendar',
//qit sen data duhet me bo
data: JSON.stringify(diffTables(currTable,prevTable)[0]),
dataType: 'json',
success: function (useremail) {
console.log(useremail);
},
error: function (xhr, status, err) {
console.log(xhr);
},
});
prevTable = currTable;
});
});
function daysFromRange(range){
var range = range;
var diff = range.diff('days');
var array = Array.from(range.by('days'));
array.splice(-1,1);
return array;
};
function templateArray(array,i){
var selectTag = "<select id='shift'>" +
"<option value='volvo' selected='selected'>Volvo</option>" +
"<option value='saab'>Saab</option>" +
"<option value='mercedes'>Mercedes</option>" +
"<option value='audi'>Audi</option>" +
"</select>";
return [array[i],selectTag,selectTag,selectTag,selectTag,selectTag,selectTag,selectTag];
};
function diffTables(tb,tc){
c = []; //stack for return values;
for(i = 0;i < tb.length ; i ++){
for(j = 0;j < tb[i].length;j++){
if( !arraysEqual(tb[i][j],tc[i][j])){
c.push(tb[i][j]);
}
}
}
return c;
}
function httpGet(theUrl)
{
var xmlHttp = new XMLHttpRequest();
xmlHttp.open( "GET", theUrl, false ); // false for synchronous request
xmlHttp.send( null );
return xmlHttp.responseText;
}
function arraysEqual(a1,a2) {
/* WARNING: arrays must not contain {objects} or behavior may be undefined */
return JSON.stringify(a1)==JSON.stringify(a2);
}
function makeTable(container,data){
var table = $("<table/>").addClass('CSSTableGenerator');
table.css("border","1");
$.each(data,function(rowIndex,r){
var row = $("<tr/>");
$.each(r , function(collIndex,c){
if(/<\/select>/.test(c)){
row.append($("<td/>").html(c));
}else{
row.append($("<t"+(rowIndex == 0 ? "h" : "d")+"/>").text(c));
};
});
table.append(row);
});
return container.append(table);
};
function appedTableColumn(table,rowData){
var lastRow = $('<tr/>').appendTo(table.find('tbody:last'));
$.each(rowData,function(collIndex,c){
lastRow.append($('<td/>'.text(c)));
});
};
function getTableData(table){
var data = [];
table.find('tr').each(function(rowIndex,r){
var cols = [];
$(this).find('td,th').each(function(colIndex,c){
if($(this).contents().is("select")){
cols.push($(this).contents("select").children("option:selected").val());
}else{
cols.push(c.textContent);
}
});
data.push(cols);
});
return data;
};
function updateTableData(table,data){
}
function getTableInfoFromArray(data){
var p = [];
for(i = 1;i < data.length;i++){
var d = [data[0]];
d.push(data[i]);
p.push(zip(d));
};
for(i=0;i<p.length;i++){
var user = p[i][0][1];
p[i].shift();
p[i].forEach(function(element){
element.push(user);
});
};
return p;
};
function zip(arrays) {
return arrays[0].map(function(_,i){
return arrays.map(function(array){return array[i]})
});
}
</script>
<style>
i {
border: solid black;
border-width: 0 3px 3px 0;
display: inline-block;
padding: 3px;
}
.right:hover { background:green;}
.left:hover { background:green;}
.calendar-selector-buttons{
width: 50px;
height: 50px;
}
.right {
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
}
.left {
transform: rotate(135deg);
-webkit-transform: rotate(135deg);
}
select{
margin: 0px;
width: 150px;
font-size: 16px;
border: 1px solid #ccc;
height: 34px;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
font-family: "Palatino";
}
textarea{
background-color: aliceblue;
margin: 25px;
margin-bottom: 0px;
margin-left: 35px;
border: 1px solid #888;
resize: none;
height: 30px;
width: 200px;
}
</style>
<div id='calendar-container'>
<div id='calendar-dates'>
<div id='calendar-selector-buttons'>
<div class ='arrow'><i class="arrow left" id="arrow-left"></i><i class="arrow right" id="arrow-right"></i><textarea id='firstDay'></textarea></div>
</div>
<div id='calendar-week-selector'>
<div class="container">
<div></div>
</div>
<div class="users"></div>
</div>
</div>
</div>
Бэкэнд PHP Symfony:
public function getCalendarAction(Request $request,$firstDate,$secondDate){
/*
select * from test
where date between '03/19/2014' and '03/19/2014 23:59:59'
// Qka duna me bo qitu
// Kejtsenet n databaze mi marr n baze te dates qi osht ne textarea
// P.sh Jun 03 2019 Jun 10 2019
// duhet memi kthy kejt schedule per qit date
// ne URL e shkruj daten, URL date enconding prej textare box e qes nGET request edhe
// query stringun e boj n baze dates
qito sene duna mi bo datetime mu pershtat me databaze
*/
$sql = "SELECT period,username FROM os_calendarshift where date(period) between date('".DateTime::createFromFormat('Y-m-d', $firstDate)->format('Y-m-d')."') and date('".DateTime::createFromFormat('Y-m-d', $secondDate)->format('Y-m-d')."');";
//Querying e kryva
//tash me kqyr me query databazen
$em = $this->getDoctrine()->getManager();
$q = $em->getConnection()->prepare($sql);
$q->execute();
$response = new JSONResponse($q->fetchAll());
$response->setStatusCode(200);
return $response;
}
Как обновить таблицу данных HTML.
Дата, возвращаемая из GET API, выглядит следующим образом:
[
{
"period": "2019-01-07 00:00:00",
"username": "gbinaku",
"shift": "audi"
},
{
"period": "2019-01-13 00:00:00",
"username": "gbinaku",
"shift": "audi"
},
{
"period": "2019-01-07 00:00:00",
"username": "abc123",
"shift": "audi"
},
{
"period": "2019-01-09 00:00:00",
"username": "ekransiqi",
"shift": "saab"
},
{
"period": "2019-01-11 00:00:00",
"username": "gbinaku",
"shift": "mercedes"
},
{
"period": "2019-01-11 00:00:00",
"username": "abc123",
"shift": "mercedes"
},
{
"period": "2019-01-09 00:00:00",
"username": "burim",
"shift": "audi"
},
{
"period": "2019-01-07 00:00:00",
"username": "albertina",
"shift": "saab"
},
{
"period": "2019-01-08 00:00:00",
"username": "kini",
"shift": "audi"
},
{
"period": "2019-01-10 00:00:00",
"username": "burim",
"shift": "mercedes"
},
{
"period": "2019-01-08 00:00:00",
"username": "cvb1",
"shift": "saab"
},
{
"period": "2019-01-07 00:00:00",
"username": "ragnar",
"shift": "mercedes"
},
{
"period": "2019-01-11 00:00:00",
"username": "cvb1",
"shift": "saab"
},
{
"period": "2019-01-12 00:00:00",
"username": "ragnar",
"shift": "audi"
},
{
"period": "2019-01-13 00:00:00",
"username": "teab",
"shift": "mercedes"
},
{
"period": "2019-01-07 00:00:00",
"username": "cvb1",
"shift": "audi"
}
]
Период, Имя пользователя и Сдвиг, однако, как мне обновить таблицу HTML соответственно из информации в ответе JSON.