mirror of
https://github.com/ascribe/onion.git
synced 2025-01-03 18:35:09 +01:00
create artwork component
This commit is contained in:
parent
9c58fa321c
commit
47246a9083
@ -9,7 +9,7 @@ class ArtworkListActions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fetchArtworkList() {
|
fetchArtworkList() {
|
||||||
ArtworkFetcher.fetch()
|
ArtworkFetcher.fetch(1, 10)
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
this.actions.updateArtworkList(res.pieces);
|
this.actions.updateArtworkList(res.pieces);
|
||||||
})
|
})
|
||||||
|
11
js/components/artwork.js
Normal file
11
js/components/artwork.js
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
let Artwork = React.createClass({
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<p>this.props.artwork.title</p>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
export default Artwork;
|
@ -1,7 +1,10 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import Router from 'react-router';
|
||||||
|
|
||||||
import ArtworkListStore from '../stores/artwork_list_store';
|
import ArtworkListStore from '../stores/artwork_list_store';
|
||||||
import ArtworkListActions from '../actions/artwork_list_actions';
|
import ArtworkListActions from '../actions/artwork_list_actions';
|
||||||
|
|
||||||
|
let Link = Router.Link;
|
||||||
|
|
||||||
var ArtworkList = React.createClass({
|
var ArtworkList = React.createClass({
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
@ -26,7 +29,7 @@ var ArtworkList = React.createClass({
|
|||||||
<ul>
|
<ul>
|
||||||
{this.state.artworkList.map((artwork, i) => {
|
{this.state.artworkList.map((artwork, i) => {
|
||||||
return (
|
return (
|
||||||
<li key={i}>{artwork.title}</li>
|
<li key={i}><Link to="artwork" params={{'bitcoin_ID_noPrefix': artwork.bitcoin_ID_noPrefix}}>{artwork.title}</Link></li>
|
||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -14,7 +14,6 @@ class AscribeApp extends React.Component {
|
|||||||
<navigation>
|
<navigation>
|
||||||
<Link to="artworks">artworks</Link>
|
<Link to="artworks">artworks</Link>
|
||||||
</navigation>
|
</navigation>
|
||||||
|
|
||||||
<RouteHandler />
|
<RouteHandler />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
var constants = {
|
var constants = {
|
||||||
'baseUrl': 'http://staging.ascribe.io/api/'
|
'baseUrl': 'http://staging.ascribe.io/api/',
|
||||||
|
'debugCredentialBase64': 'ZGltaUBtYWlsaW5hdG9yLmNvbTowMDAwMDAwMDAw' // dimi@mailinator:0000000000
|
||||||
};
|
};
|
||||||
|
|
||||||
export default constants;
|
export default constants;
|
@ -4,15 +4,24 @@ import AppConstants from '../constants/application_constants';
|
|||||||
import FetchApiUtils from '../utils/fetch_api_utils';
|
import FetchApiUtils from '../utils/fetch_api_utils';
|
||||||
|
|
||||||
var ArtworkListFetcher = {
|
var ArtworkListFetcher = {
|
||||||
fetch(page=1, pageSize=10) {
|
/**
|
||||||
|
* Fetches a list of pieces from the API.
|
||||||
|
* Can be called with all supplied queryparams the API.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
fetch(page, pageSize, search, ordering) {
|
||||||
|
|
||||||
let params = FetchApiUtils.argsToQueryParams({
|
let params = FetchApiUtils.argsToQueryParams({
|
||||||
page,
|
page,
|
||||||
pageSize
|
pageSize,
|
||||||
|
search,
|
||||||
|
ordering
|
||||||
});
|
});
|
||||||
|
|
||||||
return fetch(AppConstants.baseUrl + 'pieces/' + params, {
|
return fetch(AppConstants.baseUrl + 'pieces/' + params, {
|
||||||
headers: {
|
headers: {
|
||||||
'Authorization': 'Basic ZGltaUBtYWlsaW5hdG9yLmNvbTowMDAwMDAwMDAw'
|
'Authorization': 'Basic ' + AppConstants.debugCredentialBase64
|
||||||
}
|
}
|
||||||
}).then((res) => res.json());
|
}).then((res) => res.json());
|
||||||
}
|
}
|
||||||
|
@ -3,12 +3,14 @@ import Router from 'react-router';
|
|||||||
|
|
||||||
import AscribeApp from './components/ascribe_app';
|
import AscribeApp from './components/ascribe_app';
|
||||||
import ArtworkList from './components/artwork_list';
|
import ArtworkList from './components/artwork_list';
|
||||||
|
import Artwork from './components/artwork';
|
||||||
|
|
||||||
var Route = Router.Route;
|
var Route = Router.Route;
|
||||||
|
|
||||||
var routes = (
|
var routes = (
|
||||||
<Route name="app" path="/" handler={AscribeApp}>
|
<Route name="app" path="/" handler={AscribeApp}>
|
||||||
<Route name="artworks" handler={ArtworkList} />
|
<Route name="artworks" handler={ArtworkList} />
|
||||||
|
<Route name="artwork" path="/artworks/:bitcoin_ID_noPrefix" handler={Artwork} />
|
||||||
</Route>
|
</Route>
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
import GeneralUtils from './general_utils';
|
||||||
|
|
||||||
|
// TODO: Create Unittests that test all functions
|
||||||
let FetchApiUtils = {
|
let FetchApiUtils = {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -15,10 +18,11 @@ let FetchApiUtils = {
|
|||||||
*
|
*
|
||||||
* CamelCase gets converted to snake_case!
|
* CamelCase gets converted to snake_case!
|
||||||
*
|
*
|
||||||
* @param {[type]}
|
|
||||||
* @return {[type]}
|
|
||||||
*/
|
*/
|
||||||
argsToQueryParams(obj) {
|
argsToQueryParams(obj) {
|
||||||
|
|
||||||
|
obj = GeneralUtils.sanitize(obj);
|
||||||
|
|
||||||
return Object
|
return Object
|
||||||
.keys(obj)
|
.keys(obj)
|
||||||
.map((key, i) => {
|
.map((key, i) => {
|
||||||
|
22
js/utils/general_utils.js
Normal file
22
js/utils/general_utils.js
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
// TODO: Create Unittests that test all functions
|
||||||
|
|
||||||
|
let GeneralUtils = {
|
||||||
|
/**
|
||||||
|
* Removes undefined and null values from an key-value object.
|
||||||
|
*/
|
||||||
|
sanitize(obj) {
|
||||||
|
Object
|
||||||
|
.keys(obj)
|
||||||
|
.map((key) => {
|
||||||
|
// By matching null with a double equal, we can match undefined and null
|
||||||
|
// http://stackoverflow.com/a/15992131
|
||||||
|
if(obj[key] == null) {
|
||||||
|
delete obj[key];
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return obj;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export default GeneralUtils;
|
Loading…
Reference in New Issue
Block a user