import * as dartSass from 'sass';
import gulpSass from 'gulp-sass';
const sass = gulpSass(dartSass);
import gulp from 'gulp';
import gulpAutoPref from 'gulp-autoprefixer';
import sourcemaps from 'gulp-sourcemaps';
import rename from 'gulp-rename';
// Путь к основной папке scss
const mainPath = 'css/**/*.scss'
// Путь к основной папке с партиалами
const scssPartials = 'css/scss';
// Путь к папке с битрикс шаблоном сайта
const templatesPath = 'bitrix/templates/default/**/*.scss';
gulp.task('sass', function () {
return gulp.src(mainPath) // Найдем все .scss файлы
.pipe(sourcemaps.init())
.pipe(sass({
style: 'expanded',
}).on('error', sass.logError))
.pipe(gulpAutoPref([
"last 15 versions",
"not dead",
]))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest(file => file.base)) // Сохраняем css рядом с scss
});
gulp.task('bx-sass', function () {
return gulp.src(templatesPath) // Найдем все .scss файлы
.pipe(sourcemaps.init())
.pipe(sass({
loadPaths: [scssPartials], // Указываем дополнительные пути для поиска
style: 'expanded',
}).on('error', sass.logError))
.pipe(gulpAutoPref([
"last 15 versions",
"not dead",
]))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest(file => file.base)) // Сохраняем css рядом с scss
});
<div id="carouselExample" class="carousel slide">
<div class="carousel-inner">
<?php $menu = mysqli_query($link, "SELECT * FROM `menu` ORDER BY `id` DESC LIMIT 5");
$length = mysqli_num_rows($menu);
$i = 0; ?>
<div class="carousel-item active">
<div class="row">
<?php while ($card = mysqli_fetch_assoc($menu)) :
$i++;
// ДОБАВЛЯЕМ ВСЕ ТОВАРЫ
if ($i % 3 != 0 || $i == $length) {
include 'vendor/components/card-load.php';
} elseif ($i % 3 == 0) {
// ЕСЛИ НА СЛАЙДЕ 3 ТОВАРА, ТО ЗАКРЫВАЕМ ЕГО И ДЕЛАЕМ НОВЫЙ
include 'vendor/components/card-load.php';
echo '</div>
</div>
<div class="carousel-item">
<div class="row">';
}
// ЕСЛИ НА ОДНОМ СЛАЙДЕ МЕНЕЕ, ЧЕМ 3 ТОВАРА,
// ТО ДОБАВЛЯЕМ ПУСТУЮ КОЛОНКУ.
// ЧИСЛО СЛАЙДА ОТНИМАЕМ ОТ ОСТАТКА СЛАЙДА
// ПРИ ДЕЛЕНИИ И СРАВНИВАЕМ С $j.
// (СЛАЙДЕР БУДЕТ ВЫГЛЯДЕТЬ КОРРЕКТНО)
if ($i == $length && $length % 3 != 0) {
for ($j = 0; $j < 3 - ($i % 3); $j++) {
echo '<div class="col"></div>';
}
}
endwhile; ?>
</div>
</div>
</div>
<button class="carousel-control-prev" type="button" data-bs-target="#carouselExample" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
</button>
<button class="carousel-control-next" type="button" data-bs-target="#carouselExample" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
</button>
</div>
</div>
<div class="col">
<a href="card-info.php?id=<?= $card['id'] ?>" class="card">
<div class="card__img img">
<img src="<?= $card['img'] ?>" class="card-img-top" alt="<?= $card['img'] ?>">
</div>
<div class="card-body">
<h5 class="card-title"><?= $card['title'] ?></h5>
<p class="card-text"><?= $card['description'] ?></p>
</div>
<div class="card-footer">
<div class="row align-items-center">
<div class="col-5">
<p class="m-0"><?= $card['price'] ?> р.</p>
</div>
<object class="col">
<a href="#" class="btn btn-primary w-100">В корзину</a>
</object>
</div>
</div>
</a>
</div>
<svg width="180" height="167" viewBox="0 0 180 167" fill="none" xmlns="http://www.w3.org/2000/svg">
<g class="anim">
<path d="M126.203 63.7572C125.248 61.6869 126.152 59.2354 128.221 58.2805C130.291 57.3259 132.743 58.2294 133.699 60.2992C134.653 62.3675 133.749 64.8206 131.679 65.7747C129.609 66.7301 127.157 65.8262 126.203 63.7572ZM134.821 41.2773L29.8982 89.778L43.9743 120.291L148.895 71.7904L134.821 41.2773Z" fill="#3FD6B2" />
<path d="M107.737 72.5025C107.452 71.8852 106.722 71.6157 106.106 71.8994C105.489 72.1851 105.22 72.915 105.505 73.5314L112.456 88.6021L114.689 87.5724L107.737 72.5025Z" fill="#0F0F0F" />
<path d="M101.155 82.7588C100.87 82.1424 100.139 81.8741 99.5237 82.1573C98.907 82.4435 98.6369 83.1731 98.9218 83.7895L103.127 92.9054L105.362 91.8751L101.155 82.7588Z" fill="#0F0F0F" />
<path d="M91.8249 87.0627C91.5399 86.4463 90.8108 86.1765 90.194 86.4611C89.576 86.7462 89.3067 87.4757 89.5917 88.0929L93.7977 97.2088L96.0308 96.1786L91.8249 87.0627Z" fill="#0F0F0F" />
<path d="M82.4967 91.3649C82.2127 90.7492 81.482 90.4797 80.8656 90.7646C80.2484 91.0496 79.9795 91.7786 80.2644 92.395L84.4689 101.512L86.702 100.482L82.4967 91.3649Z" fill="#0F0F0F" />
<path d="M70.4208 89.7151C70.1362 89.0983 69.4055 88.8287 68.789 89.1129C68.1723 89.3982 67.9031 90.1285 68.1872 90.7449L75.14 105.815L77.3727 104.785L70.4208 89.7151Z" fill="#0F0F0F" />
<path d="M63.8396 99.9729C63.5555 99.3564 62.8252 99.0872 62.208 99.3714C61.5924 99.6563 61.3232 100.387 61.6077 101.003L65.8133 110.119L68.0449 109.09L63.8396 99.9729Z" fill="#0F0F0F" />
<path d="M54.5103 104.276C54.2254 103.66 53.4956 103.391 52.8791 103.675C52.2622 103.959 51.9926 104.69 52.2775 105.306L56.4836 114.423L58.7159 113.393L54.5103 104.276Z" fill="#0F0F0F" />
<path d="M45.1819 108.58C44.8974 107.964 44.1679 107.695 43.5498 107.979C42.935 108.263 42.6643 108.994 42.9503 109.61L47.1552 118.726L49.3863 117.697L45.1819 108.58Z" fill="#0F0F0F" />
</g>
<path d="M147.1 98.2161C147.619 98.4051 147.886 98.9791 147.697 99.498L144.617 107.954C144.428 108.473 143.854 108.741 143.335 108.552C142.816 108.363 142.548 107.789 142.737 107.27L145.476 99.753L137.959 97.0148C137.44 96.8257 137.173 96.2518 137.362 95.7329C137.551 95.2139 138.125 94.9465 138.644 95.1356L147.1 98.2161ZM66.1572 137.493C65.6383 137.304 65.3708 136.73 65.5599 136.211L68.6404 127.755C68.8295 127.236 69.4034 126.968 69.9223 127.157C70.4412 127.346 70.7087 127.92 70.5196 128.439L67.7813 135.956L75.2981 138.694C75.8171 138.883 76.0845 139.457 75.8954 139.976C75.7064 140.495 75.1325 140.763 74.6136 140.574L66.1572 137.493ZM147.18 100.062L66.9218 137.46L66.0771 135.647L146.335 98.2493L147.18 100.062Z" fill="#E8ECEF" />
<path d="M133.5 34V21" stroke="#0F0F0F" stroke-width="2" stroke-linecap="round" />
<path d="M138 35L142 27" stroke="#0F0F0F" stroke-width="2" stroke-linecap="round" />
<path d="M141 38.5L154 30" stroke="#0F0F0F" stroke-width="2" stroke-linecap="round" />
</svg>
$(document).on("click", ".products__card", (e) => {
const modalOverlay = document.querySelector(".products-popup");
let num = e.currentTarget.getAttribute("data-num");
// Число передаётся в функцию, чтоб показать конкретную инфу в popup
loadPopup(num);
setTimeout(() =>{
const modals = document.querySelectorAll(".products-popup__wrapper");
const target = document.querySelector(`[data-target="${num}"]`);
console.log(target);
modals.forEach((modal) => {
modal.classList.remove("popup__wrapper_active");
});
target.classList.add("popup__wrapper_active");
modalOverlay.classList.add("popup_active");
document.querySelector("body").classList.add("lock");
modalOverlay.addEventListener("click", (e) => {
if (e.target == modalOverlay || e.target.closest('.products-popup__close')) {
modalOverlay.classList.remove("popup_active");
document.querySelector("body").classList.remove("lock");
modals.forEach((modal) => {
modal.classList.remove("popup__wrapper_active");
});
}
});
}, 100);
});
const fioUrl = "https://jsonplaceholder.typicode.com/users";
const xhr = new XMLHttpRequest();
xhr.open("GET", fioUrl);
xhr.responseType = "json";
xhr.onload = function () {
console.log(xhr.response);
document.querySelector("#demo").innerHTML = toHtml(xhr.response);
};
xhr.send();
function toHtml(json) {
let html = "";
for (let k = 0; k < json.length; k++) {
const key = json[k];
html += `<tr>
<td>${key.id}</td>
<td>${key["name"]}</td>
<td>${key["username"]}</td>
<td>${key.email}</td>
<td>${key.address['street']} - ${key.address['suite']}</td>
<td>${key.phone}</td>
<td>${key.website}</td>
<td>${key.company['name']}</td>
</tr>`;
}
return html;
}
li:not(:last-child){ // margin будет работать для всех li, кроме последнего, тем самым убирая лишний отступ
margin-right:20px;
}