4,554
edits
| No edit summary Tag: Reverted | No edit summary Tags: Manual revert Reverted | ||
| Line 19: | Line 19: | ||
|              showArticleWrapper.css('display', 'block'); |              showArticleWrapper.css('display', 'block'); | ||
|              //  |              // Find all images within the clicked card | ||
|              var  |              var cardImages = []; | ||
|              var  |              for (var i = 1; i <= 5; i++) { | ||
|                 var imageClass = '.image' + i; | |||
|                 var imageElem = $(this).find(imageClass + ' img'); | |||
|                 if (imageElem.length) { | |||
|                     cardImages.push({ | |||
|                         link: $(this).find(imageClass + ' a').attr('href'), | |||
|                         src: imageElem.attr('src'), | |||
|                         alt: imageElem.attr('alt'), | |||
|                         caption: $(this).find('.caption' + imageClass).text() | |||
|                     }); | |||
|                 } | |||
|              } | |||
|              //  |              // Set up image toggle if more than one image is found | ||
|              if (cardImages.length > 1) { | |||
|                  setupImageToggle(cardImages); | |||
|              } |              } | ||
|              //  |              // Update the fixed column content with card information | ||
| 			var entryNumber = $(this).find('.entry-number').text(); | |||
| 			var title = $(this).find('.title').text(); | |||
| 			var people = $(this).find('.people').text(); | |||
| 			var type = $(this).find('.type').text(); | |||
| 			var entity = $(this).find('.entity').text(); | |||
| 			var discipline = $(this).find('.discipline').text(); | |||
| 			var subject = $(this).find('.subject').text(); | |||
| 			var description = $(this).find('.description').html(); | |||
| 			var reflection = $(this).find('.reflection').html(); | |||
| 			var quote = $(this).find('.quote').text(); | |||
| 			var modificationDate = $(this).find('.modification-date').text(); | |||
|              // Update the fixed column content |              // Update the fixed column content | ||
| 			$('#article-title').html('<p class="article-entry-number">' + entryNumber + '</p><p class="article-people">' + people + '</p>'); | |||
| 			$('#article-content').html( | |||
| 			    '<p class="article-title">' + title + '</p>' + | |||
| 			    '<p class="article-type">' + type + '</p>' + | |||
| 			    '<div class="article-metadata">' + | |||
| 			    '<div class="article-metadata-column">' + | |||
| 			    '<p class="article-metadata-label">Entity</p>' + | |||
| 			    '<p class="article-metadata-value">' + entity + '</p>' + | |||
| 			    '</div>' + | |||
| 			    '<div class="article-metadata-column">' + | |||
| 			    '<p class="article-metadata-label">Discipline</p>' + | |||
| 			    '<p class="article-metadata-value">' + discipline + '</p>' + | |||
| 			    '</div>' + | |||
| 			    '<div class="article-metadata-column">' + | |||
| 			    '<p class="article-metadata-label">Subject(s)</p>' + | |||
| 			    '<p class="article-metadata-value">' + subject + '</p>' + | |||
| 			    '</div>' + | |||
| 			    '</div>' + | |||
| 			    (image.src ? '<div class="article-images">' + | |||
| 			        '<p class="article-label-image">Image(s)</p>' + | |||
| 			        '<div class="article-image">' + getImageHtml(image) + | |||
| 			        '<div class="caption-image">' + image.caption + '</div></div>' + | |||
| 			        '</div>' : '') + | |||
| 			    (description ? '<p class="article-label-description">Description:</p>' + | |||
| 			        '<div class="article-description">' + formatParagraphs(description) + '</div>' : '') + | |||
| 			    (reflection ? '<p class="article-label-reflection">Reflection:</p>' + | |||
| 			        '<div class="article-reflection">' + formatParagraphs(reflection) + '</div>' : '') + | |||
| 			    (quote ? '<p class="article-label-quote">Quote:</p>' + | |||
| 			        '<div class="article-quote">“' + formatParagraphs(quote) + '”</div>' : '') + | |||
| 			    '<p class="article-label-modification-date">Added on</p>' + | |||
| 			    '<div class="article-modification-date">' + formatSimpleDate(modificationDate) + '</div>' | |||
| 			); | |||
|             function getImageHtml(image) { | |||
| 			    return '<div class="image-container">' + | |||
| 			               '<img src="' + image.src + '" alt="' + image.alt + '">' + | |||
| 			               '<div class="caption">' + image.caption + '</div>' + | |||
| 			           '</div>'; | |||
| 			} | |||
| 			function  | 			function formatParagraphs(text) { | ||
| 			    // Split the text into paragraphs and wrap each in a <span> | |||
| 			    var paragraphs = text.split('\n').filter(function (p) { return p.trim() !== '' }); | |||
| 			    return paragraphs.map(function (p) { return '<span>' + p.trim() + '</span>'; }).join(''); | |||
| 			} | |||
| 			function formatSimpleDate(inputDate) { | |||
| 			    // Remove spaces from the date string | |||
| 			    var dateWithoutSpaces = inputDate.replace(/\s/g, ''); | |||
| 			    // Assuming dateWithoutSpaces is in the format "XX XX XX" | |||
| 			    var formattedDate = dateWithoutSpaces.slice(0, 2) + '.' + dateWithoutSpaces.slice(2, 4) + '.' + dateWithoutSpaces.slice(4); | |||
| 			    return formattedDate; | |||
| 			} | 			} | ||
|              // Apply the fade-out effect to the #list element |              // Apply the fade-out effect to the #list element | ||
| Line 119: | Line 115: | ||
|              event.stopPropagation(); |              event.stopPropagation(); | ||
|          }); |          }); | ||
|         function setupImageToggle(images) { | |||
|             var currentIndex = 0; | |||
|             function toggleImage() { | |||
|                 currentIndex = (currentIndex + 1) % images.length; | |||
|                 var image = images[currentIndex]; | |||
|                 // Update image source and alt text | |||
|                 var articleImageContainer = $('#article-content').find('.article-image'); | |||
|                 articleImageContainer.find('img').attr('src', image.src).attr('alt', image.alt); | |||
|                 // Update the caption | |||
|                 articleImageContainer.find('.caption').text(image.caption); | |||
|             } | |||
|             // Attach click event to image for toggling | |||
|             $('#article-content').on('click', '.article-image img', function () { | |||
|                 toggleImage(); | |||
|             }); | |||
|         } | |||
|          // Attach a mousedown event listener to close the fixed column |          // Attach a mousedown event listener to close the fixed column | ||