Logo rights 'D'-bate could cost DMACC or Drake University over $250,000
Logo rights 'D'-bate could cost DMACC or Drake University over $250,000
*** debate over the letter D could cost either Drake University or Des Moines Area Community College hundreds of thousands of dollars. If *** judge agrees *** court-ordered rebrand at DMAC is more costly than originally ruled. We're asking for $250,000 rather than $25,000. In November, *** judge said the two schools' logos were nearly identical and temporarily barred DMAC from using this logo. Since then, the community. Says it has spent thousands removing the logo before their December 13th deadline. DMA has 13 locations across central Iowa. We have over 35,000 students. We have over 60 buildings, 500 classrooms, and public spaces, so it's *** pretty significant effort to get all of those changed out. But acknowledges that some things take more than 21 days to remove. One of the biggest items is our basketball court. That basketball court was actually installed before our rebranding, but it does have *** block. on it and for the safety of the players, we need to wait until the season is over to make any changes to that. Now Drake University is accusing DMAC of not complying with the order. Its lawyers filed the motion Monday mentioning uses on men's basketball uniforms, student IDs, and billboards after the deadline. But now DMAC says that court decision is underestimating the extensive work and cost of removing all uses. They filed their own motion Friday that would force Drake to reimburse. The $250,000 instead of $25,000 for rebranding if the community college wins the lawsuit. Despite ongoing battles, Drake says in part that they value DMAC as *** long-standing partner, the sentiment DMAC says they reflect. We've just always viewed Drake as *** partner, and we're looking forward to moving past this and focusing on our students and preserving that partnership. Pepper Paura, KCCI 8 News, Iowa's news leader.
Logo rights 'D'-bate could cost DMACC or Drake University over $250,000
Updated: 10:00 AM CST Dec 30, 2024
Editorial Standards ⓘ
Des Moines Area Community College claims a court-ordered temporary rebrand will cost more than ten times the original estimate in a logo rights lawsuit against the college.Drake University sued DMACC in July, alleging the school's logo was too similar to its own and violated copyright law. In November, a judge called the branding "nearly identical" and barred DMACC from using their "D" logo until a final ruling could be made in the case.The decision also set a deadline to remove all usage before Dec. 13, with the stipulation that Drake University would DMACC $25,000 as reimbursement for removing the logo if the community college won the lawsuit. DMACC VP of Student Affairs Erica Spiller told KCCI on Friday the school is working tirelessly to remove the logo from all uses as quickly as possible, but feels the decision underestimates the time and effort required to rebrand and is asking the court to increase how much Drake will be liable to pay."DMACC has 13 locations across central Iowa. We have over 35,000 students. We have over 60 buildings, 500 classrooms and public spaces. So it's a pretty significant effort to get all of those changed out," Spiller said. "We now know that the cost is much more than that to comply with that preliminary injunction, so we're asking for $250,000 rather than the $25,000." This request is on the heels of a complaint from Drake accusing DMACC of continuing to use the logo after the court deadline to stop. If DMACC loses the suit, it will be liable for all rebranding costs.
DES MOINES, Iowa —
Des Moines Area Community College claims a court-ordered temporary rebrand will cost more than ten times the original estimate in a logo rights lawsuit against the college.
Drake University sued DMACC in July, alleging the school's logo was too similar to its own and violated copyright law. In November, a judge called the branding "nearly identical" and barred DMACC from using their "D" logo until a final ruling could be made in the case.
The decision also set a deadline to remove all usage before Dec. 13, with the stipulation that Drake University would DMACC $25,000 as reimbursement for removing the logo if the community college won the lawsuit.
DMACC VP of Student Affairs Erica Spiller told KCCI on Friday the school is working tirelessly to remove the logo from all uses as quickly as possible, but feels the decision underestimates the time and effort required to rebrand and is asking the court to increase how much Drake will be liable to pay.
"DMACC has 13 locations across central Iowa. We have over 35,000 students. We have over 60 buildings, 500 classrooms and public spaces. So it's a pretty significant effort to get all of those changed out," Spiller said. "We now know that the cost is much more than that to comply with that preliminary injunction, so we're asking for $250,000 rather than the $25,000."
This request is on the heels of a complaint from Drake accusing DMACC of continuing to use the logo after the court deadline to stop. If DMACC loses the suit, it will be liable for all rebranding costs.
`;
}
function refreshWeatherIframe(containerId) {
var iframeId = 'weather-iframe-' + containerId;
var iframe = document.getElementById(iframeId);
if (iframe && iframe.src) {
var originalSrc = iframe.src;
iframe.src = originalSrc + (originalSrc.indexOf('?') > -1 ? '&' : '?') + 't=' + Date.now();
}
}
function initializeWeatherBox(container) {
var containerId = container.getAttribute('data-container-id');
var isWeatherBoxV2 = containerId === 'home-weather-v2';
function switchWeatherTab(tabName, clickedElement) {
container.querySelectorAll('[data-tab-id]').forEach(function(tab) {
tab.classList.remove('open');
tab.setAttribute('aria-selected', 'false');
});
clickedElement.classList.add('open');
clickedElement.setAttribute('aria-selected', 'true');
container.querySelectorAll('[data-content-id]').forEach(function(content) {
content.style.display = 'none';
content.setAttribute('hidden', 'true');
});
var targetContent = container.querySelector('[data-content-id="' + tabName + '"]');
if (targetContent) {
targetContent.style.display = 'block';
targetContent.removeAttribute('hidden');
}
}
function loadWeatherData() {
// If weather data is already being loaded, wait for it
if (window.weatherDataPromise) {
window.weatherDataPromise.then(function(data) {
if (data && data.data) {
var weatherContainer = container.closest('.weather-box-container');
if (weatherContainer) {
weatherContainer.style.display = 'flex';
updateCurrentWeather(data.data);
updateForecastTabs(data.data);
updateWeatherAlertsBar(data.data);
}
}
});
return;
}
var location = { zip: window.DEFAULT_ZIPCODE };
try {
var storedLocations = localStorage.getItem('hrst.zip.history');
if (storedLocations) {
var locations = JSON.parse(storedLocations);
if (locations && locations.length > 0) {
location = locations[0];
}
}
} catch (e) {}
var apiUrl = (window.DEWY_HOSTNAME || '') + '/api/v1/weather/full/' + location.zip;
if (window.fetch) {
window.weatherDataPromise = fetch(apiUrl)
.then(function(response) { return response.json(); })
.then(function(data) {
if (data && data.data) {
var article = container.closest('.article--wrapper');
var weatherContainer = container.closest('.weather-box-container');
if (weatherContainer) {
weatherContainer.style.display = 'flex';
updateCurrentWeather(data.data);
updateForecastTabs(data.data);
updateWeatherAlertsBar(data.data);
}
return data;
}
})
.catch(function(error) {
console.error('Error loading weather:', error);
// Reset to unknown background on error
updateWeatherBackground('unknown');
});
}
}
function updateWeatherAlertsBar(weatherData) {
var weatherWatchHeader = container.querySelector('.weather-watch-header');
if (weatherWatchHeader && weatherData.alerts_count > 0) {
weatherWatchHeader.className = 'weather-watch-header has-alerts';
var weatherWatchText = weatherWatchHeader.querySelector('.weather-watch-text');
var weatherWatchLink = weatherWatchHeader.querySelector('.weather-watch-link');
if (weatherWatchText) {
weatherWatchText.textContent = `Weather Alerts (${weatherData.alerts_count})`;
}
if (weatherWatchLink) {
weatherWatchLink.setAttribute('onclick', "return handleWeatherLinkClick(event, 'click_alerts', 'click', 'mobile-weather', '/alerts');");
}
}
}
function updateCurrentWeather(weatherData) {
if (weatherData.current) {
var tempValue = weatherData.current.temp_f || '';
var skyValue = weatherData.current.sky || '';
var feelsLikeValue = weatherData.current.feels_like_f || weatherData.current.temp_f || '';
var tempEl = container.querySelector('.weather-grid--current-temp-value');
if (tempEl) {
tempEl.textContent = tempValue;
tempEl.setAttribute('aria-label', tempValue + ' degrees Fahrenheit');
}
var iconEl = container.querySelector('.weather-grid--current-icon');
if (iconEl && weatherData.current.icon_name) {
iconEl.className = 'weather-grid--current-icon weather-current-icon icon icon-weather-' + weatherData.current.icon_name;
}
var skyEl = container.querySelector('.weather-grid--sky');
if (skyEl) {
skyEl.textContent = skyValue;
skyEl.setAttribute('aria-label', 'Current condition: ' + skyValue);
}
var feelsEl = container.querySelector('.weather-grid--feels');
if (feelsEl) {
feelsEl.textContent = feelsLikeValue + '°F';
feelsEl.setAttribute('aria-label', feelsLikeValue + ' degrees Fahrenheit');
}
var weatherContainer = container.querySelector('.weather-temp-container');
if (weatherContainer) {
var summary = 'Current temperature ' + tempValue + ' degrees Fahrenheit, ' +
skyValue + ', feels like ' + feelsLikeValue + ' degrees';
weatherContainer.setAttribute('aria-label', summary);
}
updateWeatherBackground(weatherData.current.icon_name);
}
}
function updateWeatherBackground(iconName) {
try {
var bgPath = weatherImages.backgrounds[iconName] || weatherImages.backgrounds.unknown;
container.style.backgroundImage = 'url(' + bgPath + ')';
} catch (e) {
console.log('Error updating weather background:', e);
}
}
function updateForecastTabs(weatherData) {
var visibleItems = isWeatherBoxV2 ? 6 : 5;
if (weatherData.hourly) {
var hourlyContainer = container.querySelector('.weather-hourly-forecast');
if (hourlyContainer) {
var html = '';
var maxHours = Math.min(visibleItems, weatherData.hourly.length);
for (var i = 0; i < maxHours; i++) {
var hour = weatherData.hourly[i];
html += generateForecastItem({
timeLabel: hour.hour_display,
iconName: hour.icon_name,
primaryTemp: hour.temp_f,
secondaryInfo: hour.precip_chance + '%'
});
}
hourlyContainer.innerHTML = html;
}
}
if (weatherData.daily) {
var dailyContainer = container.querySelector('.weather-daily-forecast');
if (dailyContainer) {
var html = '';
var maxDays = Math.min(visibleItems, weatherData.daily.length);
for (var i = 0; i < maxDays; i++) {
var day = weatherData.daily[i];
var dayName = getShortDayName(day.day);
html += generateForecastItem({
timeLabel: dayName,
iconName: day.icon_name,
primaryTemp: day.high_f,
secondaryInfo: day.precip_chance + '%'
});
}
dailyContainer.innerHTML = html;
}
}
}
function getShortDayName(dayName) {
switch (dayName) {
case 'Today':
return 'Today';
case 'Tomorrow':
return 'Tmrw';
case 'Sunday':
return 'Sun';
case 'Monday':
return 'Mon';
case 'Tuesday':
return 'Tue';
case 'Wednesday':
return 'Wed';
case 'Thursday':
return 'Thu';
case 'Friday':
return 'Fri';
case 'Saturday':
return 'Sat';
default:
return dayName;
}
}
container.querySelectorAll('[data-tab-id]').forEach(function(tab) {
var isActive = tab.classList.contains('open');
tab.setAttribute('tabindex', '0'); // Both tabs focusable for VoiceOver
tab.setAttribute('role', 'tab');
tab.setAttribute('aria-selected', isActive);
tab.addEventListener('keydown', function(e) {
var tabs = Array.from(container.querySelectorAll('[data-tab-id]'));
var currentIndex = tabs.indexOf(this);
switch(e.key) {
case 'ArrowLeft':
e.preventDefault();
var prevIndex = currentIndex > 0 ? currentIndex - 1 : tabs.length - 1;
tabs[prevIndex].focus();
break;
case 'ArrowRight':
e.preventDefault();
var nextIndex = currentIndex < tabs.length - 1 ? currentIndex + 1 : 0;
tabs[nextIndex].focus();
break;
case 'Enter':
case ' ':
e.preventDefault();
var tabId = this.getAttribute('data-tab-id');
switchWeatherTab(tabId, this);
if (tabId === 'hourly') {
dispatchWeatherGA4Event('click_hourly', 'click', containerId);
} else if (tabId === 'daily') {
dispatchWeatherGA4Event('click_daily', 'click', containerId);
}
break;
}
});
tab.onclick = function() {
var tabId = this.getAttribute('data-tab-id');
switchWeatherTab(tabId, this);
if (tabId === 'hourly') {
dispatchWeatherGA4Event('click_hourly', 'click', containerId);
} else if (tabId === 'daily') {
dispatchWeatherGA4Event('click_daily', 'click', containerId);
}
return false;
};
});
loadWeatherData();
window.addEventListener('pageshow', function(event) {
if (event.persisted) {
// Fix for weather radar iframe appearing gray after browser back/forward navigation
// When user navigates back, the page loads from browser cache but the iframe
// content doesn't restore properly, showing a gray screen instead of the radar map
// This forces a fresh reload of the iframe by adding a timestamp parameter
setTimeout(function() {
refreshWeatherIframe(containerId);
}, 300);
}
});
}
document.querySelectorAll('.weather-sidebar').forEach(function(weatherBox) {
initializeWeatherBox(weatherBox);
});
document.addEventListener('fullscreenchange', function() {
var fullscreenElement = document.fullscreenElement;
if (!fullscreenElement) {
document.querySelector('.weather-box-container').querySelectorAll('.fa-times').forEach(function(icon) {
icon.classList.remove('fa-times');
icon.classList.add('fa-expand');
});
}
});
});
`;
}
function refreshWeatherIframe(containerId) {
var iframeId = 'weather-iframe-' + containerId;
var iframe = document.getElementById(iframeId);
if (iframe && iframe.src) {
var originalSrc = iframe.src;
iframe.src = originalSrc + (originalSrc.indexOf('?') > -1 ? '&' : '?') + 't=' + Date.now();
}
}
function initializeWeatherBox(container) {
var containerId = container.getAttribute('data-container-id');
var isWeatherBoxV2 = containerId === 'home-weather-v2';
function switchWeatherTab(tabName, clickedElement) {
container.querySelectorAll('[data-tab-id]').forEach(function(tab) {
tab.classList.remove('open');
tab.setAttribute('aria-selected', 'false');
});
clickedElement.classList.add('open');
clickedElement.setAttribute('aria-selected', 'true');
container.querySelectorAll('[data-content-id]').forEach(function(content) {
content.style.display = 'none';
content.setAttribute('hidden', 'true');
});
var targetContent = container.querySelector('[data-content-id="' + tabName + '"]');
if (targetContent) {
targetContent.style.display = 'block';
targetContent.removeAttribute('hidden');
}
}
function loadWeatherData() {
// If weather data is already being loaded, wait for it
if (window.weatherDataPromise) {
window.weatherDataPromise.then(function(data) {
if (data && data.data) {
var weatherContainer = container.closest('.weather-box-container');
if (weatherContainer) {
weatherContainer.style.display = 'flex';
updateCurrentWeather(data.data);
updateForecastTabs(data.data);
updateWeatherAlertsBar(data.data);
}
}
});
return;
}
var location = { zip: window.DEFAULT_ZIPCODE };
try {
var storedLocations = localStorage.getItem('hrst.zip.history');
if (storedLocations) {
var locations = JSON.parse(storedLocations);
if (locations && locations.length > 0) {
location = locations[0];
}
}
} catch (e) {}
var apiUrl = (window.DEWY_HOSTNAME || '') + '/api/v1/weather/full/' + location.zip;
if (window.fetch) {
window.weatherDataPromise = fetch(apiUrl)
.then(function(response) { return response.json(); })
.then(function(data) {
if (data && data.data) {
var article = container.closest('.article--wrapper');
var weatherContainer = container.closest('.weather-box-container');
if (weatherContainer) {
weatherContainer.style.display = 'flex';
updateCurrentWeather(data.data);
updateForecastTabs(data.data);
updateWeatherAlertsBar(data.data);
}
return data;
}
})
.catch(function(error) {
console.error('Error loading weather:', error);
// Reset to unknown background on error
updateWeatherBackground('unknown');
});
}
}
function updateWeatherAlertsBar(weatherData) {
var weatherWatchHeader = container.querySelector('.weather-watch-header');
if (weatherWatchHeader && weatherData.alerts_count > 0) {
weatherWatchHeader.className = 'weather-watch-header has-alerts';
var weatherWatchText = weatherWatchHeader.querySelector('.weather-watch-text');
var weatherWatchLink = weatherWatchHeader.querySelector('.weather-watch-link');
if (weatherWatchText) {
weatherWatchText.textContent = `Weather Alerts (${weatherData.alerts_count})`;
}
if (weatherWatchLink) {
weatherWatchLink.setAttribute('onclick', "return handleWeatherLinkClick(event, 'click_alerts', 'click', 'sidelist-weather', '/alerts');");
}
}
}
function updateCurrentWeather(weatherData) {
if (weatherData.current) {
var tempValue = weatherData.current.temp_f || '';
var skyValue = weatherData.current.sky || '';
var feelsLikeValue = weatherData.current.feels_like_f || weatherData.current.temp_f || '';
var tempEl = container.querySelector('.weather-grid--current-temp-value');
if (tempEl) {
tempEl.textContent = tempValue;
tempEl.setAttribute('aria-label', tempValue + ' degrees Fahrenheit');
}
var iconEl = container.querySelector('.weather-grid--current-icon');
if (iconEl && weatherData.current.icon_name) {
iconEl.className = 'weather-grid--current-icon weather-current-icon icon icon-weather-' + weatherData.current.icon_name;
}
var skyEl = container.querySelector('.weather-grid--sky');
if (skyEl) {
skyEl.textContent = skyValue;
skyEl.setAttribute('aria-label', 'Current condition: ' + skyValue);
}
var feelsEl = container.querySelector('.weather-grid--feels');
if (feelsEl) {
feelsEl.textContent = feelsLikeValue + '°F';
feelsEl.setAttribute('aria-label', feelsLikeValue + ' degrees Fahrenheit');
}
var weatherContainer = container.querySelector('.weather-temp-container');
if (weatherContainer) {
var summary = 'Current temperature ' + tempValue + ' degrees Fahrenheit, ' +
skyValue + ', feels like ' + feelsLikeValue + ' degrees';
weatherContainer.setAttribute('aria-label', summary);
}
updateWeatherBackground(weatherData.current.icon_name);
}
}
function updateWeatherBackground(iconName) {
try {
var bgPath = weatherImages.backgrounds[iconName] || weatherImages.backgrounds.unknown;
container.style.backgroundImage = 'url(' + bgPath + ')';
} catch (e) {
console.log('Error updating weather background:', e);
}
}
function updateForecastTabs(weatherData) {
var visibleItems = isWeatherBoxV2 ? 6 : 5;
if (weatherData.hourly) {
var hourlyContainer = container.querySelector('.weather-hourly-forecast');
if (hourlyContainer) {
var html = '';
var maxHours = Math.min(visibleItems, weatherData.hourly.length);
for (var i = 0; i < maxHours; i++) {
var hour = weatherData.hourly[i];
html += generateForecastItem({
timeLabel: hour.hour_display,
iconName: hour.icon_name,
primaryTemp: hour.temp_f,
secondaryInfo: hour.precip_chance + '%'
});
}
hourlyContainer.innerHTML = html;
}
}
if (weatherData.daily) {
var dailyContainer = container.querySelector('.weather-daily-forecast');
if (dailyContainer) {
var html = '';
var maxDays = Math.min(visibleItems, weatherData.daily.length);
for (var i = 0; i < maxDays; i++) {
var day = weatherData.daily[i];
var dayName = getShortDayName(day.day);
html += generateForecastItem({
timeLabel: dayName,
iconName: day.icon_name,
primaryTemp: day.high_f,
secondaryInfo: day.precip_chance + '%'
});
}
dailyContainer.innerHTML = html;
}
}
}
function getShortDayName(dayName) {
switch (dayName) {
case 'Today':
return 'Today';
case 'Tomorrow':
return 'Tmrw';
case 'Sunday':
return 'Sun';
case 'Monday':
return 'Mon';
case 'Tuesday':
return 'Tue';
case 'Wednesday':
return 'Wed';
case 'Thursday':
return 'Thu';
case 'Friday':
return 'Fri';
case 'Saturday':
return 'Sat';
default:
return dayName;
}
}
container.querySelectorAll('[data-tab-id]').forEach(function(tab) {
var isActive = tab.classList.contains('open');
tab.setAttribute('tabindex', '0'); // Both tabs focusable for VoiceOver
tab.setAttribute('role', 'tab');
tab.setAttribute('aria-selected', isActive);
tab.addEventListener('keydown', function(e) {
var tabs = Array.from(container.querySelectorAll('[data-tab-id]'));
var currentIndex = tabs.indexOf(this);
switch(e.key) {
case 'ArrowLeft':
e.preventDefault();
var prevIndex = currentIndex > 0 ? currentIndex - 1 : tabs.length - 1;
tabs[prevIndex].focus();
break;
case 'ArrowRight':
e.preventDefault();
var nextIndex = currentIndex < tabs.length - 1 ? currentIndex + 1 : 0;
tabs[nextIndex].focus();
break;
case 'Enter':
case ' ':
e.preventDefault();
var tabId = this.getAttribute('data-tab-id');
switchWeatherTab(tabId, this);
if (tabId === 'hourly') {
dispatchWeatherGA4Event('click_hourly', 'click', containerId);
} else if (tabId === 'daily') {
dispatchWeatherGA4Event('click_daily', 'click', containerId);
}
break;
}
});
tab.onclick = function() {
var tabId = this.getAttribute('data-tab-id');
switchWeatherTab(tabId, this);
if (tabId === 'hourly') {
dispatchWeatherGA4Event('click_hourly', 'click', containerId);
} else if (tabId === 'daily') {
dispatchWeatherGA4Event('click_daily', 'click', containerId);
}
return false;
};
});
loadWeatherData();
window.addEventListener('pageshow', function(event) {
if (event.persisted) {
// Fix for weather radar iframe appearing gray after browser back/forward navigation
// When user navigates back, the page loads from browser cache but the iframe
// content doesn't restore properly, showing a gray screen instead of the radar map
// This forces a fresh reload of the iframe by adding a timestamp parameter
setTimeout(function() {
refreshWeatherIframe(containerId);
}, 300);
}
});
}
document.querySelectorAll('.weather-sidebar').forEach(function(weatherBox) {
initializeWeatherBox(weatherBox);
});
document.addEventListener('fullscreenchange', function() {
var fullscreenElement = document.fullscreenElement;
if (!fullscreenElement) {
document.querySelector('.weather-box-container').querySelectorAll('.fa-times').forEach(function(icon) {
icon.classList.remove('fa-times');
icon.classList.add('fa-expand');
});
}
});
});
Loading more articles...