Minor tweaks to client code

This commit is contained in:
Michael Jackson 2019-07-09 16:13:55 -07:00
parent 69030142da
commit 08c66598a0
4 changed files with 61 additions and 65 deletions

View File

@ -1,7 +1,7 @@
import React from 'react'; import React from 'react';
import ReactDOM from 'react-dom'; import ReactDOM from 'react-dom';
import App from './autoIndex/App'; import App from './autoIndex/App.js';
const props = window.__DATA__ || {}; const props = window.__DATA__ || {};

View File

@ -1,9 +1,8 @@
/** @jsx jsx */ /** @jsx jsx */
import React from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import { Global, css, jsx } from '@emotion/core'; import { Global, css, jsx } from '@emotion/core';
import DirectoryListing from './DirectoryListing'; import DirectoryListing from './DirectoryListing.js';
const globalStyles = css` const globalStyles = css`
body { body {
@ -16,69 +15,66 @@ const globalStyles = css`
} }
`; `;
export default class App extends React.Component { export default function App({
static defaultProps = { packageName,
availableVersions: [] packageVersion,
}; availableVersions = [],
filename,
handleChange = event => { entry,
entries
}) {
function handleChange(event) {
window.location.href = window.location.href.replace( window.location.href = window.location.href.replace(
'@' + this.props.packageVersion, '@' + packageVersion,
'@' + event.target.value '@' + event.target.value
); );
};
render() {
return (
<div css={{ maxWidth: 900, margin: '0 auto' }}>
<Global styles={globalStyles} />
<header
css={{
display: 'flex',
flexDirection: 'row',
alignItems: 'center',
justifyContent: 'space-between'
}}
>
<h1>
Index of /{this.props.packageName}@{this.props.packageVersion}
{this.props.filename}
</h1>
<div css={{ float: 'right', lineHeight: '2.25em' }}>
Version:{' '}
<select
id="version"
defaultValue={this.props.packageVersion}
onChange={this.handleChange}
css={{ fontSize: '1em' }}
>
{this.props.availableVersions.map(v => (
<option key={v} value={v}>
{v}
</option>
))}
</select>
</div>
</header>
<hr />
<DirectoryListing
filename={this.props.filename}
entry={this.props.entry}
entries={this.props.entries}
/>
<hr />
<address css={{ textAlign: 'right' }}>
{this.props.packageName}@{this.props.packageVersion}
</address>
</div>
);
} }
return (
<div css={{ maxWidth: 900, margin: '0 auto' }}>
<Global styles={globalStyles} />
<header
css={{
display: 'flex',
flexDirection: 'row',
alignItems: 'center',
justifyContent: 'space-between'
}}
>
<h1>
Index of /{packageName}@{packageVersion}
{filename}
</h1>
<div css={{ float: 'right', lineHeight: '2.25em' }}>
Version:{' '}
<select
id="version"
defaultValue={packageVersion}
onChange={handleChange}
css={{ fontSize: '1em' }}
>
{availableVersions.map(v => (
<option key={v} value={v}>
{v}
</option>
))}
</select>
</div>
</header>
<hr />
<DirectoryListing filename={filename} entry={entry} entries={entries} />
<hr />
<address css={{ textAlign: 'right' }}>
{packageName}@{packageVersion}
</address>
</div>
);
} }
if (process.env.NODE_ENV !== 'production') { if (process.env.NODE_ENV !== 'production') {

View File

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import ReactDOM from 'react-dom'; import ReactDOM from 'react-dom';
import App from './main/App'; import App from './main/App.js';
ReactDOM.render(<App />, document.getElementById('root')); ReactDOM.render(<App />, document.getElementById('root'));

View File

@ -6,8 +6,8 @@ import formatBytes from 'pretty-bytes';
import formatDate from 'date-fns/format'; import formatDate from 'date-fns/format';
import parseDate from 'date-fns/parse'; import parseDate from 'date-fns/parse';
import formatNumber from '../utils/formatNumber'; import formatNumber from '../utils/formatNumber.js';
import formatPercent from '../utils/formatPercent'; import formatPercent from '../utils/formatPercent.js';
import cloudflareLogo from './CloudflareLogo.png'; import cloudflareLogo from './CloudflareLogo.png';
import angularLogo from './AngularLogo.png'; import angularLogo from './AngularLogo.png';