1
0
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:
Tim Daubenschütz 2015-05-19 17:01:28 +02:00
parent 9c58fa321c
commit 47246a9083
9 changed files with 60 additions and 9 deletions

View File

@ -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
View File

@ -0,0 +1,11 @@
import React from 'react';
let Artwork = React.createClass({
render() {
return (
<p>this.props.artwork.title</p>
);
}
});
export default Artwork;

View File

@ -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>

View File

@ -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>
); );

View File

@ -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;

View File

@ -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());
} }

View File

@ -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>
); );

View File

@ -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
View 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;