From 508f1ed430272bf5263f9eebd27db2cb4a6e2c27 Mon Sep 17 00:00:00 2001 From: unclecheese Date: Thu, 21 Jan 2016 12:44:19 +1300 Subject: [PATCH] ENHANCEMENT: Don't apply bootstrap templates if the user has already customsed. --- code/BootstrapFieldList.php | 45 ++++++++++++++++++++++--------------- 1 file changed, 27 insertions(+), 18 deletions(-) diff --git a/code/BootstrapFieldList.php b/code/BootstrapFieldList.php index be1b3cc..0a01f0c 100644 --- a/code/BootstrapFieldList.php +++ b/code/BootstrapFieldList.php @@ -17,6 +17,8 @@ class BootstrapFieldList extends Extension { public function bootstrapify() { foreach($this->owner as $f) { + $sng = Injector::inst()->get($f->class, true, ['dummy', '']); + if(isset($this->ignores[$f->getName()])) continue; // If we have a Tabset, bootstrapify all Tabs @@ -29,27 +31,34 @@ public function bootstrapify() { $f->Fields()->bootstrapify(); } - $template = "Bootstrap{$f->class}_holder"; - if(SSViewer::hasTemplate($template)) { - $f->setFieldHolderTemplate($template); - } - else { - $f->setFieldHolderTemplate("BootstrapFieldHolder"); - } - - foreach(array_reverse(ClassInfo::ancestry($f)) as $className) { - $bootstrapCandidate = "Bootstrap{$className}"; - $nativeCandidate = $className; - if(SSViewer::hasTemplate($bootstrapCandidate)) { - $f->setTemplate($bootstrapCandidate); - break; + // If the user has customised the holder template already, don't apply the default one. + if($sng->getFieldHolderTemplate() == $f->getFieldHolderTemplate()) { + $template = "Bootstrap{$f->class}_holder"; + if(SSViewer::hasTemplate($template)) { + $f->setFieldHolderTemplate($template); } - elseif(SSViewer::hasTemplate($nativeCandidate)) { - $f->setTemplate($nativeCandidate); - break; + else { + $f->setFieldHolderTemplate("BootstrapFieldHolder"); } + } + + // If the user has customised the field template already, don't apply the default one. + if($sng->getTemplate() == $f->getTemplate()) { + foreach(array_reverse(ClassInfo::ancestry($f)) as $className) { + $bootstrapCandidate = "Bootstrap{$className}"; + $nativeCandidate = $className; + if(SSViewer::hasTemplate($bootstrapCandidate)) { + $f->setTemplate($bootstrapCandidate); + break; + } + elseif(SSViewer::hasTemplate($nativeCandidate)) { + $f->setTemplate($nativeCandidate); + break; + } + + } } } @@ -67,4 +76,4 @@ public function bootstrapIgnore($field) { return $this->owner; } -} \ No newline at end of file +}