Skip to content

Commit

Permalink
feat: améliore le formulaire des métadonnées
Browse files Browse the repository at this point in the history
  • Loading branch information
ggrossetie committed Dec 3, 2024
1 parent 26603cd commit f69d0d7
Show file tree
Hide file tree
Showing 11 changed files with 280 additions and 1,071 deletions.
24 changes: 11 additions & 13 deletions front/src/components/Form.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -97,11 +97,9 @@ function ArrayFieldTemplate (properties) {
const addItemTitle = properties.uiSchema['ui:add-item-title'] ?? 'form.addItem.title'
const removeItemTitle = properties.uiSchema['ui:remove-item-title'] ?? 'form.removeItem.title'
const title = properties.uiSchema['ui:title']

const inlineRemoveButton = properties.schema?.items?.type === 'string' || !removeItemTitle
return (
<div className={styles.arrayField}>
<fieldset className={styles.fieldset} key={properties.key}>
<fieldset className={clsx(styles.fieldset, styles.array)} key={properties.key}>
{title && <Translation>{(t) =>
<legend id={properties.id}>{t(title)}</legend>}
</Translation>}
Expand All @@ -120,7 +118,6 @@ function ArrayFieldTemplate (properties) {
)}
{properties.items &&
properties.items.map((element) => {
console.log({ element })
return (
<div
id={element.key}
Expand All @@ -147,7 +144,6 @@ function ArrayFieldTemplate (properties) {
)
})}
</fieldset>
</div>
)
}

Expand Down Expand Up @@ -204,14 +200,16 @@ function ObjectFieldTemplate (properties) {
}
</Translation>
</legend>}
{elements.map(([field, element]) => (
element
? <Fragment key={field}>{element.content}</Fragment>
: <p key={field} className={styles.fieldHasNoElementError}>
Field <code>{field}</code> defined in <code>ui:groups</code> is not an
entry of <code>data-schema.json[properties]</code> object.
</p>
))}
{elements.map(([field, element]) => {
return (
element
? <Fragment key={field}>{element.content}</Fragment>
: <p key={field} className={styles.fieldHasNoElementError}>
Field <code>{field}</code> defined in <code>ui:groups</code> is not an
entry of <code>data-schema.json[properties]</code> object.
</p>
)
})}
</fieldset>
)
}
Expand Down
40 changes: 26 additions & 14 deletions front/src/components/Write/ArticleEditorMetadata.jsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { Toggle } from '@geist-ui/core'
import React, { useCallback, useMemo, useState } from 'react'
import { useDispatch, useSelector } from 'react-redux'
import PropTypes from 'prop-types'
Expand Down Expand Up @@ -73,20 +74,31 @@ export default function ArticleEditorMetadata ({ onChange, readOnly, metadata })
</button>
{expanded && (
<div className={styles.yamlEditor}>
<NavTag
defaultValue={selector}
onChange={setSelector}
items={[
{
value: 'basic',
name: t('write.basicMode.metadataButton'),
},
{
value: 'raw',
name: t('write.rawMode.metadataButton'),
},
]}
/>
<header className={styles.header}>
<h2>Metadonnées</h2>
<div className={styles.toggle} onClick={() => setSelector(selector === 'raw' ? 'basic' : 'raw')}>
<Toggle id="raw-mode" checked={selector === 'raw'} title={'Activer le mode YAML'} onChange={(e) => {
console.log(e)
setSelector(e.target.checked ? 'raw' : 'basic')
}}/>
<label htmlFor="raw-mode">YAML</label>
</div>
</header>

{/*<NavTag*/}
{/* defaultValue={selector}*/}
{/* onChange={setSelector}*/}
{/* items={[*/}
{/* {*/}
{/* value: 'basic',*/}
{/* name: t('write.basicMode.metadataButton'),*/}
{/* },*/}
{/* {*/}
{/* value: 'raw',*/}
{/* name: t('write.rawMode.metadataButton'),*/}
{/* },*/}
{/* ]}*/}
{/*/>*/}
{selector === 'raw' && (
<>
{error !== '' && <p className={styles.error}>{error}</p>}
Expand Down
23 changes: 22 additions & 1 deletion front/src/components/Write/articleEditorMetadata.module.scss
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
min-width: 375px;
max-width: 375px;
max-height: calc(100vh - 76px);
overflow-y: auto;
overflow-y: scroll;
padding: 1em 0.5em 2em 0.75em;

> button {
Expand Down Expand Up @@ -71,6 +71,27 @@
}
}

.toggle {
display: flex;
gap: 0.5rem;
justify-content: flex-end;
font-size: 1.125rem;
cursor: pointer;

> label {
cursor: pointer;
font-weight: 500;
user-select: none;
}
}

.header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1.25rem;
}

.yamlEditor {
display: flex;
flex-direction: column;
Expand Down
24 changes: 17 additions & 7 deletions front/src/components/form.module.scss
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,6 @@
> fieldset {
> button {
font-weight: bold;
margin: 0.5rem 0;
}
}
}
Expand Down Expand Up @@ -108,12 +107,16 @@
> * {
width: 100%;
}

&.person {
margin-top: 1rem;
}
}

&.field-string,
&.field-boolean {
label {
padding-bottom: 0.15rem;
padding-bottom: 0.15rem;
}
}

Expand Down Expand Up @@ -160,11 +163,11 @@
}
}
}

.array-item.keywords {
display: flex;
align-items: center;

> .field-string {
flex: 1;
}
Expand Down Expand Up @@ -217,11 +220,16 @@
gap: 0.5rem;
padding: 0 0 1.5rem;
margin: 0;
font-size: 1em;

legend {
@include legend;
padding: 0 0 0.5rem;
font-size: 1.25rem;
font-size: 1.15em;
}

fieldset {
font-size: 0.8em;
}
}

Expand All @@ -234,11 +242,13 @@

.addButton,
.removeButton {
font-size: .7em;
font-size: 1em;
margin-top: .25rem;
}

.inlineRemoveButton {
font-size: 1em;
font-size: 1rem;
margin-top: 0;
}

.output {
Expand Down
55 changes: 29 additions & 26 deletions front/src/locales/en/translation.json
Original file line number Diff line number Diff line change
Expand Up @@ -202,7 +202,6 @@
"article.metadata.url": "Article URL",
"article.metadata.url.placeholder": "Article URL",
"article.metadata.subtitle": "Subtitle",
"article.metadata.surtitle": "Surtitle",
"article.metadata.language": "Language",
"article.metadata.language.placeholder": "Select a language",
"article.metadata.publicationDate": "Publication date",
Expand All @@ -212,13 +211,6 @@
"article.metadata.journalIssue.placeholder": "Issue number",
"article.metadata.acknowledgements": "Acknowledgements",
"article.metadata.acknowledgements.title": "Acknowledgements",
"article.metadata.bibliography.title": "Bibliography",
"article.metadata.citationsLink": "Citation Link",
"article.metadata.citationsLink.yes": "Yes",
"article.metadata.citationsLink.no": "No",
"article.metadata.bibliographyDisplay": "Display",
"article.metadata.bibliographyDisplay.all": "All citations",
"article.metadata.bibliographyDisplay.onlyUsed": "Only used",
"article.metadata.authors": "Authors",
"article.metadata.authors.addItem": "Add an author",
"article.metadata.people.surname": "Last name",
Expand All @@ -237,12 +229,12 @@
"article.metadata.translationOf.lang": "Language",
"article.metadata.publisher": "Publisher",
"article.metadata.journal": "Journal",
"article.metadata.journalEmail": "Journal’s email",
"article.metadata.journal.name": "Name",
"article.metadata.journal.email": "Email",
"article.metadata.journal.publisher": "Publisher",
"article.metadata.journal.url": "URL",
"article.metadata.abstract": "Abstract",
"article.metadata.abstract.addItem": "Add an abstract in another language",
"article.metadata.abstract.text": "Abstract",
"article.metadata.abstract.lang": "Language",
"article.metadata.abstract.lang.placeholder": "Select a language",
"article.metadata.language.addItem": "Add a language",
"article.metadata.keywords": "Keywords",
"article.metadata.keywords.addItem": "Add a keyword",
"article.metadata.keywords.removeItem": "Remove this keyword",
Expand All @@ -251,10 +243,6 @@
"article.metadata.funder.title": "Funder",
"article.metadata.funder.name": "Organization",
"article.metadata.funder.id": "ID",
"article.metadata.translatedTitle.title": "Translated titles",
"article.metadata.translatedTitle.addItem": "Add a title in another language",
"article.metadata.translatedTitle.lang": "Language",
"article.metadata.translatedTitle.lang.placeholder": "Select a language",
"article.metadata.controlledKeywords": "Controlled keywords",
"article.metadata.controlledKeywords.addItem": "Add a controlled keyword",
"article.metadata.dossier": "Issue",
Expand All @@ -270,17 +258,32 @@
"article.metadata.type": "Categories",
"article.metadata.production.title": "Production",
"article.metadata.issnnum": "ISSN",
"article.metadata.prod": "Productor",
"article.metadata.prodnum": "Prodnum",
"article.metadata.diffnum": "Diffnum",
"article.metadata.type.essay": "Essay",
"article.metadata.type.creation": "Creation",
"article.metadata.type.lecture": "Lecture",
"article.metadata.type.dossierSummary": "Issue summary",
"article.metadata.type.interview": "Interview",
"article.metadata.type.editorialColumn": "Editorial column",
"article.metadata.production": "Production",
"article.metadata.headerTitle": "Article",
"article.metadata.titleAndAbstract": "Title and abstract",
"article.metadata.localizedContent": "Localized content",
"article.metadata.funder": "Funder",
"article.metadata.journalDirectors": "Journal directors",
"article.metadata.production.entities": "Production entities",
"article.metadata.production.entities.addItem": "Add a production entity",
"article.metadata.production.entities.type": "Type",
"article.metadata.production.entities.media": "Media",
"article.metadata.production.entities.name": "Name",
"article.metadata.production.entities.type.publisher": "Publisher",
"article.metadata.production.entities.type.producer": "Producer",
"article.metadata.production.entities.type.editor": "Editor",
"article.metadata.production.entities.media.all": " ",
"article.metadata.production.entities.media.print": "Print",
"article.metadata.production.entities.media.digital": "Digital",
"article.metadata.production.entities.media.ebook": "e-book",
"article.metadata.issue": "Issue",
"article.metadata.issue.title": "Title",
"article.metadata.issue.number": "",
"article.metadata.issue.identifier": "Identifier",
"form.addItem.title": "Add",
"form.addPerson.title": "Add a person",
"form.removeItem.title": "Remove",
"form.removePerson.title": "Remove this person",
"corpus.metadata.form.name": "Name",
"corpus.metadata.form.issue": "Issue",
"corpus.metadata.form.issue.title": "Title",
Expand Down
Loading

0 comments on commit f69d0d7

Please sign in to comment.