|
1 | 1 | import React, { useEffect } from "react"; |
2 | | -import { Box, Grid, Typography } from "@mui/material"; |
| 2 | +import { Box, Button, Grid, Typography } from "@mui/material"; |
3 | 3 | import { metadataConfig } from "../../metadata.config"; |
4 | 4 | import { useDispatch, useSelector } from "react-redux"; |
5 | 5 | import { RootState } from "../../types/data"; |
@@ -120,69 +120,89 @@ export const DisplayMetadata = (props: MetadataType) => { |
120 | 120 | metadataList = publicDatasetMetadataList; |
121 | 121 | if (publicView) currentMetadataDefList = publicMetadataDefinitionList; |
122 | 122 | else currentMetadataDefList = metadataDefinitionList; |
123 | | - |
124 | | - return currentMetadataDefList.map((metadataDef) => { |
125 | | - return metadataList.map((metadata, idx) => { |
126 | | - if (metadataDef.name === metadata.definition) { |
127 | | - return ( |
128 | | - <Box className="inputGroup" key={idx}> |
129 | | - <Typography variant="h6">{metadata.definition}</Typography> |
130 | | - <Typography variant="subtitle2"> |
131 | | - {metadata.description} |
132 | | - </Typography> |
133 | | - { |
134 | | - // construct metadata using its definition |
135 | | - metadataDef.fields.map((field, idxx) => { |
136 | | - return React.cloneElement( |
137 | | - metadataConfig[field.widgetType ?? "NA"] ?? |
138 | | - metadataConfig["NA"], |
139 | | - { |
140 | | - widgetName: metadataDef.name, |
141 | | - fieldName: field.name, |
142 | | - options: field.config.options ?? [], |
143 | | - updateMetadata: updateMetadata, |
144 | | - initialReadOnly: true, |
145 | | - resourceId: resourceId, |
146 | | - content: metadata.content ?? null, |
147 | | - metadataId: metadata.id ?? null, |
148 | | - isRequired: field.required, |
149 | | - key: idxx, |
150 | | - datasetRole: datasetRole, |
151 | | - frozen: about.frozen, |
152 | | - frozenVersionNum: about.frozen_version_num, |
153 | | - } |
154 | | - ); |
155 | | - }) |
156 | | - } |
157 | | - <Grid container spacing={2}> |
158 | | - <Grid item xs={11} sm={11} md={11} lg={11} xl={11}> |
159 | | - <Agent |
160 | | - created={metadata.created} |
161 | | - agent={metadata.agent} |
162 | | - /> |
163 | | - <FrozenWrapper |
164 | | - frozen={about.frozen} |
165 | | - frozenVersionNum={about.frozen_version_num} |
166 | | - > |
167 | | - <AuthWrapper |
168 | | - currRole={datasetRole.role} |
169 | | - allowedRoles={["owner", "editor", "uploader"]} |
| 123 | + let hasUserMetadata = false; |
| 124 | + metadataList.map((metadata, idx) => { |
| 125 | + if (metadata.agent.listener === null) { |
| 126 | + hasUserMetadata = true; |
| 127 | + } |
| 128 | + }); |
| 129 | + if (hasUserMetadata) { |
| 130 | + return currentMetadataDefList.map((metadataDef) => { |
| 131 | + return metadataList.map((metadata, idx) => { |
| 132 | + if (metadataDef.name === metadata.definition) { |
| 133 | + return ( |
| 134 | + <Box className="inputGroup" key={idx}> |
| 135 | + <Typography variant="h6">{metadata.definition}</Typography> |
| 136 | + <Typography variant="subtitle2"> |
| 137 | + {metadata.description} |
| 138 | + </Typography> |
| 139 | + { |
| 140 | + // construct metadata using its definition |
| 141 | + metadataDef.fields.map((field, idxx) => { |
| 142 | + return React.cloneElement( |
| 143 | + metadataConfig[field.widgetType ?? "NA"] ?? |
| 144 | + metadataConfig["NA"], |
| 145 | + { |
| 146 | + widgetName: metadataDef.name, |
| 147 | + fieldName: field.name, |
| 148 | + options: field.config.options ?? [], |
| 149 | + updateMetadata: updateMetadata, |
| 150 | + initialReadOnly: true, |
| 151 | + resourceId: resourceId, |
| 152 | + content: metadata.content ?? null, |
| 153 | + metadataId: metadata.id ?? null, |
| 154 | + isRequired: field.required, |
| 155 | + key: idxx, |
| 156 | + datasetRole: datasetRole, |
| 157 | + frozen: about.frozen, |
| 158 | + frozenVersionNum: about.frozen_version_num, |
| 159 | + } |
| 160 | + ); |
| 161 | + }) |
| 162 | + } |
| 163 | + <Grid container spacing={2}> |
| 164 | + <Grid item xs={11} sm={11} md={11} lg={11} xl={11}> |
| 165 | + <Agent |
| 166 | + created={metadata.created} |
| 167 | + agent={metadata.agent} |
| 168 | + /> |
| 169 | + <FrozenWrapper |
| 170 | + frozen={about.frozen} |
| 171 | + frozenVersionNum={about.frozen_version_num} |
170 | 172 | > |
171 | | - <MetadataDeleteButton |
172 | | - metadataId={metadata.id ?? null} |
173 | | - deleteMetadata={deleteMetadata} |
174 | | - resourceId={resourceId} |
175 | | - widgetName={metadataDef.name} |
176 | | - /> |
177 | | - </AuthWrapper> |
178 | | - </FrozenWrapper> |
| 173 | + <AuthWrapper |
| 174 | + currRole={datasetRole.role} |
| 175 | + allowedRoles={["owner", "editor", "uploader"]} |
| 176 | + > |
| 177 | + <MetadataDeleteButton |
| 178 | + metadataId={metadata.id ?? null} |
| 179 | + deleteMetadata={deleteMetadata} |
| 180 | + resourceId={resourceId} |
| 181 | + widgetName={metadataDef.name} |
| 182 | + /> |
| 183 | + </AuthWrapper> |
| 184 | + </FrozenWrapper> |
| 185 | + </Grid> |
179 | 186 | </Grid> |
180 | | - </Grid> |
181 | | - </Box> |
182 | | - ); |
183 | | - } |
| 187 | + </Box> |
| 188 | + ); |
| 189 | + } |
| 190 | + }); |
184 | 191 | }); |
185 | | - }); |
| 192 | + } else { |
| 193 | + return ( |
| 194 | + <Box textAlign="left"> |
| 195 | + <p> |
| 196 | + Currently there is no user metadata provided for this resource. |
| 197 | + To start adding some click on the Add metadata button. User |
| 198 | + metadata is metadata about the dataset added by any user who has |
| 199 | + write permission to the dataset. The list of available field is |
| 200 | + defined by the administrators of the system. If you would like |
| 201 | + to add a new entry please contact one of the administrators. |
| 202 | + </p> |
| 203 | + </Box> |
| 204 | + ); |
| 205 | + } |
186 | 206 | })()} |
187 | 207 | </> |
188 | 208 | ); |
|
0 commit comments