diff --git a/packages/netlify-cms-core/src/components/App/App.js b/packages/netlify-cms-core/src/components/App/App.js index 3ff09bf5..a27b0a16 100644 --- a/packages/netlify-cms-core/src/components/App/App.js +++ b/packages/netlify-cms-core/src/components/App/App.js @@ -169,6 +169,7 @@ class App extends React.Component { openMediaLibrary={openMediaLibrary} hasWorkflow={hasWorkflow} displayUrl={config.get('display_url')} + isTestRepo={config.getIn(['backend', 'name']) === 'test-repo'} showMediaButton={showMediaButton} /> diff --git a/packages/netlify-cms-core/src/components/App/Header.js b/packages/netlify-cms-core/src/components/App/Header.js index ddb63d0d..27134f7d 100644 --- a/packages/netlify-cms-core/src/components/App/Header.js +++ b/packages/netlify-cms-core/src/components/App/Header.js @@ -118,6 +118,7 @@ class Header extends React.Component { openMediaLibrary: PropTypes.func.isRequired, hasWorkflow: PropTypes.bool.isRequired, displayUrl: PropTypes.string, + isTestRepo: PropTypes.bool, t: PropTypes.func.isRequired, }; @@ -136,6 +137,7 @@ class Header extends React.Component { openMediaLibrary, hasWorkflow, displayUrl, + isTestRepo, t, showMediaButton, } = this.props; @@ -198,6 +200,7 @@ class Header extends React.Component { )} diff --git a/packages/netlify-cms-core/src/components/UI/SettingsDropdown.js b/packages/netlify-cms-core/src/components/UI/SettingsDropdown.js index f14df219..a3562c69 100644 --- a/packages/netlify-cms-core/src/components/UI/SettingsDropdown.js +++ b/packages/netlify-cms-core/src/components/UI/SettingsDropdown.js @@ -39,6 +39,13 @@ const AppHeaderSiteLink = styled.a` padding: 10px 16px; `; +const AppHeaderTestRepoIndicator = styled.a` + font-size: 14px; + font-weight: 400; + color: #7b8290; + padding: 10px 16px; +`; + const Avatar = ({ imageUrl }) => imageUrl ? : ; @@ -46,8 +53,17 @@ Avatar.propTypes = { imageUrl: PropTypes.string, }; -const SettingsDropdown = ({ displayUrl, imageUrl, onLogoutClick, t }) => ( +const SettingsDropdown = ({ displayUrl, isTestRepo, imageUrl, onLogoutClick, t }) => ( + {isTestRepo && ( + + Test Backend ↗ + + )} {displayUrl ? ( {stripProtocol(displayUrl)} @@ -70,6 +86,7 @@ const SettingsDropdown = ({ displayUrl, imageUrl, onLogoutClick, t }) => ( SettingsDropdown.propTypes = { displayUrl: PropTypes.string, + isTestRepo: PropTypes.bool, imageUrl: PropTypes.string, onLogoutClick: PropTypes.func.isRequired, t: PropTypes.func.isRequired,