Merge branch '2.5.x' of github.com:sourcefabric/Airtime into 2.5.x
This commit is contained in:
commit
b037bfdf97
|
@ -1112,35 +1112,36 @@ class Application_Model_Scheduler
|
||||||
|
|
||||||
$removedItems = CcScheduleQuery::create()->findPks($scheduledIds);
|
$removedItems = CcScheduleQuery::create()->findPks($scheduledIds);
|
||||||
|
|
||||||
//check to make sure all items selected are up to date
|
// This array is used to keep track of every show instance that was
|
||||||
foreach ($removedItems as $removedItem) {
|
// effected by the track deletion. It will be used later on to
|
||||||
|
// remove gaps in the schedule and adjust crossfade times.
|
||||||
|
$effectedInstanceIds = array();
|
||||||
|
|
||||||
|
foreach ($removedItems as $removedItem) {
|
||||||
$instance = $removedItem->getCcShowInstances($this->con);
|
$instance = $removedItem->getCcShowInstances($this->con);
|
||||||
|
$effectedInstanceIds[] = $instance->getDbId();
|
||||||
|
|
||||||
//check if instance is linked and if so get the schedule items
|
//check if instance is linked and if so get the schedule items
|
||||||
//for all linked instances so we can delete them too
|
//for all linked instances so we can delete them too
|
||||||
if (!$cancelShow && $instance->getCcShow()->isLinked()) {
|
if (!$cancelShow && $instance->getCcShow()->isLinked()) {
|
||||||
//returns all linked instances if linked
|
//returns all linked instances if linked
|
||||||
$ccShowInstances = $this->getInstances($instance->getDbId());
|
$ccShowInstances = $this->getInstances($instance->getDbId());
|
||||||
|
|
||||||
$instanceIds = array();
|
$instanceIds = array();
|
||||||
foreach ($ccShowInstances as $ccShowInstance) {
|
foreach ($ccShowInstances as $ccShowInstance) {
|
||||||
$instanceIds[] = $ccShowInstance->getDbId();
|
$instanceIds[] = $ccShowInstance->getDbId();
|
||||||
}
|
}
|
||||||
/*
|
$effectedInstanceIds = array_merge($effectedInstanceIds, $instanceIds);
|
||||||
* Find all the schedule items that are in the same position
|
|
||||||
* as the selected item by the user.
|
// Delete the same track, represented by $removedItem, in
|
||||||
* The position of each track is the same across each linked instance
|
// each linked show instance.
|
||||||
*/
|
|
||||||
$itemsToDelete = CcScheduleQuery::create()
|
$itemsToDelete = CcScheduleQuery::create()
|
||||||
->filterByDbPosition($removedItem->getDbPosition())
|
->filterByDbPosition($removedItem->getDbPosition())
|
||||||
->filterByDbInstanceId($instanceIds, Criteria::IN)
|
->filterByDbInstanceId($instanceIds, Criteria::IN)
|
||||||
->find();
|
->filterByDbId($removedItem->getDbId(), Criteria::NOT_EQUAL)
|
||||||
foreach ($itemsToDelete as $item) {
|
->delete($this->con);
|
||||||
if (!$removedItems->contains($item)) {
|
|
||||||
$removedItems->append($item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//check to truncate the currently playing item instead of deleting it.
|
//check to truncate the currently playing item instead of deleting it.
|
||||||
if ($removedItem->isCurrentItem($this->epochNow)) {
|
if ($removedItem->isCurrentItem($this->epochNow)) {
|
||||||
|
@ -1165,29 +1166,11 @@ class Application_Model_Scheduler
|
||||||
} else {
|
} else {
|
||||||
$removedItem->delete($this->con);
|
$removedItem->delete($this->con);
|
||||||
}
|
}
|
||||||
|
|
||||||
// update is_scheduled in cc_files but only if
|
|
||||||
// the file is not scheduled somewhere else
|
|
||||||
$fileId = $removedItem->getDbFileId();
|
|
||||||
// check if the removed item is scheduled somewhere else
|
|
||||||
$futureScheduledFiles = Application_Model_Schedule::getAllFutureScheduledFiles();
|
|
||||||
if (!is_null($fileId) && !in_array($fileId, $futureScheduledFiles)) {
|
|
||||||
$db_file = CcFilesQuery::create()->findPk($fileId, $this->con);
|
|
||||||
$db_file->setDbIsScheduled(false)->save($this->con);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Application_Model_StoredFile::updatePastFilesIsScheduled();
|
||||||
|
|
||||||
if ($adjustSched === true) {
|
if ($adjustSched === true) {
|
||||||
//get the show instances of the shows we must adjust times for.
|
foreach ($effectedInstanceIds as $instance) {
|
||||||
foreach ($removedItems as $item) {
|
|
||||||
|
|
||||||
$instance = $item->getDBInstanceId();
|
|
||||||
if (!in_array($instance, $showInstances)) {
|
|
||||||
$showInstances[] = $instance;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($showInstances as $instance) {
|
|
||||||
$this->removeGaps($instance);
|
$this->removeGaps($instance);
|
||||||
$this->calculateCrossfades($instance);
|
$this->calculateCrossfades($instance);
|
||||||
}
|
}
|
||||||
|
@ -1195,7 +1178,7 @@ class Application_Model_Scheduler
|
||||||
|
|
||||||
//update the status flag in cc_schedule.
|
//update the status flag in cc_schedule.
|
||||||
$instances = CcShowInstancesQuery::create()
|
$instances = CcShowInstancesQuery::create()
|
||||||
->filterByPrimaryKeys($showInstances)
|
->filterByPrimaryKeys($effectedInstanceIds)
|
||||||
->find($this->con);
|
->find($this->con);
|
||||||
|
|
||||||
foreach ($instances as $instance) {
|
foreach ($instances as $instance) {
|
||||||
|
|
Loading…
Reference in New Issue