diff options
author | Stas Vilchik <vilchiks@gmail.com> | 2017-03-13 16:41:46 +0100 |
---|---|---|
committer | Stas Vilchik <stas-vilchik@users.noreply.github.com> | 2017-03-14 10:39:38 +0100 |
commit | 796469600844cbbe5727e10761be8582b045ebf9 (patch) | |
tree | 7dfa10752765e01eb0c91475da05b8947d672179 /server/sonar-web/src/main/js | |
parent | c3358eec573fb6fbc171843f0b4fcb9fe51f139c (diff) | |
download | sonarqube-796469600844cbbe5727e10761be8582b045ebf9.tar.gz sonarqube-796469600844cbbe5727e10761be8582b045ebf9.zip |
SONAR-8778 display deprecated key and its version
Diffstat (limited to 'server/sonar-web/src/main/js')
4 files changed, 159 insertions, 61 deletions
diff --git a/server/sonar-web/src/main/js/api/web-api.js b/server/sonar-web/src/main/js/api/web-api.js index 5ccf16624f6..bc58899bf9d 100644 --- a/server/sonar-web/src/main/js/api/web-api.js +++ b/server/sonar-web/src/main/js/api/web-api.js @@ -20,7 +20,7 @@ // @flow import { getJSON } from '../helpers/request'; -type Param = { +export type Param = { key: string, defaultValue?: string, description: string, @@ -33,7 +33,7 @@ type Param = { required: boolean }; -type Action = { +export type Action = { key: string, description: string, deprecatedSince?: string, @@ -48,7 +48,7 @@ type Action = { params?: Array<Param> }; -type Domain = { +export type Domain = { actions: Array<Action>, description: string, internal: boolean, diff --git a/server/sonar-web/src/main/js/apps/web-api/components/Params.js b/server/sonar-web/src/main/js/apps/web-api/components/Params.js index d258075ee50..ac8459cc2f2 100644 --- a/server/sonar-web/src/main/js/apps/web-api/components/Params.js +++ b/server/sonar-web/src/main/js/apps/web-api/components/Params.js @@ -17,83 +17,98 @@ * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ +// @flow import React from 'react'; import InternalBadge from './InternalBadge'; import DeprecatedBadge from './DeprecatedBadge'; +import type { Param } from '../../../api/web-api'; -export default function Params ({ params, showInternal }) { - const displayedParameters = showInternal ? params : params.filter(p => !p.internal); +export default class Params extends React.PureComponent { + props: { + params: Array<Param>, + showInternal: boolean + }; - return ( + render () { + const { showInternal, params } = this.props; + const displayedParameters = showInternal ? params : params.filter(p => !p.internal); + + return ( <div className="web-api-params"> <table> <tbody> {displayedParameters.map(param => ( - <tr key={param.key}> - <td style={{ width: 180 }}> - <code>{param.key}</code> + <tr key={param.key}> + <td className="markdown" style={{ width: 180 }}> + <code>{param.key}</code> - {param.internal && ( - <div className="little-spacer-top"> - <InternalBadge/> - </div> - )} + {param.internal && + <div className="little-spacer-top"> + <InternalBadge/> + </div>} - {param.deprecatedSince && ( - <div className="little-spacer-top"> - <DeprecatedBadge since={param.deprecatedSince}/> - </div> - )} + {param.deprecatedSince && + <div className="little-spacer-top"> + <DeprecatedBadge since={param.deprecatedSince}/> + </div>} - <div className="note little-spacer-top"> - {param.required ? 'required' : 'optional'} - </div> + {param.deprecatedKey && + <div className="little-spacer-top"> + <code>{param.deprecatedKey}</code> + </div>} + + {param.deprecatedKey && + param.deprecatedKeySince && + <div className="little-spacer-top"> + <DeprecatedBadge since={param.deprecatedKeySince}/> + </div>} - {param.since && ( - <div className="note little-spacer-top"> - since {param.since} - </div> - )} - </td> + <div className="note little-spacer-top"> + {param.required ? 'required' : 'optional'} + </div> + + {param.since && + <div className="note little-spacer-top"> + since {param.since} + </div>} + </td> - <td> - <div - className="markdown" - dangerouslySetInnerHTML={{ __html: param.description }}/> - </td> + <td> + <div + className="markdown" + dangerouslySetInnerHTML={{ __html: param.description }}/> + </td> - <td style={{ width: 250 }}> - {param.possibleValues && ( - <div> - <h4>Possible values</h4> - <ul className="list-styled"> - {param.possibleValues.map(value => ( - <li key={value} className="little-spacer-top"> - <code>{value}</code> - </li> - ))} - </ul> - </div> - )} + <td style={{ width: 250 }}> + {param.possibleValues && + <div> + <h4>Possible values</h4> + <ul className="list-styled"> + {param.possibleValues.map(value => ( + <li key={value} className="little-spacer-top"> + <code>{value}</code> + </li> + ))} + </ul> + </div>} - {param.defaultValue && ( - <div className="little-spacer-top"> - <h4>Default value</h4> - <code>{param.defaultValue}</code> - </div> - )} + {param.defaultValue && + <div className="little-spacer-top"> + <h4>Default value</h4> + <code>{param.defaultValue}</code> + </div>} - {param.exampleValue && ( - <div className="little-spacer-top"> - <h4>Example value</h4> - <code>{param.exampleValue}</code> - </div> - )} - </td> - </tr> + {param.exampleValue && + <div className="little-spacer-top"> + <h4>Example value</h4> + <code>{param.exampleValue}</code> + </div>} + </td> + </tr> ))} </tbody> </table> </div> - ); + ); + } } diff --git a/server/sonar-web/src/main/js/apps/web-api/components/__tests__/Params-test.js b/server/sonar-web/src/main/js/apps/web-api/components/__tests__/Params-test.js new file mode 100644 index 00000000000..c3d0a92834c --- /dev/null +++ b/server/sonar-web/src/main/js/apps/web-api/components/__tests__/Params-test.js @@ -0,0 +1,31 @@ +/* + * SonarQube + * Copyright (C) 2009-2017 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +import React from 'react'; +import { shallow } from 'enzyme'; +import Params from '../Params'; + +it('should render deprecated key', () => { + const params = [{ + key: 'foo', + deprecatedKey: 'foo-deprecated', + deprecatedKeySince: '5.0' + }]; + expect(shallow(<Params params={params} showInternal={true}/>)).toMatchSnapshot(); +}); diff --git a/server/sonar-web/src/main/js/apps/web-api/components/__tests__/__snapshots__/Params-test.js.snap b/server/sonar-web/src/main/js/apps/web-api/components/__tests__/__snapshots__/Params-test.js.snap new file mode 100644 index 00000000000..e96ab29ed2d --- /dev/null +++ b/server/sonar-web/src/main/js/apps/web-api/components/__tests__/__snapshots__/Params-test.js.snap @@ -0,0 +1,52 @@ +exports[`test should render deprecated key 1`] = ` +<div + className="web-api-params"> + <table> + <tbody> + <tr> + <td + className="markdown" + style={ + Object { + "width": 180, + } + }> + <code> + foo + </code> + <div + className="little-spacer-top"> + <code> + foo-deprecated + </code> + </div> + <div + className="little-spacer-top"> + <DeprecatedBadge + since="5.0" /> + </div> + <div + className="note little-spacer-top"> + optional + </div> + </td> + <td> + <div + className="markdown" + dangerouslySetInnerHTML={ + Object { + "__html": undefined, + } + } /> + </td> + <td + style={ + Object { + "width": 250, + } + } /> + </tr> + </tbody> + </table> +</div> +`; |