From 2706f04f3a713e5256f1dd41576be5584596bcdb Mon Sep 17 00:00:00 2001 From: Brett Sun Date: Mon, 27 Jun 2016 11:30:32 +0200 Subject: [PATCH] Add exports for custom propTypes as shape specs rather than the complete shape Allows easier composition of the shapes in case we need to extend them in components later --- js/components/prop_types/current_user_shape.js | 9 +++++++-- js/components/prop_types/index.js | 4 ++-- js/components/prop_types/whitelabel_shape.js | 9 +++++++-- 3 files changed, 16 insertions(+), 6 deletions(-) diff --git a/js/components/prop_types/current_user_shape.js b/js/components/prop_types/current_user_shape.js index 5735f384..d854450b 100644 --- a/js/components/prop_types/current_user_shape.js +++ b/js/components/prop_types/current_user_shape.js @@ -3,10 +3,15 @@ import React from 'react'; const { number, object, shape, string } = React.PropTypes; -export default shape({ +const currentUserShapeSpec = { acl: object, email: string, id: number, profile: object, username: string -}); +}; + +export default shape(currentUserShapeSpec); +export { + currentUserShapeSpec +}; diff --git a/js/components/prop_types/index.js b/js/components/prop_types/index.js index e5f818dd..5b69a304 100644 --- a/js/components/prop_types/index.js +++ b/js/components/prop_types/index.js @@ -1,5 +1,5 @@ -export { default as currentUserShape } from './current_user_shape'; -export { default as whitelabelShape } from './whitelabel_shape'; +export currentUserShape from './current_user_shape'; +export whitelabelShape from './whitelabel_shape'; // Re-export PropTypes from react-router export { locationShape, routerShape } from 'react-router/es6/PropTypes'; diff --git a/js/components/prop_types/whitelabel_shape.js b/js/components/prop_types/whitelabel_shape.js index 72f8bc36..63c5b1a8 100644 --- a/js/components/prop_types/whitelabel_shape.js +++ b/js/components/prop_types/whitelabel_shape.js @@ -3,9 +3,14 @@ import React from 'react'; const { shape, string } = React.PropTypes; -export default shape({ +const whitelabelShapeSpec = { name: string, subdomain: string, title: string, user: string -}); +}; + +export default shape(whitelabelShapeSpec); +export { + whitelabelShapeSpec +};