Skip to content

Commit

Permalink
Release/3.2.1 (#68)
Browse files Browse the repository at this point in the history
* Fixed spaceship operator regression
* Remove 'empty' get parameter (#66)
* Improved layout of arrays in directive list (eg, optimisation values) (#67)
* Added optimisation value to the list alongside text equivalent.
* Bumping version and updating readme
  • Loading branch information
amnuts authored Dec 16, 2020
1 parent d07fa78 commit 240b965
Show file tree
Hide file tree
Showing 8 changed files with 61 additions and 28 deletions.
6 changes: 6 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,12 @@ When the real-time updates are active the interface will automatically update al

## Releases

**Version 3.2.1**\
Minor maintenance release to:
* Put back "spaceship operator" so PHP8 doesn't give deprecation warnings (must have been accidentally removed in a previous commit)
* More refined axios usage when it comes to parameters
* A little extra formatting on the opcache optimization levels

**Version 3.2.0**\
Updated ReactJS to latest and used minified versions and made slight improvement to sort option when no pagination is present.

Expand Down
22 changes: 15 additions & 7 deletions build/_frontend/interface.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ class Interface extends React.Component {
this.setState({realtime: true})
this.polling = setInterval(() => {
this.setState({fetching: true, resetting: false});
axios.get('?', {time: Date.now()})
axios.get(window.location.pathname, {time: Date.now()})
.then((response) => {
this.setState({opstate: response.data});
});
Expand All @@ -43,7 +43,7 @@ class Interface extends React.Component {
resetHandler = () => {
if (this.state.realtime) {
this.setState({resetting: true});
axios.get('?', {params: {reset: 1}})
axios.get(window.location.pathname, {params: {reset: 1}})
.then((response) => {
console.log('success: ', response.data);
});
Expand Down Expand Up @@ -329,6 +329,16 @@ function GeneralInfo(props) {


function Directives(props) {
let directiveList = (directive) => {
return (
<ul className="directive-list">{
directive.v.map((item, key) => {
return <li key={key}>{item}</li>
})
}</ul>
);
};

let directiveNodes = props.directives.map(function(directive) {
let map = { 'opcache.':'', '_':' ' };
let dShow = directive.k.replace(/opcache\.|_/gi, function(matched){
Expand All @@ -341,9 +351,7 @@ function Directives(props) {
vShow = React.createElement('i', {}, 'no value');
} else {
if (Array.isArray(directive.v)) {
vShow = directive.v.map((item, key) => {
return <span key={key}>{item}<br/></span>
});
vShow = directiveList(directive);
} else {
vShow = directive.v;
}
Expand Down Expand Up @@ -677,7 +685,7 @@ class CachedFiles extends React.Component {
handleInvalidate = e => {
e.preventDefault();
if (this.props.realtime) {
axios.get('?', {params: { invalidate_searched: this.state.searchTerm }})
axios.get(window.location.pathname, {params: { invalidate_searched: this.state.searchTerm }})
.then((response) => {
console.log('success: ' , response.data);
});
Expand Down Expand Up @@ -799,7 +807,7 @@ class CachedFile extends React.Component {
handleInvalidate = e => {
e.preventDefault();
if (this.props.realtime) {
axios.get('?', {params: { invalidate: e.currentTarget.getAttribute('data-file') }})
axios.get(window.location.pathname, {params: { invalidate: e.currentTarget.getAttribute('data-file') }})
.then((response) => {
console.log('success: ' , response.data);
});
Expand Down
15 changes: 14 additions & 1 deletion build/_frontend/interface.scss
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,20 @@ $footer-border-color: #CCC;
}
}

.directive-list {
list-style-type: none;
padding: 0;
margin: 0;

li {
margin-bottom: 0.5em;

&:last-child {
margin-bottom: 0;
}
}
}

.file-filter {
width: 520px;
}
Expand Down Expand Up @@ -324,7 +338,6 @@ $footer-border-color: #CCC;
display: inline-block;

a {
display: inline-block;
display: inline-flex;
align-items: center;
white-space: nowrap;
Expand Down
2 changes: 1 addition & 1 deletion build/build.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
* OPcache GUI - build script
*
* @author Andrew Collington, andy@amnuts.com
* @version 3.2.0
* @version 3.2.1
* @link https://github.com/amnuts/opcache-gui
* @license MIT, http://acollington.mit-license.org/
*/
Expand Down
2 changes: 1 addition & 1 deletion build/template.phps
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ namespace Amnuts\Opcache;
* A simple but effective single-file GUI for the OPcache PHP extension.
*
* @author Andrew Collington, andy@amnuts.com
* @version 3.2.0
* @version 3.2.1
* @link https://github.com/amnuts/opcache-gui
* @license MIT, http://acollington.mit-license.org/
*/
Expand Down
34 changes: 20 additions & 14 deletions index.php

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "opcache-gui",
"description": "A clean and responsive interface for Zend OPcache information, showing statistics, settings and cached files, and providing a real-time update for the information (using jQuery and React).",
"version": "3.2.0",
"version": "3.2.1",
"main": "index.js",
"devDependencies": {
"@babel/cli": "^7.12.8",
Expand Down
6 changes: 3 additions & 3 deletions src/Opcache/Service.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

class Service
{
const VERSION = '3.2.0';
const VERSION = '3.2.1';

protected $data;
protected $options;
Expand Down Expand Up @@ -210,7 +210,7 @@ protected function compileState(): array
$files = [];
if (!empty($status['scripts']) && $this->getOption('allow_filelist')) {
uasort($status['scripts'], function ($a, $b) {
return $a['hits'] < $b['hits'];
return $a['hits'] <=> $b['hits'];
});
foreach ($status['scripts'] as &$file) {
$file['full_path'] = str_replace('\\', '/', $file['full_path']);
Expand Down Expand Up @@ -287,7 +287,7 @@ protected function compileState(): array
$levels = [];
foreach ($this->optimizationLevels as $level => $info) {
if ($level & $v) {
$levels[] = $info;
$levels[] = "{$info} [{$level}]";
}
}
$v = $levels ?: 'none';
Expand Down

0 comments on commit 240b965

Please sign in to comment.