Themeable Webinterface mit neuem Style.

git-svn-id: http://svn.ipfire.org/svn/ipfire/trunk@364 ea5c0bd1-69bd-2848-81d8-4f18e57aeed8
This commit is contained in:
ms
2006-12-16 16:07:45 +00:00
parent d733119b38
commit f8e080ef11
20 changed files with 2181 additions and 1761 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 1014 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 449 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 155 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 155 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 72 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 70 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 43 B

View File

@@ -0,0 +1,326 @@
#!/usr/bin/perl
sub showmenu() {
print <<EOF
<div id="menu">
<ul>
EOF
;
foreach my $k1 ( sort keys %$menu ) {
if (! $menu->{$k1}{'enabled'}) {
next;
}
my $link = getlink($menu->{$k1});
if ($link eq '') {
next;
}
if (! is_menu_visible($link)) {
next;
}
if ($menu->{$k1}->{'selected'}) {
print "<li><a href=\"$link\" class=\"active\">$menu->{$k1}{'caption'}</a></li>";
} else {
print "<li><a href=\"$link\">$menu->{$k1}{'caption'}</a></li>";
}
}
print <<EOF
</ul>
</div>
EOF
;
}
sub getselected($) {
my $root = shift;
if (!$root) {
return 0;
}
foreach my $item (%$root) {
if ($root->{$item}{'selected'}) {
return $root->{$item};
}
}
}
sub showsubsection($$) {
my $root = shift;
if (! $root) {
return;
}
my $selected = getselected($root);
if (! $selected) {
return;
}
my $submenus = $selected->{'subMenu'};
if (! $submenus) {
return;
}
print <<EOF
<h4><span>Side</span>menu</h4>
<ul class="links">
EOF
;
foreach my $item (sort keys %$submenus) {
my $hash = $submenus->{$item};
if (! $hash->{'enabled'}) {
next;
}
my $link = getlink($hash);
if ($link eq '') {
next;
}
if (! is_menu_visible($link)) {
next;
}
if ($hash->{'selected'}) {
print '<li class="selected">';
} else {
print '<li>';
}
print "<a href=\"$link\">$hash->{'caption'}</a></li>";
}
print <<EOF
</ul>
EOF
;
}
sub showsubsubsection($) {
my $root = shift;
if (!$root) {
return;
}
my $selected = getselected($root);
if (! $selected) {
return
}
if (! $selected->{'subMenu'}) {
return
}
showsubsection($selected->{'subMenu'}, 'menu-subtop');
}
sub openpage {
my $title = shift;
my $boh = shift;
my $extrahead = shift;
@URI=split ('\?', $ENV{'REQUEST_URI'} );
&readhash("${swroot}/main/settings", \%settings);
&genmenu();
my $h2 = gettitle($menu);
$title = "IPFire - $title";
if ($settings{'WINDOWWITHHOSTNAME'} eq 'on') {
$title = "$settings{'HOSTNAME'}.$settings{'DOMAINNAME'} - $title";
}
print <<END
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>$title</title>
$extrahead
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
END
;
if ($settings{'FX'} ne 'off') {
print <<END
<meta http-equiv="Page-Enter" content="blendTrans(Duration=0.5,Transition=12)" />
<meta http-equiv="Page-Exit" content="blendTrans(Duration=0.5,Transition=12)" />
END
;
}
print <<END
<link rel="shortcut icon" href="/favicon.ico" />
<link rel="stylesheet" type="text/css" href="/themes/ipfire/include/style.css" />
<script language="javascript" type="text/javascript">
function swapVisibility(id) {
el = document.getElementById(id);
if(el.style.display != 'block') {
el.style.display = 'block'
}
else {
el.style.display = 'none'
}
}
</script>
</head>
<body>
<!-- IPFIRE HEADER -->
<div id="header">
<div id="header_inner" class="fixed">
<div id="logo">
<h1><span>IPFire</span></h1>
<h2>$h2</h2>
</div>
END
;
&showmenu();
print <<END
</div>
</div>
<div id="main">
<div id="main_inner" class="fixed">
<div id="primaryContent_2columns">
<div id="columnA_2columns">
END
;
}
sub openpagewithoutmenu {
my $title = shift;
my $boh = shift;
my $extrahead = shift;
@URI=split ('\?', $ENV{'REQUEST_URI'} );
&readhash("${swroot}/main/settings", \%settings);
&genmenu();
my $h2 = gettitle($menu);
$title = "IPFire - $title";
if ($settings{'WINDOWWITHHOSTNAME'} eq 'on') {
$title = "$settings{'HOSTNAME'}.$settings{'DOMAINNAME'} - $title";
}
print <<END
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>$title</title>
$extrahead
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
END
;
if ($settings{'FX'} ne 'off') {
print <<END
<meta http-equiv="Page-Enter" content="blendTrans(Duration=0.5,Transition=12)" />
<meta http-equiv="Page-Exit" content="blendTrans(Duration=0.5,Transition=12)" />
END
;
}
print <<END
<link rel="shortcut icon" href="/favicon.ico" />
<link rel="stylesheet" type="text/css" href="/include/style.css" />
<script language="javascript" type="text/javascript">
function swapVisibility(id) {
el = document.getElementById(id);
if(el.style.display != 'block') {
el.style.display = 'block'
}
else {
el.style.display = 'none'
}
}
</script>
</head>
<body>
<!-- IPFIRE HEADER -->
<div id="header">
<div id="header_inner" class="fixed">
<div id="logo">
<h1><span>IPFire</span></h1>
<h2>$h2</h2>
</div>
</div>
</div>
<div id="main">
<div id="main_inner" class="fixed">
<div id="primaryContent_2columns">
<div id="columnA_2columns">
END
;
}
sub closepage () {
my $status = &connectionstatus();
$uptime = `/usr/bin/uptime`;
print <<END
</div>
</div>
<div id="secondaryContent_2columns">
<div id="columnC_2columns">
END
;
&showsubsection($menu);
&showsubsubsection($menu);
print <<END
</div>
</div>
<br class="clear" />
<div id="footer" class="fixed">
<b>Status:</b> $status <b>Uptime:</b>$uptime <b>Version:</b> $FIREBUILD
</div>
</div>
</body>
</html>
END
;
}
sub openbigbox
{
}
sub closebigbox
{
}
sub openbox
{
$width = $_[0];
$align = $_[1];
$caption = $_[2];
print <<END
<!-- openbox -->
<div class="post" align="$align">
END
;
if ($caption) { print "<h3>$caption</h3>\n"; } else { print "&nbsp;"; }
}
sub closebox
{
print <<END
</div>
<br class="clear" />
<!-- closebox -->
END
;
}
1;

View File

@@ -0,0 +1,430 @@
/*
Nonzero1.0 by nodethirtythree design
http://www.nodethirtythree.com
missing in a maze
*/
/* This controls the width of the fluid width layouts */
div.fluid
{
width: 90% !important;
}
/* This controls the width of the fixed width layouts */
div.fixed
{
width: 950px !important;
}
/* Basic Stuff */
*
{
margin: 0em;
padding: 0em;
}
body
{
background-color: #fff;
color: #585858;
font-size: 9pt;
font-family: "trebuchet ms", helvetica, sans-serif;
}
h1,h2,h3,h4,h5,h6
{
font-weight: normal;
letter-spacing: -1px;
text-transform: lowercase;
text-align: left;
}
h3,h4,h5,h6
{
color: #66000F;
}
h1 span
{
font-weight: bold;
}
h3 span
{
font-weight: bold;
}
h4 span
{
font-weight: bold;
}
br.clear
{
clear: both;
}
img
{
padding: 3px;
border: solid 1px #e1e1e1;
}
img.floatTL
{
float: left;
margin-right: 1.5em;
margin-bottom: 1.5em;
margin-top: 0.5em;
}
a
{
text-decoration: underline;
color: #D90000;
}
a:hover
{
text-decoration: none;
}
ul.links
{
list-style: none;
}
ul.links li
{
line-height: 2em;
}
ul.links li.first
{
}
p
{
line-height: 1.8em;
}
/* Header */
#header
{
width:100%;
height:122px;
background: #440000 url('/themes/ipfire/images/n1.gif') repeat-x;
}
#header_inner
{
position: relative;
width: 950px;
height:122px;
margin: 0 auto;
}
/* Logo */
#logo
{
position: absolute;
bottom: 0.6em;
}
#logo h1
{
display: inline;
color: #fff;
font-size: 2.6em;
}
#logo h2
{
display: inline;
padding-left: 0.5em;
color: #E5CCD0;
font-size: 1.0em;
}
/* Menu */
#menu
{
position: absolute;
right: 0em;
bottom: 0em;
}
#menu ul
{
list-style: none;
}
#menu li
{
float: left;
}
#menu li a
{
margin-left: 0.5em;
display: block;
padding: 1.1em 1.4em 1.0em 1.4em;
background: #fff url('/themes/ipfire/images/n4.gif') repeat-x;
border: solid 1px #fff;
color: #616161;
font-weight: bold;
font-size: 1.0em;
text-transform: lowercase;
text-decoration: none;
}
#menu li a.active
{
background: #CA2F2F url('/themes/ipfire/images/n3.gif') repeat-x;
color: #fff;
border: solid 1px #A94B4B;
}
/* Main */
#main
{
background: #fff url('/themes/ipfire/images/n2.gif') 0px 1px repeat-x;
}
#main_inner p
{
text-align: justify;
margin-bottom: 2.0em;
}
#main_inner ul
{
margin-bottom: 2.0em;
}
#main_inner
{
position: relative;
width: 950px;
margin: 0 auto;
padding-top: 3.5em;
}
#main_inner h3,h4
{
border-bottom: dotted 1px #E1E1E1;
position: relative;
}
#main_inner h3
{
font-size: 2.1em;
padding-bottom: 0.1em;
margin-bottom: 0.8em;
}
#main_inner h4
{
font-size: 1.2em;
padding-bottom: 0.175em;
margin-bottom: 1.4em;
margin-top: 0.95em;
}
#main_inner .post
{
position: relative;
}
#main_inner .post h3
{
position: relative;
font-size: 1.7em;
padding-bottom: 1.2em;
}
#main_inner .post ul.post_info
{
list-style: none;
position: absolute;
top: 3em;
font-size: 0.8em;
}
#main_inner .post ul.post_info li
{
background-position: 0em 0.2em;
background-repeat: no-repeat;
display: inline;
padding-left: 18px;
}
#main_inner .post ul.post_info li.date
{
background-image: url('/themes/ipfire/images/n5.gif');
}
#main_inner .post ul.post_info li.comments
{
background-image: url('/themes/ipfire/images/n6.gif');
margin-left: 1.1em;
}
/* Footer */
#footer
{
width: 950px;
margin: 0 auto;
text-align: center;
clear: both;
border-top: dotted 1px #E1E1E1;
margin-top: 1.0em;
margin-bottom: 1.0em;
padding-top: 1.0em;
text-transform: lowercase;
}
/* Search */
input.button
{
background: #CA2F2F url('/themes/ipfire/images/n3.gif') repeat-x;
color: #fff;
border: solid 1px #A94B4B;
font-weight: bold;
text-transform: lowercase;
font-size: 0.8em;
height: 2.0em;
}
input.text
{
border: solid 1px #F1F1F1;
font-size: 1.0em;
padding: 0.25em 0.25em 0.25em 0.25em;
}
#search
{
position: relative;
width: 100%;
margin-bottom: 2.0em;
}
#search input.text
{
position: absolute;
top: 0em;
left: 0em;
width: 9.5em;
}
#search input.button
{
position: absolute;
top: 0em;
right: 0em;
min-width: 2.0em;
max-width: 2.5em;
}
/* LAYOUT - 3 COLUMNS */
/* Primary content */
#primaryContent_3columns
{
position: relative;
margin-right: 34em;
}
#columnA_3columns
{
position: relative;
float: left;
width: 100%;
margin-right: -34em;
padding-right: 2em;
}
/* Secondary Content */
#secondaryContent_3columns
{
float: right;
}
#columnB_3columns
{
width: 13.0em;
float: left;
padding: 0em 2em 0.5em 2em;
border-left: dotted 1px #E1E1E1;
}
#columnC_3columns
{
width: 13.0em;
float: left;
padding: 0em 0em 0.5em 2em;
border-left: dotted 1px #E1E1E1;
}
/* LAYOUT - 2 COLUMNS */
/* Primary content */
#primaryContent_2columns
{
position: relative;
margin-right: 17em;
}
#columnA_2columns
{
position: relative;
float: left;
width: 100%;
margin-right: -17em;
padding-right: 2em;
}
/* Secondary Content */
#secondaryContent_2columns
{
float: right;
}
#columnC_2columns
{
width: 13.0em;
float: left;
padding: 0em 0em 0.5em 2em;
border-left: dotted 1px #E1E1E1;
}
/* LAYOUT - COLUMNLESS */
/* Primary content */
#primaryContent_columnless
{
position: relative;
}
#columnA_columnless
{
position: relative;
width: 100%;
}