Skip to content

Commit 1c62f32

Browse files
committed
Add fullscreen navbar-tool
1 parent 97b3412 commit 1c62f32

File tree

1 file changed

+62
-0
lines changed

1 file changed

+62
-0
lines changed

src/Widgets/Navbar/Fullscreen.php

Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
<?php
2+
3+
namespace Encore\Admin\Widgets\Navbar;
4+
5+
use Encore\Admin\Admin;
6+
use Illuminate\Contracts\Support\Renderable;
7+
8+
/**
9+
* Class FullScreen
10+
*
11+
* @see https://javascript.ruanyifeng.com/htmlapi/fullscreen.html
12+
*/
13+
class Fullscreen implements Renderable
14+
{
15+
public function render()
16+
{
17+
$script = <<<'SCRIPT'
18+
function launchFullscreen(element) {
19+
if(element.requestFullscreen) {
20+
element.requestFullscreen();
21+
} else if(element.mozRequestFullScreen) {
22+
element.mozRequestFullScreen();
23+
} else if(element.msRequestFullscreen){
24+
element.msRequestFullscreen();
25+
} else if(element.webkitRequestFullscreen) {
26+
element.webkitRequestFullScreen();
27+
}
28+
}
29+
30+
function exitFullscreen() {
31+
if (document.exitFullscreen) {
32+
document.exitFullscreen();
33+
} else if (document.msExitFullscreen) {
34+
document.msExitFullscreen();
35+
} else if (document.mozCancelFullScreen) {
36+
document.mozCancelFullScreen();
37+
} else if (document.webkitExitFullscreen) {
38+
document.webkitExitFullscreen();
39+
}
40+
}
41+
42+
$('.nav-fullscreen').click(function () {
43+
if (document.fullscreenElement) {
44+
exitFullscreen();
45+
} else {
46+
launchFullscreen(document.body)
47+
}
48+
});
49+
50+
SCRIPT;
51+
52+
Admin::script($script);
53+
54+
return <<<'EOT'
55+
<li>
56+
<a href="javascript:void(0);" class="nav-fullscreen">
57+
<i class="fa fa-arrows-alt"></i>
58+
</a>
59+
</li>
60+
EOT;
61+
}
62+
}

0 commit comments

Comments
 (0)