Integrated favicon handler with correct files & actions

Format does not look 100% correct though, won't show in Firefox/gimp.
This commit is contained in:
Dan Brown 2023-02-09 13:24:43 +00:00
parent 420f89af99
commit 1a189640f1
No known key found for this signature in database
GPG key ID: 46D9F943C24A2EF9
5 changed files with 35 additions and 6 deletions

View file

@ -51,6 +51,8 @@ class AppSettingsStore
$this->destroyExistingSettingImage('app-icon-' . $size); $this->destroyExistingSettingImage('app-icon-' . $size);
setting()->remove('app-icon-' . $size); setting()->remove('app-icon-' . $size);
} }
$this->faviconHandler->restoreOriginal();
} }
} }

View file

@ -17,19 +17,32 @@ class FaviconHandler
*/ */
public function saveForUploadedImage(UploadedFile $file): void public function saveForUploadedImage(UploadedFile $file): void
{ {
$targetPath = public_path('favicon.ico');
if (!is_writeable($targetPath)) {
return;
}
$imageData = file_get_contents($file->getRealPath()); $imageData = file_get_contents($file->getRealPath());
$image = $this->imageTool->make($imageData); $image = $this->imageTool->make($imageData);
$image->resize(32, 32); $image->resize(32, 32);
$bmpData = $image->encode('bmp'); $bmpData = $image->encode('bmp');
$icoData = $this->bmpToIco($bmpData, 32, 32); $icoData = $this->bmpToIco($bmpData, 32, 32);
// TODO - Below are test paths file_put_contents($targetPath, $icoData);
file_put_contents(public_path('uploads/test.ico'), $icoData); }
file_put_contents(public_path('uploads/test.bmp'), $bmpData);
// TODO - Permission check for icon overwrite /**
// TODO - Write to correct location * Restore the original favicon image.
// TODO - Handle deletion and restore of original icon on user icon clear */
public function restoreOriginal(): void
{
$targetPath = public_path('favicon.ico');
$original = public_path('icon.ico');
if (!is_writeable($targetPath)) {
return;
}
copy($original, $targetPath);
} }
/** /**

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

After

Width:  |  Height:  |  Size: 3.1 KiB

BIN
public/icon.ico Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

View file

@ -52,6 +52,10 @@ class SettingsTest extends TestCase
$this->assertFalse(setting()->get('app-icon-128')); $this->assertFalse(setting()->get('app-icon-128'));
$this->assertFalse(setting()->get('app-icon-64')); $this->assertFalse(setting()->get('app-icon-64'));
$this->assertFalse(setting()->get('app-icon-32')); $this->assertFalse(setting()->get('app-icon-32'));
$this->assertEquals(
file_get_contents(public_path('icon.ico')),
file_get_contents(public_path('favicon.ico')),
);
$prevFileCount = count(glob(dirname($expectedPath) . DIRECTORY_SEPARATOR . '*.png')); $prevFileCount = count(glob(dirname($expectedPath) . DIRECTORY_SEPARATOR . '*.png'));
@ -71,6 +75,11 @@ class SettingsTest extends TestCase
$resp = $this->get('/'); $resp = $this->get('/');
$this->withHtml($resp)->assertElementCount('link[sizes][href*="my-app-icon"]', 6); $this->withHtml($resp)->assertElementCount('link[sizes][href*="my-app-icon"]', 6);
$this->assertNotEquals(
file_get_contents(public_path('icon.ico')),
file_get_contents(public_path('favicon.ico')),
);
$reset = $this->post('/settings/customization', ['app_icon_reset' => 'true']); $reset = $this->post('/settings/customization', ['app_icon_reset' => 'true']);
$reset->assertRedirect('/settings/customization'); $reset->assertRedirect('/settings/customization');
@ -81,5 +90,10 @@ class SettingsTest extends TestCase
$this->assertFalse(setting()->get('app-icon-128')); $this->assertFalse(setting()->get('app-icon-128'));
$this->assertFalse(setting()->get('app-icon-64')); $this->assertFalse(setting()->get('app-icon-64'));
$this->assertFalse(setting()->get('app-icon-32')); $this->assertFalse(setting()->get('app-icon-32'));
$this->assertEquals(
file_get_contents(public_path('icon.ico')),
file_get_contents(public_path('favicon.ico')),
);
} }
} }