Untitled

 avatar
unknown
plain_text
a year ago
4.1 kB
8
Indexable
<?php
// Array of carousel items with type defining the layout (image-content, content-only)
$carousels = [
    ['type' => 'image-content', 'image' => 'image1.jpg', 'content' => 'Content for carousel 1'],
    ['type' => 'content-only', 'image' => '', 'content' => 'Content for carousel 2'],
    ['type' => 'image-content', 'image' => 'image3.jpg', 'content' => 'Content for carousel 3'],
];

// Default settings if needed
$default_case = 'image-content'; // Can be 'image-content', 'content-only'

// Function to render the carousel item based on type
function render_carousel_item($carousel, $default_case) {
    $type = $carousel['type'] ?? $default_case; // Use default case if type is not set
    $image = $carousel['image'] ?? '';
    $content = $carousel['content'] ?? '';

    // Start carousel item container
    echo '<div class="carousel-item">';
    
    if ($type === 'image-content' && $image) {
        // Image on the left, content on the right
        echo '<div class="carousel-left">';
        echo '<img src="' . $image . '" alt="Carousel Image">';
        echo '</div>';
        echo '<div class="carousel-right">';
        echo '<p>' . $content . '</p>';
        echo '</div>';
    } elseif ($type === 'content-only') {
        // Expand content to cover the whole carousel area
        echo '<div class="carousel-full-content">';
        echo '<p>' . $content . '</p>';
        echo '</div>';
    } else {
        // Handle default case (image-content layout)
        if ($image) {
            echo '<div class="carousel-left">';
            echo '<img src="' . $image . '" alt="Carousel Image">';
            echo '</div>';
        }
        echo '<div class="carousel-right">';
        echo '<p>' . $content . '</p>';
        echo '</div>';
    }
    
    // End carousel item container
    echo '</div>';
}

// Begin carousel structure
echo '<div class="carousel-container">';
echo '<div class="carousel-items-wrapper">';

// Loop through each carousel and render
foreach ($carousels as $carousel) {
    render_carousel_item($carousel, $default_case);
}

echo '</div>';

// Add navigation buttons
echo '<button class="carousel-control prev">←</button>';
echo '<button class="carousel-control next">→</button>';

echo '</div>'; // End carousel-container
?>

<style>
.carousel-container {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.carousel-items-wrapper {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

.carousel-item {
    display: none;
    justify-content: space-between;
    width: 100%;
}

.carousel-left {
    width: 40%;
}

.carousel-left img {
    width: 100%;
    height: auto;
}

.carousel-right, .carousel-full-content {
    width: 100%;
    padding: 20px;
    background-color: #f0f0f0;
}

.carousel-right {
    width: 60%;
}

.carousel-full-content {
    width: 100%;
}

/* Navigation buttons */
.carousel-control {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 2;
}

.carousel-control.prev {
    left: 10px;
}

.carousel-control.next {
    right: 10px;
}
</style>

<script>
// Basic JavaScript to handle carousel navigation
document.addEventListener('DOMContentLoaded', function() {
    const items = document.querySelectorAll('.carousel-item');
    const nextButton = document.querySelector('.carousel-control.next');
    const prevButton = document.querySelector('.carousel-control.prev');
    let currentIndex = 0;

    function updateCarousel() {
        items.forEach((item, index) => {
            item.style.display = index === currentIndex ? 'flex' : 'none';
        });
    }

    nextButton.addEventListener('click', function() {
        currentIndex = (currentIndex + 1) % items.length; // Move to next item
        updateCarousel();
    });

    prevButton.addEventListener('click', function() {
        currentIndex = (currentIndex - 1 + items.length) % items.length; // Move to previous item
        updateCarousel();
    });

    // Initialize carousel
    updateCarousel();
});
</script>
Editor is loading...
Leave a Comment