diff options
Diffstat (limited to 'server/sonar-web')
6 files changed, 67 insertions, 13 deletions
diff --git a/server/sonar-web/src/main/js/apps/code/components/PortfolioNewCodeToggle.tsx b/server/sonar-web/src/main/js/apps/code/components/PortfolioNewCodeToggle.tsx index b69acfffd56..fe5b0c1b44b 100644 --- a/server/sonar-web/src/main/js/apps/code/components/PortfolioNewCodeToggle.tsx +++ b/server/sonar-web/src/main/js/apps/code/components/PortfolioNewCodeToggle.tsx @@ -19,29 +19,35 @@ */ import * as React from 'react'; import { Button } from '../../../components/controls/buttons'; +import Tooltip from '../../../components/controls/Tooltip'; import { translate } from '../../../helpers/l10n'; export interface PortfolioNewCodeToggleProps { + enabled: boolean; showNewCode: boolean; onNewCodeToggle: (newSelected: boolean) => void; } export default function PortfolioNewCodeToggle(props: PortfolioNewCodeToggleProps) { - const { showNewCode } = props; + const { showNewCode, enabled } = props; return ( - <div className="big-spacer-right"> - <div className="button-group"> + <Tooltip + overlay={translate('code_viewer.portfolio_code_toggle_disabled.help')} + visible={enabled ? false : undefined}> + <div className="big-spacer-right button-group"> <Button + disabled={!enabled} className={showNewCode ? 'button-active' : undefined} onClick={() => props.onNewCodeToggle(true)}> {translate('projects.view.new_code')} </Button> <Button + disabled={!enabled} className={showNewCode ? undefined : 'button-active'} onClick={() => props.onNewCodeToggle(false)}> {translate('projects.view.overall_code')} </Button> </div> - </div> + </Tooltip> ); } diff --git a/server/sonar-web/src/main/js/apps/code/components/Search.tsx b/server/sonar-web/src/main/js/apps/code/components/Search.tsx index 188c4dff9c1..740504eabd9 100644 --- a/server/sonar-web/src/main/js/apps/code/components/Search.tsx +++ b/server/sonar-web/src/main/js/apps/code/components/Search.tsx @@ -17,7 +17,7 @@ * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -import { omit } from 'lodash'; +import { isEmpty, omit } from 'lodash'; import * as React from 'react'; import { getTree } from '../../../api/components'; import SearchBox from '../../../components/controls/SearchBox'; @@ -133,13 +133,14 @@ export class Search extends React.PureComponent<Props, State> { render() { const { component, newCodeSelected } = this.props; - const { loading } = this.state; + const { loading, query } = this.state; const isPortfolio = ['VW', 'SVW', 'APP'].includes(component.qualifier); return ( <div className="code-search" id="code-search"> {isPortfolio && ( <PortfolioNewCodeToggle + enabled={isEmpty(query)} onNewCodeToggle={this.props.onNewCodeToggle} showNewCode={newCodeSelected} /> diff --git a/server/sonar-web/src/main/js/apps/code/components/__tests__/PortfolioNewCodeToggle-test.tsx b/server/sonar-web/src/main/js/apps/code/components/__tests__/PortfolioNewCodeToggle-test.tsx index 7ac8ef235ad..458246b4af1 100644 --- a/server/sonar-web/src/main/js/apps/code/components/__tests__/PortfolioNewCodeToggle-test.tsx +++ b/server/sonar-web/src/main/js/apps/code/components/__tests__/PortfolioNewCodeToggle-test.tsx @@ -20,12 +20,20 @@ import { shallow } from 'enzyme'; import * as React from 'react'; import { Button } from '../../../../components/controls/buttons'; +import Tooltip from '../../../../components/controls/Tooltip'; import PortfolioNewCodeToggle, { PortfolioNewCodeToggleProps } from '../PortfolioNewCodeToggle'; it('renders correctly', () => { expect(shallowRender()).toMatchSnapshot(); }); +it('should show tooltips when disabled', () => { + const wrapper = shallowRender({ enabled: false }); + expect(wrapper.find(Tooltip).props().visible).toBeUndefined(); + wrapper.setProps({ enabled: true }); + expect(wrapper.find(Tooltip).props().visible).toBe(false); +}); + it('should toggle correctly', () => { const onNewCodeToggle = jest.fn(); const wrapper = shallowRender({ onNewCodeToggle }); @@ -46,6 +54,11 @@ it('should toggle correctly', () => { function shallowRender(props?: Partial<PortfolioNewCodeToggleProps>) { return shallow( - <PortfolioNewCodeToggle showNewCode={true} onNewCodeToggle={jest.fn()} {...props} /> + <PortfolioNewCodeToggle + showNewCode={true} + enabled={true} + onNewCodeToggle={jest.fn()} + {...props} + /> ); } diff --git a/server/sonar-web/src/main/js/apps/code/components/__tests__/Search-test.tsx b/server/sonar-web/src/main/js/apps/code/components/__tests__/Search-test.tsx index e050a1d9092..b816ba31631 100644 --- a/server/sonar-web/src/main/js/apps/code/components/__tests__/Search-test.tsx +++ b/server/sonar-web/src/main/js/apps/code/components/__tests__/Search-test.tsx @@ -44,7 +44,13 @@ it('should render correcly', () => { expect(shallowRender()).toMatchSnapshot(); expect( shallowRender({ component: mockComponent({ qualifier: ComponentQualifier.Portfolio }) }) - ).toMatchSnapshot('node code toggle for portfolio'); + ).toMatchSnapshot('new code toggle for portfolio'); + expect( + shallowRender({ + component: mockComponent({ qualifier: ComponentQualifier.Portfolio }), + location: mockLocation({ query: { id: 'foo', search: 'bar' } }) + }) + ).toMatchSnapshot('new code toggle for portfolio disabled'); }); it('should search correct query on mount', async () => { diff --git a/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/PortfolioNewCodeToggle-test.tsx.snap b/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/PortfolioNewCodeToggle-test.tsx.snap index 0a91ab15adf..c8e72a5fdf5 100644 --- a/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/PortfolioNewCodeToggle-test.tsx.snap +++ b/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/PortfolioNewCodeToggle-test.tsx.snap @@ -1,23 +1,26 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`renders correctly 1`] = ` -<div - className="big-spacer-right" +<Tooltip + overlay="code_viewer.portfolio_code_toggle_disabled.help" + visible={false} > <div - className="button-group" + className="big-spacer-right button-group" > <Button className="button-active" + disabled={false} onClick={[Function]} > projects.view.new_code </Button> <Button + disabled={false} onClick={[Function]} > projects.view.overall_code </Button> </div> -</div> +</Tooltip> `; diff --git a/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/Search-test.tsx.snap b/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/Search-test.tsx.snap index 5ca52b0c451..ab28840e91c 100644 --- a/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/Search-test.tsx.snap +++ b/server/sonar-web/src/main/js/apps/code/components/__tests__/__snapshots__/Search-test.tsx.snap @@ -19,12 +19,13 @@ exports[`should render correcly 1`] = ` </div> `; -exports[`should render correcly: node code toggle for portfolio 1`] = ` +exports[`should render correcly: new code toggle for portfolio 1`] = ` <div className="code-search" id="code-search" > <PortfolioNewCodeToggle + enabled={true} onNewCodeToggle={[MockFunction]} showNewCode={false} /> @@ -41,3 +42,27 @@ exports[`should render correcly: node code toggle for portfolio 1`] = ` /> </div> `; + +exports[`should render correcly: new code toggle for portfolio disabled 1`] = ` +<div + className="code-search" + id="code-search" +> + <PortfolioNewCodeToggle + enabled={false} + onNewCodeToggle={[MockFunction]} + showNewCode={false} + /> + <SearchBox + minLength={3} + onChange={[Function]} + onKeyDown={[Function]} + placeholder="code.search_placeholder.portfolio" + value="bar" + /> + <DeferredSpinner + className="spacer-left" + loading={true} + /> +</div> +`; |