controllerClass())); foreach($classes as $class) { if($class != "Object") { $singleton = singleton($class); $manyManyRelations = $singleton->uninherited('many_many', true); if(isset($manyManyRelations) && array_key_exists($this->name, $manyManyRelations)) { $this->manyManyParentClass = $class; $manyManyTable = $class . '_' . $this->name; break; } $belongsManyManyRelations = $singleton->uninherited( 'belongs_many_many', true ); if( isset( $belongsManyManyRelations ) && array_key_exists( $this->name, $belongsManyManyRelations ) ) { $this->manyManyParentClass = $class; $manyManyTable = $belongsManyManyRelations[$this->name] . '_' . $this->name; break; } } } if(!$manyManyTable) user_error("I could not find the relation $this->name in " . $this->controllerClass() . " or any of its ancestors.",E_USER_WARNING); $tableClasses = ClassInfo::dataClassesFor($this->sourceClass); $source = array_shift($tableClasses); $sourceField = $this->sourceClass; if($this->manyManyParentClass == $sourceField) $sourceField = 'Child'; $parentID = $this->controller->ID; $this->sourceJoin .= " LEFT JOIN `$manyManyTable` ON (`$source`.`ID` = `{$sourceField}ID` AND `{$this->manyManyParentClass}ID` = '$parentID')"; $this->joinField = 'Checked'; if(isset($_REQUEST['ctf'][$this->Name()]['only_related'])) $this->OnlyRelated = $_REQUEST['ctf'][$this->Name()]['only_related']; $this->addPermission('only_related'); // If drag-and-drop is enabled, we need to turn on the only related filter if($this->ShowAll()) $this->OnlyRelated = '1'; } public function setParentClass($class) { parent::setParentClass($class); $this->joinField = "Checked"; } protected function loadSort() { if($this->ShowAll()) $this->setPageSize(999); if(SortableDataObject::is_sortable_many_many($this->sourceClass(), $this->controllerClass())) { list($parentClass, $componentClass, $parentField, $componentField, $table) = singleton($this->controllerClass())->many_many($this->Name()); $sort_column = "`$table`.SortOrder"; if(!isset($_REQUEST['ctf'][$this->Name()]['sort']) || $_REQUEST['ctf'][$this->Name()]['sort'] == $sort_column) { $this->sort = $sort_column; $this->sourceSort = "$sort_column " . SortableDataObject::$sort_dir; } } elseif($this->Sortable() && (!isset($_REQUEST['ctf'][$this->Name()]['sort']) || $_REQUEST['ctf'][$this->Name()]['sort'] == "SortOrder")) { $this->sort = "SortOrder"; $this->sourceSort = "SortOrder " . SortableDataObject::$sort_dir; } elseif(isset($_REQUEST['ctf'][$this->Name()]['sort'])) $this->sourceSort = $_REQUEST['ctf'][$this->Name()]['sort'] . " " . $this->sort_dir; } public function setOnlyRelated($bool) { if(!isset($_REQUEST['ctf'][$this->Name()]['only_related'])) $this->OnlyRelated = $bool; } public function OnlyRelated() { return self::$only_related !== null ? self::$only_related : $this->OnlyRelated; } public function getQueryString($params = array()) { $only_related = isset($params['only_related'])? $params['only_related'] : $this->OnlyRelated(); return parent::getQueryString($params)."&ctf[{$this->Name()}][only_related]={$only_related}"; } public function OnlyRelatedLink() { return $this->RelativeLink(array('only_related' => '1')); } public function AllRecordsLink() { return $this->RelativeLink(array('only_related' => '0')); } function getQuery($limitClause = null) { if($this->customQuery) { $query = $this->customQuery; $query->select[] = "{$this->sourceClass}.ID AS ID"; $query->select[] = "{$this->sourceClass}.ClassName AS ClassName"; $query->select[] = "{$this->sourceClass}.ClassName AS RecordClassName"; } else { $query = singleton($this->sourceClass)->extendedSQL($this->sourceFilter, $this->sourceSort, $limitClause, $this->sourceJoin); // Add more selected fields if they are from joined table. $SNG = singleton($this->sourceClass); foreach($this->FieldList() as $k => $title) { if(! $SNG->hasField($k) && ! $SNG->hasMethod('get' . $k)) $query->select[] = $k; } $parent = $this->controllerClass(); $if_clause = "IF(`{$this->manyManyParentClass}ID` IS NULL, '0', '1')"; $query->select[] = "$if_clause AS Checked"; if($this->OnlyRelated()) $query->where[] = $if_clause; } return clone $query; } function getParentIdName($parentClass, $childClass) { return $this->getParentIdNameRelation($parentClass, $childClass, 'many_many'); } function ExtraData() { $items = array(); foreach($this->unpagedSourceItems as $item) { if($item->{$this->joinField}) $items[] = $item->ID; } $list = implode(',', $items); $value = ","; $value .= !empty($list) ? $list."," : ""; $inputId = $this->id() . '_' . $this->htmlListEndName; $controllerID = $this->controller->ID; return << HTML; } public function Sortable() { return SortableDataObject::is_sortable_many_many($this->sourceClass()); } public function SortableClass() { return $this->controllerClass()."-".$this->sourceClass(); } } class ManyManyFileDataObjectManager_Item extends FileDataObjectManager_Item { function MarkingCheckbox() { $name = $this->parent->Name() . '[]'; $disabled = $this->parent->hasMarkingPermission() ? "" : "disabled='disabled'"; if($this->parent->IsReadOnly) return "item->ID}\" disabled=\"disabled\"/>"; else if($this->item->{$this->parent->joinField}) return "item->ID}\" checked=\"checked\" $disabled />"; else return "item->ID}\" $disabled />"; } } ?>