Added pulse animation to show when data is being updated.
Fixed possible incorrect show count string. Added key property to fix a couple React warnings.
This commit is contained in:
parent
86872dd0ba
commit
87808bd73c
2 changed files with 45 additions and 16 deletions
53
index.php
53
index.php
|
@ -223,28 +223,55 @@ $opcache = OpCacheService::init();
|
|||
#resetCache, #toggleRealtime, footer > a { background-position: 5px 50%; background-repeat: no-repeat; background-color: transparent; }
|
||||
footer > a { background-position: 0 50%; background-image: url(''); font-size: 80%; }
|
||||
#resetCache { background-image: url(''); }
|
||||
#toggleRealtime { background-image: url(''); }
|
||||
#toggleRealtime { position: relative; background-image: url(''); }
|
||||
#counts { width: 270px; float: right; }
|
||||
#counts > div > div { background-color: #ededed; margin-bottom: 10px; }
|
||||
#counts > div > div > h3 { background-color: #cdcdcd; padding: 4px 6px; margin: 0; }
|
||||
#counts > div > div > p { margin: 0; text-align: center; }
|
||||
#counts > div > div > p > span.large ~ span { font-size: 20pt; margin: 0; }
|
||||
#counts > div > div > p > span.large + span { font-size: 20pt; margin: 0; }
|
||||
#counts > div > div > p > span.large { font-size: 80pt; margin: 0; padding: 0; text-align: center; }
|
||||
#info { margin-right: 280px; }
|
||||
#frmFilter { width: 520px; }
|
||||
#moreinfo { padding: 10px; }
|
||||
#moreinfo > p { text-align: left !important; line-height: 180%; }
|
||||
.metainfo { font-size: 80%; }
|
||||
.hide { display: none; }
|
||||
#toggleRealtime.pulse::before {
|
||||
content: ""; position: absolute;
|
||||
top: 13px; left: 3px; width: 18px; height: 18px;
|
||||
z-index: 10; opacity: 0; background-color: transparent;
|
||||
border: 2px solid rgb(255, 116, 0); border-radius: 100%;
|
||||
-webkit-animation: pulse 1s linear 2;
|
||||
-moz-animation: pulse 1s linear 2;
|
||||
animation: pulse 1s linear 2;
|
||||
}
|
||||
@media screen and (max-width: 750px) {
|
||||
#info { margin-right:auto; }
|
||||
#info { margin-right:auto; clear:both; }
|
||||
nav > ul { border-bottom: 0; }
|
||||
nav > ul > li { display: block; margin: 0; }
|
||||
nav > ul > li > a { display: block; margin: 0 10px; padding: 10px 0 10px 30px; border: 0; }
|
||||
nav > ul > li > a[data-for].active { border-bottom-color: #ccc; }
|
||||
#counts { position:relative; display:block; width:100%; }
|
||||
#toggleRealtime.pulse::before { top: 8px; }
|
||||
}
|
||||
@media screen and (max-width: 550px) {
|
||||
#frmFilter { width: 100%; }
|
||||
}
|
||||
@keyframes pulse {
|
||||
0% {transform: scale(1); opacity: 0;}
|
||||
50% {transform: scale(1.3); opacity: 0.7;}
|
||||
100% {transform: scale(1.6); opacity: 1;}
|
||||
}
|
||||
@-webkit-keyframes pulse {
|
||||
0% {-webkit-transform: scale(1); opacity: 0;}
|
||||
50% {-webkit-transform: scale(1.3); opacity: 0.7;}
|
||||
100% {-webkit-transform: scale(1.6); opacity: 0;}
|
||||
}
|
||||
@-moz-keyframes pulse {
|
||||
0% {-moz-transform: scale(1); opacity: 0;}
|
||||
50% {-moz-transform: scale(1.3); opacity: 0.7;}
|
||||
100% {-moz-transform: scale(1.6); opacity: 0;}
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
|
@ -285,7 +312,7 @@ $opcache = OpCacheService::init();
|
|||
</div>
|
||||
</div>
|
||||
<div id="files">
|
||||
<p><label>Start typing to filter on script path<br/><input type="text" style="width:40em;" name="filter" id="frmFilter" /><label></p>
|
||||
<p><label>Start typing to filter on script path<br/><input type="text" name="filter" id="frmFilter" /><label></p>
|
||||
<div class="container" id="filelist"></div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -301,11 +328,13 @@ $opcache = OpCacheService::init();
|
|||
|
||||
$(function(){
|
||||
function updateStatus() {
|
||||
$('#toggleRealtime').removeClass('pulse');
|
||||
$.ajax({
|
||||
url: "#",
|
||||
dataType: "json",
|
||||
cache: false,
|
||||
success: function(data) {
|
||||
$('#toggleRealtime').addClass('pulse');
|
||||
opstate = data;
|
||||
overviewCountsObj.setState({
|
||||
data : opstate.overview
|
||||
|
@ -331,7 +360,7 @@ $opcache = OpCacheService::init();
|
|||
} else {
|
||||
clearInterval(realtime);
|
||||
realtime = false;
|
||||
$(this).text('Enable real-time update');
|
||||
$(this).text('Enable real-time update').removeClass('pulse');
|
||||
}
|
||||
});
|
||||
$('nav a[data-for]').click(function(){
|
||||
|
@ -342,7 +371,7 @@ $opcache = OpCacheService::init();
|
|||
return false;
|
||||
});
|
||||
$(document).on('paint', '#filelist table tbody', function(event, params) {
|
||||
var trs = $('tr:visible', $(this));
|
||||
var trs = $('tr', $(this)).not('.hide');
|
||||
trs.filter(':odd').css({backgroundColor:'#E0ECEF'})
|
||||
.end().filter(':even').css({backgroundColor:'#EFFEFF'});
|
||||
filesObj.setState({showing: trs.length});
|
||||
|
@ -350,9 +379,9 @@ $opcache = OpCacheService::init();
|
|||
$('#frmFilter').bind('keyup', function(event){
|
||||
$('span.pathname').each(function(index){
|
||||
if ($(this).text().toLowerCase().indexOf($('#frmFilter').val().toLowerCase()) == -1) {
|
||||
$(this).closest('tr').hide();
|
||||
$(this).closest('tr').addClass('hide');
|
||||
} else {
|
||||
$(this).closest('tr').show();
|
||||
$(this).closest('tr').removeClass('hide');
|
||||
}
|
||||
});
|
||||
$('#filelist table tbody').trigger('paint');
|
||||
|
@ -396,7 +425,7 @@ $opcache = OpCacheService::init();
|
|||
return {
|
||||
version : opstate.version,
|
||||
start : opstate.overview.readable.start_time,
|
||||
reset : opstate.overview.readable.last_restart_time,
|
||||
reset : opstate.overview.readable.last_restart_time
|
||||
};
|
||||
},
|
||||
render: function() {
|
||||
|
@ -437,7 +466,7 @@ $opcache = OpCacheService::init();
|
|||
vShow = directive.v;
|
||||
}
|
||||
return (
|
||||
React.createElement("tr", null,
|
||||
React.createElement("tr", {key: directive.k},
|
||||
React.createElement("td", {title: directive.k}, dShow),
|
||||
React.createElement("td", null, vShow)
|
||||
)
|
||||
|
@ -482,7 +511,7 @@ $opcache = OpCacheService::init();
|
|||
+ file.full_path, 'data-file': file.full_path, onClick: this.handleInvalidate}, "force file invalidation"));
|
||||
}
|
||||
return (
|
||||
React.createElement("tr", null,
|
||||
React.createElement("tr", {key: file.full_path},
|
||||
React.createElement("td", null,
|
||||
React.createElement("div", null,
|
||||
React.createElement("span", {className: "pathname"}, file.full_path), React.createElement("br", null),
|
||||
|
@ -527,7 +556,7 @@ $opcache = OpCacheService::init();
|
|||
},
|
||||
render: function() {
|
||||
var display = this.state.formatted + ' file' + (this.state.total == 1 ? '' : 's') + ' cached';
|
||||
if (this.props.showing !== null && this.props.showing != 0 && this.props.showing != this.state.total) {
|
||||
if (this.props.showing !== null && this.props.showing != this.state.total) {
|
||||
display += ', ' + this.props.showing + ' showing due to filter';
|
||||
}
|
||||
return (React.createElement("h3", null, display));
|
||||
|
|
|
@ -35,7 +35,7 @@ var GeneralInfo = React.createClass({
|
|||
return {
|
||||
version : opstate.version,
|
||||
start : opstate.overview.readable.start_time,
|
||||
reset : opstate.overview.readable.last_restart_time,
|
||||
reset : opstate.overview.readable.last_restart_time
|
||||
};
|
||||
},
|
||||
render: function() {
|
||||
|
@ -76,7 +76,7 @@ var Directives = React.createClass({
|
|||
vShow = directive.v;
|
||||
}
|
||||
return (
|
||||
<tr>
|
||||
<tr key={directive.k}>
|
||||
<td title={directive.k}>{dShow}</td>
|
||||
<td>{vShow}</td>
|
||||
</tr>
|
||||
|
@ -121,7 +121,7 @@ var Files = React.createClass({
|
|||
+ file.full_path} data-file={file.full_path} onClick={this.handleInvalidate}>force file invalidation</a></span>;
|
||||
}
|
||||
return (
|
||||
<tr>
|
||||
<tr key={file.full_path}>
|
||||
<td>
|
||||
<div>
|
||||
<span className="pathname">{file.full_path}</span><br/>
|
||||
|
@ -166,7 +166,7 @@ var FilesListed = React.createClass({
|
|||
},
|
||||
render: function() {
|
||||
var display = this.state.formatted + ' file' + (this.state.total == 1 ? '' : 's') + ' cached';
|
||||
if (this.props.showing !== null && this.props.showing != 0 && this.props.showing != this.state.total) {
|
||||
if (this.props.showing !== null && this.props.showing != this.state.total) {
|
||||
display += ', ' + this.props.showing + ' showing due to filter';
|
||||
}
|
||||
return (<h3>{display}</h3>);
|
||||
|
|
Loading…
Reference in a new issue