X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fcomponents%2Ftechniques%2FDetail.js;h=9d9534ed31f2d6831f883fa2ce043975e90958e7;hb=6976d85a7117de53f7d42dee3de1f6b8fcb9726d;hp=d586a9a159375e544d8b4f4bb0b04d8b3eb2299b;hpb=7e8555cfc96dcd364ca4fe9895e51af1bb04b546;p=alttp.git diff --git a/resources/js/components/techniques/Detail.js b/resources/js/components/techniques/Detail.js index d586a9a..9d9534e 100644 --- a/resources/js/components/techniques/Detail.js +++ b/resources/js/components/techniques/Detail.js @@ -1,21 +1,52 @@ import PropTypes from 'prop-types'; import React from 'react'; -import { Container } from 'react-bootstrap'; +import { Alert, Container } from 'react-bootstrap'; +import { withTranslation } from 'react-i18next'; +import List from './List'; import Outline from './Outline'; +import Requirements from './Requirements'; +import Rulesets from './Rulesets'; +import RawHTML from '../common/RawHTML'; +import { + getRelations, + getTranslation, + hasRelations, + sorted, +} from '../../helpers/Technique'; +import i18n from '../../i18n'; const Detail = ({ technique }) => -

{technique.title}

+
+

{getTranslation(technique, 'title', i18n.language)}

+ {technique && technique.rulesets ? + + : null} +
-
+ + {technique.chapters ? technique.chapters.map(chapter =>
{chapter.pivot.level ? - React.createElement(`h${chapter.pivot.level}`, {}, chapter.title) + React.createElement( + `h${chapter.pivot.level}`, + {}, + getTranslation(chapter, 'title', i18n.language), + ) : null} -
+
) : null} + {hasRelations(technique, 'related') ? <> +

{i18n.t('techniques.seeAlso')}

+ + : null} + {getTranslation(technique, 'attribution', i18n.language) ? + + + + : null} ; Detail.propTypes = { @@ -23,8 +54,10 @@ Detail.propTypes = { chapters: PropTypes.arrayOf(PropTypes.shape({ })), description: PropTypes.string, + rulesets: PropTypes.shape({ + }), title: PropTypes.string, }), }; -export default Detail; +export default withTranslation()(Detail);