mirror of
https://github.com/silverstripe/silverstripe-subsites
synced 2024-10-22 11:05:55 +02:00
Merge pull request #334 from creative-commoners/pulls/2.0/fix-file-subsites
API Move subsite dropdown logic for folders into FolderFormFactoryExtension
This commit is contained in:
commit
17e0db47a1
@ -3,8 +3,7 @@ language: php
|
||||
addons:
|
||||
firefox: "31.0"
|
||||
|
||||
# Required for Behat, currently
|
||||
dist: precise
|
||||
dist: trusty
|
||||
|
||||
env:
|
||||
global:
|
||||
@ -16,9 +15,9 @@ matrix:
|
||||
include:
|
||||
- php: 5.6
|
||||
env: DB=MYSQL PHPCS_TEST=1 PHPUNIT_TEST=1
|
||||
- php: 7.0
|
||||
env: DB=PGSQL PHPUNIT_TEST=1
|
||||
- php: 7.1
|
||||
env: DB=PGSQL PHPUNIT_TEST=1
|
||||
- php: 7.2
|
||||
env: DB=MYSQL PHPUNIT_COVERAGE_TEST=1
|
||||
- php: 7.0
|
||||
env: DB=MYSQL BEHAT_TEST=1
|
||||
|
@ -28,6 +28,10 @@ SilverStripe\Assets\File:
|
||||
extensions:
|
||||
- SilverStripe\Subsites\Extensions\FileSubsites
|
||||
|
||||
SilverStripe\AssetAdmin\Forms\FolderFormFactory:
|
||||
extensions:
|
||||
- SilverStripe\Subsites\Extensions\FolderFormFactoryExtension
|
||||
|
||||
SilverStripe\ErrorPage\ErrorPage:
|
||||
extensions:
|
||||
- SilverStripe\Subsites\Extensions\ErrorPageSubsite
|
||||
|
@ -76,7 +76,7 @@ body.SubsiteAdmin .right form #URL .fieldgroup * {
|
||||
display: none;
|
||||
}
|
||||
|
||||
#Root_DetailsView .subsites-move-dropdown,
|
||||
#Form_ItemEditForm .subsites-move-dropdown {
|
||||
.editor__details .subsites-move-dropdown,
|
||||
#Form_fileEditorForm.subsites-move-dropdown {
|
||||
display: block;
|
||||
}
|
||||
|
@ -2,10 +2,6 @@
|
||||
|
||||
namespace SilverStripe\Subsites\Extensions;
|
||||
|
||||
use SilverStripe\Assets\Folder;
|
||||
use SilverStripe\Forms\DropdownField;
|
||||
use SilverStripe\Forms\FieldList;
|
||||
use SilverStripe\Forms\LiteralField;
|
||||
use SilverStripe\ORM\DataExtension;
|
||||
use SilverStripe\ORM\DataQuery;
|
||||
use SilverStripe\ORM\Queries\SQLSelect;
|
||||
@ -41,43 +37,6 @@ class FileSubsites extends DataExtension
|
||||
return $this->owner->Title;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add subsites-specific fields to the folder editor.
|
||||
* @param FieldList $fields
|
||||
*/
|
||||
public function updateCMSFields(FieldList $fields)
|
||||
{
|
||||
if ($this->owner instanceof Folder) {
|
||||
$sites = Subsite::accessible_sites('CMS_ACCESS_AssetAdmin');
|
||||
$values = [];
|
||||
$values[0] = _t(__CLASS__ . '.AllSitesDropdownOpt', 'All sites');
|
||||
foreach ($sites as $site) {
|
||||
$values[$site->ID] = $site->Title;
|
||||
}
|
||||
ksort($values);
|
||||
if ($sites) {
|
||||
//Dropdown needed to move folders between subsites
|
||||
/** @var @skipUpgrade */
|
||||
$dropdown = new DropdownField(
|
||||
'SubsiteID',
|
||||
_t(__CLASS__ . '.SubsiteFieldLabel', 'Subsite'),
|
||||
$values
|
||||
);
|
||||
$dropdown->addExtraClass('subsites-move-dropdown');
|
||||
$fields->push($dropdown);
|
||||
$fields->push(new LiteralField(
|
||||
'Message',
|
||||
'<p class="message notice">' .
|
||||
_t(
|
||||
'ASSETADMIN.SUBSITENOTICE',
|
||||
'Folders and files created in the main site are accessible by all subsites.'
|
||||
)
|
||||
. '</p>'
|
||||
));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Update any requests to limit the results to the current site
|
||||
* @param SQLSelect $query
|
||||
@ -90,7 +49,8 @@ class FileSubsites extends DataExtension
|
||||
}
|
||||
|
||||
// If you're querying by ID, ignore the sub-site - this is a bit ugly... (but it was WAYYYYYYYYY worse)
|
||||
//@TODO I don't think excluding if SiteTree_ImageTracking is a good idea however because of the SS 3.0 api and ManyManyList::removeAll() changing the from table after this function is called there isn't much of a choice
|
||||
// @TODO I don't think excluding if SiteTree_ImageTracking is a good idea however because of the SS 3.0 api and
|
||||
// ManyManyList::removeAll() changing the from table after this function is called there isn't much of a choice
|
||||
|
||||
$from = $query->getFrom();
|
||||
if (isset($from['SiteTree_ImageTracking']) || $query->filtersOnID()) {
|
47
src/Extensions/FolderFormFactoryExtension.php
Normal file
47
src/Extensions/FolderFormFactoryExtension.php
Normal file
@ -0,0 +1,47 @@
|
||||
<?php
|
||||
|
||||
namespace SilverStripe\Subsites\Extensions;
|
||||
|
||||
use SilverStripe\Core\Extension;
|
||||
use SilverStripe\Forms\DropdownField;
|
||||
use SilverStripe\Forms\FieldList;
|
||||
use SilverStripe\Forms\LiteralField;
|
||||
use SilverStripe\Subsites\Model\Subsite;
|
||||
|
||||
class FolderFormFactoryExtension extends Extension
|
||||
{
|
||||
/**
|
||||
* Add subsites-specific fields to the folder editor.
|
||||
* @param FieldList $fields
|
||||
*/
|
||||
public function updateFormFields(FieldList $fields)
|
||||
{
|
||||
$sites = Subsite::accessible_sites('CMS_ACCESS_AssetAdmin');
|
||||
$values = [];
|
||||
$values[0] = _t(__CLASS__ . '.AllSitesDropdownOpt', 'All sites');
|
||||
foreach ($sites as $site) {
|
||||
$values[$site->ID] = $site->Title;
|
||||
}
|
||||
ksort($values);
|
||||
if ($sites) {
|
||||
// Dropdown needed to move folders between subsites
|
||||
/** @var @skipUpgrade */
|
||||
$dropdown = DropdownField::create(
|
||||
'SubsiteID',
|
||||
_t(__CLASS__ . '.SubsiteFieldLabel', 'Subsite'),
|
||||
$values
|
||||
);
|
||||
$dropdown->addExtraClass('subsites-move-dropdown');
|
||||
$fields->push($dropdown);
|
||||
$fields->push(LiteralField::create(
|
||||
'Message',
|
||||
'<p class="message notice">' .
|
||||
_t(
|
||||
__CLASS__ . '.SUBSITENOTICE',
|
||||
'Folders and files created in the main site are accessible by all subsites.'
|
||||
)
|
||||
. '</p>'
|
||||
));
|
||||
}
|
||||
}
|
||||
}
|
34
tests/php/Extensions/FolderFormFactoryExtensionTest.php
Normal file
34
tests/php/Extensions/FolderFormFactoryExtensionTest.php
Normal file
@ -0,0 +1,34 @@
|
||||
<?php
|
||||
|
||||
namespace SilverStripe\Subsites\Tests\Extensions;
|
||||
|
||||
use SilverStripe\AssetAdmin\Forms\FolderFormFactory;
|
||||
use SilverStripe\Assets\Folder;
|
||||
use SilverStripe\Dev\SapphireTest;
|
||||
use SilverStripe\Forms\Form;
|
||||
use SilverStripe\Forms\FormFactory;
|
||||
|
||||
class FolderFormFactoryExtensionTest extends SapphireTest
|
||||
{
|
||||
protected static $fixture_file = 'FolderFormFactoryExtensionTest.yml';
|
||||
|
||||
public function testSubsitesFolderDropdown()
|
||||
{
|
||||
$this->logInWithPermission('ADMIN');
|
||||
|
||||
/** @var Folder $folder */
|
||||
$folder = $this->objFromFixture(Folder::class, 'folder_a');
|
||||
|
||||
/** @var Form $folderForm */
|
||||
$folderForm = FolderFormFactory::create()->getForm(null, FormFactory::DEFAULT_NAME, [
|
||||
'Record' => $folder
|
||||
]);
|
||||
|
||||
$source = array_values($folderForm->Fields()->fieldByName('SubsiteID')->getSource());
|
||||
$result = array_values($source);
|
||||
|
||||
$this->assertContains('Main site', $result);
|
||||
$this->assertContains('Subsite A', $result);
|
||||
$this->assertContains('Subsite B', $result);
|
||||
}
|
||||
}
|
11
tests/php/Extensions/FolderFormFactoryExtensionTest.yml
Normal file
11
tests/php/Extensions/FolderFormFactoryExtensionTest.yml
Normal file
@ -0,0 +1,11 @@
|
||||
SilverStripe\Subsites\Model\Subsite:
|
||||
main:
|
||||
Title: Template
|
||||
subsite_a:
|
||||
Title: Subsite A
|
||||
subsite_b:
|
||||
Title: Subsite B
|
||||
|
||||
SilverStripe\Assets\Folder:
|
||||
folder_a:
|
||||
Title: Folder A
|
@ -12,15 +12,6 @@ class FileSubsitesTest extends BaseSubsiteTest
|
||||
{
|
||||
protected static $fixture_file = 'SubsiteTest.yml';
|
||||
|
||||
/**
|
||||
* Disable other file extensions
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected static $illegal_extensions = [
|
||||
SiteTree::class => ['Translatable'], // @todo implement namespace for Translatable
|
||||
];
|
||||
|
||||
public function testTrivialFeatures()
|
||||
{
|
||||
$this->assertTrue(is_array(singleton(FileSubsites::class)->extraStatics()));
|
||||
@ -73,27 +64,4 @@ class FileSubsitesTest extends BaseSubsiteTest
|
||||
$file->onAfterUpload();
|
||||
$this->assertEquals($folder->SubsiteID, $file->SubsiteID);
|
||||
}
|
||||
|
||||
public function testSubsitesFolderDropdown()
|
||||
{
|
||||
$this->logInAs('admin');
|
||||
|
||||
$file = new Folder();
|
||||
|
||||
$source = array_values($file->getCMSFields()->dataFieldByName('SubsiteID')->getSource());
|
||||
asort($source);
|
||||
|
||||
$this->assertEquals([
|
||||
'Main site',
|
||||
'Subsite1 Template',
|
||||
'Subsite2 Template',
|
||||
'Template',
|
||||
'Test 1',
|
||||
'Test 2',
|
||||
'Test 3',
|
||||
'Test Non-SSL',
|
||||
'Test SSL',
|
||||
'Test Vagrant VM on port 8080'
|
||||
], array_values($source));
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user