<div id="otvet">
.tg {border-collapse:collapse;border-spacing:0;}
.tg td{border-color:black;border-style:solid;border-width:1px;font-family:Arial, sans-serif;font-size:14px;
overflow:hidden;padding:10px 5px;word-break:normal;}
.tg th{border-color:black;border-style:solid;border-width:1px;font-family:Arial, sans-serif;font-size:14px;
font-weight:normal;overflow:hidden;padding:10px 5px;word-break:normal;}
.tg .tg-s9fd{background-color:#E0FFE0;border-color:inherit;text-align:center;vertical-align:top}
.tg .tg-oqqy{background-color:#E0FFE0;border-color:inherit;font-weight:bold;text-align:center;vertical-align:top}
.tg .tg-l38m{background-color:#FFF;border-color:inherit;text-align:right;vertical-align:top}
.tg .tg-fyfk{background-color:#FFF;border-color:inherit;font-weight:bold;text-align:center;vertical-align:top}
.tg .tg-nbj5{background-color:#FFF;border-color:inherit;text-align:center;vertical-align:top}
.tg .tg-jxgv{background-color:#FFF;border-color:inherit;text-align:left;vertical-align:top}
.tg .tg-pdeq{background-color:#FFF;border-color:inherit;font-weight:bold;text-align:left;vertical-align:top}
.tg .tg-u0ix{background-color:#FFF;border-color:inherit;font-weight:bold;text-align:right;vertical-align:top}
.tg .tg-w5ex{background-color:#FFFBF0;border-color:inherit;text-align:left;vertical-align:top}
.tg .tg-g0qq{background-color:#FFFBF0;border-color:inherit;text-align:right;vertical-align:top}
.tg .tg-0pky{border-color:inherit;text-align:left;vertical-align:top}
.tg .tg-dvpl{border-color:inherit;text-align:right;vertical-align:top}
document.addEventListener('DOMContentLoaded', function() {
var responseData = [
{
"ШАПКА": [
{
"ТабНомер": "20511",
"Сотрудник": "Димаков Андрей Владиславович",
"Заголовок": "Ноябрь 2023",
"ОбщийОблагаемыйДоход": 236899.94,
"Должность": "техник ИВЦ ",
"Подразделение": "отдел 23. Группа проектирования и сопровождения информационных систем",
"Организация": "АО \"ПО \"СЕВЕР\"",
"КВыплате": 14297.23
}]
},
{
"НАЧИСЛЕНО": [
{
"ВидНачисления": "Оклад по чаcам",
"ПериодНачисления": "Ноябрь 2023",
"ОтработанныеДни": 16,
"ОтработанныеЧасы": 127.2,
"ОплаченныеДни": 0,
"ОплаченныеЧасы": 127.2,
"СуммаНачисления": 14150.24
},
{
"ВидНачисления": "Оплата отпуска по календарным дням",
"ПериодНачисления": "Ноябрь 2023",
"ОтработанныеДни": 0,
"ОтработанныеЧасы": 0,
"ОплаченныеДни": 5,
"ОплаченныеЧасы": 0,
"СуммаНачисления": 3398.9
},
{
"ВидНачисления": "ИСН",
"ПериодНачисления": "Ноябрь 2023",
"ОтработанныеДни": 0,
"ОтработанныеЧасы": 0,
"ОплаченныеДни": 0,
"ОплаченныеЧасы": 127.2,
"СуммаНачисления": 6846.89
},
{
"ВидНачисления": "Индексирующая выплата",
"ПериодНачисления": "Ноябрь 2023",
"ОтработанныеДни": 0,
"ОтработанныеЧасы": 0,
"ОплаченныеДни": 0,
"ОплаченныеЧасы": 127.2,
"СуммаНачисления": 1443.17
},
{
"ВидНачисления": "Районный коэффициент",
"ПериодНачисления": "Ноябрь 2023",
"ОтработанныеДни": 0,
"ОтработанныеЧасы": 0,
"ОплаченныеДни": 0,
"ОплаченныеЧасы": 0,
"СуммаНачисления": 5610.08,
"ВсегоНачислено": 31449.28
}]
},
{
"УДЕРЖАНО": [
{
"ВидУдержания": "НДФЛ исчисленный",
"ПериодУдержания": null,
"СуммаУдержания": 4088
},
{
"ВидУдержания": null,
"ПериодУдержания": null,
"СуммаУдержания": null
},
{
"ВидУдержания": null,
"ПериодУдержания": null,
"СуммаУдержания": null
},
{
"ВидУдержания": null,
"ПериодУдержания": null,
"СуммаУдержания": null
},
{
"ВидУдержания": null,
"ПериодУдержания": null,
"СуммаУдержания": null
},
{
"ВсегоУдержано": 4088
}]
},
{
"ВЫПЛАЧЕНО": [
{
"ВидВыплаты": "Отпускные (перечислено в банк)",
"ПериодВыплаты": "09.11.2023",
"СуммаВыплаты": 2956.9
},
{
"ВидВыплаты": "Зарплата (перечислено в банк)",
"ПериодВыплаты": "10.11.2023",
"СуммаВыплаты": 20066.91
},
{
"ВидВыплаты": "Аванс (перечислено в банк)",
"ПериодВыплаты": "24.11.2023",
"СуммаВыплаты": 10107.15
},
{
"ВсегоВыплачено": 33130.96
}]
},
{
"ПОДВАЛ": [
{
"СуммаДолгНаКонецПериода": 14297.23,
"СуммаДолгНаНачалоПериода": 20066.91
}]
}
];
const nachisleno = responseData.find(i => i.НАЧИСЛЕНО).НАЧИСЛЕНО;
const uderzhano = responseData.find(i => i.УДЕРЖАНО).УДЕРЖАНО;
const upperRows = function*(){
for (let i = 0; i < Math.max(nachisleno.length, uderzhano.length); i += 1) {
yield [ nachisleno[i] ?? {}, uderzhano[i] ?? {}, ];
}
};
var container = document.getElementById('otvet');
container.innerHTML = `
<table class="tg">
<tbody>
<tr>
<td class="tg-jxgv" colspan="8" style="border-style: none;"> </td>
<td class="tg-jxgv" colspan="7" style="border-style: none;"></td>
</tr>
<tr>
<td class="tg-oqqy" rowspan="2">Вид</td>
<td class="tg-s9fd" colspan="2" rowspan="2">Период</td>
<td class="tg-s9fd" colspan="2">Отработано</td>
<td class="tg-s9fd" colspan="2">Оплачено</td>
<td class="tg-s9fd" rowspan="2">Сумма</td>
<td class="tg-oqqy" colspan="3" rowspan="2">Вид</td>
<td class="tg-s9fd" colspan="2" rowspan="2">Период</td>
<td class="tg-s9fd" colspan="2" rowspan="2">Сумма</td>
</tr>
<tr>
<td class="tg-s9fd">Дни</td>
<td class="tg-s9fd">Часы</td>
<td class="tg-s9fd">Дни</td>
<td class="tg-s9fd">Часы</td>
</tr>
<tr>
<td class="tg-pdeq" colspan="8">1.Начислено</td>
<td class="tg-pdeq" colspan="7">2. Удержано</td>
</tr>
<!-- Чисто по циклу пройтись. <b>Вот на это стоит обратить внимание </b>-->
${Array.from(upperRows()).map(item => {
const видНачисления = item[0]["ВидНачисления"] || "";
const периодНачисления = item[0]["ПериодНачисления"] || "";
const отработанныеДни = item[0]["ОтработанныеДни"] || "";
const отработанныеЧасы = item[0]["ОтработанныеЧасы"] || "";
const оплаченныеДни = item[0]["ОплаченныеДни"] || "";
const оплаченныеЧасы = item[0]["ОплаченныеЧасы"] || "";
const суммаНачисления = item[0]["СуммаНачисления"] || "";
const видУдержания = item[1]["ВидУдержания"] || "";
const периодУдержания = item[1]["ПериодУдержания"] || "";
const суммаУдержания = item[1]["СуммаУдержания"] || "";
return `
<tr>
<td class="tg-jxgv">${видНачисления}</td>
<td class="tg-l38m" colspan="2">${периодНачисления}</td>
<td class="tg-l38m">${отработанныеДни}</td>
<td class="tg-l38m">${отработанныеЧасы}</td>
<td class="tg-l38m">${оплаченныеДни}</td>
<td class="tg-l38m">${оплаченныеЧасы}</td>
<td class="tg-l38m">${суммаНачисления}</td>
<td class="tg-jxgv" colspan="3">${видУдержания}</td>
<td class="tg-jxgv" colspan="2">${периодУдержания}</td>
<td class="tg-l38m" colspan="2">${суммаУдержания}</td>
</tr>
`;
}).join('')}
<!-- Конец цикла -->
<td class="tg-jxgv" colspan="7">Всего начислено</td>
<td class="tg-l38m">31 449,28</td>
<td class="tg-jxgv" colspan="5">Всего удержано</td>
<td class="tg-l38m" colspan="2">4 088,00</td>
</tr>
<tr>
<td class="tg-pdeq">3. Доходы в натуральной форме</td>
<td class="tg-pdeq" colspan="2"></td>
<td class="tg-pdeq"></td>
<td class="tg-pdeq"></td>
<td class="tg-pdeq"></td>
<td class="tg-pdeq"></td>
<td class="tg-pdeq"></td>
<td class="tg-pdeq" colspan="7">4. Выплаченные суммы</td>
</tr>
<tr>
<td class="tg-jxgv"> </td>
<td class="tg-l38m" colspan="2"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-jxgv" colspan="3">Аванс (перечислено в банк)</td>
<td class="tg-l38m"
colspan="2">24.11.23</td>
<td class="tg-l38m" colspan="2">10 107,15</td>
</tr>
<tr>
<td class="tg-jxgv"> </td>
<td class="tg-l38m" colspan="2"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-jxgv" colspan="3">Зарплата (перечислено в банк)</td>
<td class="tg-l38m" colspan="2">10.11.23</td>
<td class="tg-l38m" colspan="2">20 066,91</td>
</tr>
<tr>
<td class="tg-jxgv"> </td>
<td class="tg-l38m" colspan="2"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-l38m"> </td>
<td class="tg-jxgv" colspan="3">Отпускные (перечислено в банк)</td>
<td class="tg-l38m" colspan="2">09.11.23</td>
<td class="tg-l38m" colspan="2">2 956,90</td>
</tr>
<tr>
<td class="tg-jxgv" colspan="7">Всего натуральных доходов</td>
<td class="tg-l38m"> </td>
<td class="tg-jxgv" colspan="5">Всего выплат</td>
<td class="tg-l38m" colspan="2">33 130,96</td>
</tr>
</tbody>
</table>
`;
//console.log(responseData);
});
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.