Skip to content

Commit

Permalink
NEW WebP support in CMS
Browse files Browse the repository at this point in the history
  • Loading branch information
Maxime Rainville committed Feb 8, 2022
1 parent 9548372 commit 1ce0018
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 16 deletions.
2 changes: 1 addition & 1 deletion _config/filetypes.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,4 @@ SilverStripe\Assets\File:
css: 'CSS file'
html: 'HTML file'
htm: 'HTML file'

webp: 'WEBP Image'
7 changes: 4 additions & 3 deletions src/File.php
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@ class File extends DataObject implements AssetContainer, Thumbnail, CMSPreviewab
'docx', 'dotx', 'flv', 'gif', 'gpx', 'gz', 'hqx', 'ico', 'jpeg', 'jpg', 'kml',
'm4a', 'm4v', 'mid', 'midi', 'mkv', 'mov', 'mp3', 'mp4', 'mpa', 'mpeg', 'mpg', 'ogg', 'ogv', 'pages',
'pcx', 'pdf', 'png', 'pps', 'ppt', 'pptx', 'potx', 'ra', 'ram', 'rm', 'rtf', 'sit', 'sitx',
'tar', 'tgz', 'tif', 'tiff', 'txt', 'wav', 'webm', 'wma', 'wmv', 'xls', 'xlsx', 'xltx', 'zip',
'tar', 'tgz', 'tif', 'tiff', 'txt', 'wav', 'webm', 'webp', 'wma', 'wmv', 'xls', 'xlsx', 'xltx', 'zip',
'zipx',
];

Expand All @@ -218,10 +218,10 @@ class File extends DataObject implements AssetContainer, Thumbnail, CMSPreviewab
'potm', 'potx', 'pps', 'ppt', 'pptx', 'rtf', 'txt', 'xhtml', 'xls', 'xlsx', 'xltm', 'xltx', 'xml',
],
'image' => [
'alpha', 'als', 'bmp', 'cel', 'gif', 'ico', 'icon', 'jpeg', 'jpg', 'pcx', 'png', 'ps', 'psd', 'tif', 'tiff',
'alpha', 'als', 'bmp', 'cel', 'gif', 'ico', 'icon', 'jpeg', 'jpg', 'pcx', 'png', 'ps', 'psd', 'tif', 'tiff', 'webp'
],
'image/supported' => [
'gif', 'jpeg', 'jpg', 'png', 'bmp', 'ico',
'gif', 'jpeg', 'jpg', 'png', 'bmp', 'ico', 'webp'
],
'flash' => [
'fla', 'swf'
Expand All @@ -246,6 +246,7 @@ class File extends DataObject implements AssetContainer, Thumbnail, CMSPreviewab
'gif' => Image::class,
'bmp' => Image::class,
'ico' => Image::class,
'webp' => Image::class,
];

/**
Expand Down
1 change: 1 addition & 0 deletions src/Storage/DBFile.php
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ class DBFile extends DBComposite implements AssetContainer, Thumbnail
'image/x-icon',
'image/vnd.microsoft.icon',
'image/vnd.adobe.photoshop',
'image/webp',
];

/**
Expand Down
35 changes: 23 additions & 12 deletions tests/php/FileTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -194,33 +194,44 @@ public function testInvalidImageManipulations()
$this->assertNull($broken->Pad(100, 100));
}

public function testAppCategory()
public function appCategoryDataProvider()
{
return [
['image', 'jpg'],
['image', 'JPG'],
['image', 'JPEG'],
['image', 'png'],
['image', 'tif'],
['image', 'webp'],
['document', 'pdf'],
['video', 'mov'],
['audio', 'OGG'],
];
}

/**
* @dataProvider appCategoryDataProvider
*/
public function testAppCategory($category, $extension)
{
// Test various categories
$this->assertEquals('image', File::get_app_category('jpg'));
$this->assertEquals('image', File::get_app_category('JPG'));
$this->assertEquals('image', File::get_app_category('JPEG'));
$this->assertEquals('image', File::get_app_category('png'));
$this->assertEquals('image', File::get_app_category('tif'));
$this->assertEquals('document', File::get_app_category('pdf'));
$this->assertEquals('video', File::get_app_category('mov'));
$this->assertEquals('audio', File::get_app_category('OGG'));
$this->assertEquals($category, File::get_app_category($extension));
}

public function testGetCategoryExtensions()
{
// Test specific categories
$images = [
'alpha', 'als', 'bmp', 'cel', 'gif', 'ico', 'icon', 'jpeg', 'jpg', 'pcx', 'png', 'ps', 'psd', 'tif', 'tiff'
'alpha', 'als', 'bmp', 'cel', 'gif', 'ico', 'icon', 'jpeg', 'jpg', 'pcx', 'png', 'ps', 'psd', 'tif', 'tiff', 'webp'
];
$this->assertEquals($images, File::get_category_extensions('image'));
$this->assertEquals(
['bmp', 'gif', 'ico', 'jpeg', 'jpg', 'png'],
['bmp', 'gif', 'ico', 'jpeg', 'jpg', 'png', 'webp'],
File::get_category_extensions('image/supported')
);
$this->assertEquals($images, File::get_category_extensions(['image', 'image/supported']));
$this->assertEquals(
['bmp', 'fla', 'gif', 'ico', 'jpeg', 'jpg', 'png', 'swf'],
['bmp', 'fla', 'gif', 'ico', 'jpeg', 'jpg', 'png', 'swf', 'webp'],
File::get_category_extensions(['flash', 'image/supported'])
);

Expand Down

0 comments on commit 1ce0018

Please sign in to comment.