@hestia-earth/ui-components 0.25.2 → 0.25.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/files/files-error.model.mjs +31 -24
- package/esm2022/glossary/glossary.service.mjs +1 -1
- package/esm2022/node/node-store.service.mjs +2 -2
- package/fesm2022/hestia-earth-ui-components.mjs +31 -24
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/glossary/glossary.service.d.ts +1 -1
- package/package.json +1 -1
|
@@ -31,7 +31,7 @@ const nodeTypeDataStates = (nodeType, aggregated = false) => {
|
|
|
31
31
|
const sortNodes = (values) => values?.length
|
|
32
32
|
? orderBy(values.filter(Boolean), ['original.aggregated', 'original.site.@id', 'original.cycle.@id', 'original.@id'], ['asc', 'asc', 'asc', 'asc'])
|
|
33
33
|
: [];
|
|
34
|
-
const isAggregated = (id) => !!id
|
|
34
|
+
const isAggregated = (id) => !!id?.match(/^[a-zA-Z]+[-][a-zA-Z]+[-][\d]{4,}[-][\d]{4,}/g);
|
|
35
35
|
export class HeNodeStoreService {
|
|
36
36
|
constructor(nodeService) {
|
|
37
37
|
this.nodeService = nodeService;
|
|
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.8", ngImpor
|
|
|
115
115
|
providedIn: 'root'
|
|
116
116
|
}]
|
|
117
117
|
}], ctorParameters: function () { return [{ type: i1.HeNodeService }]; } });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-store.service.js","sourceRoot":"","sources":["../../../src/node/node-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { JSONLD, NodeType } from '@hestia-earth/schema';\nimport { DataState } from '@hestia-earth/api';\nimport { catchError, map, mergeMap, shareReplay, toArray } from 'rxjs/operators';\nimport { Observable, ReplaySubject, forkJoin, of } from 'rxjs';\nimport orderBy from 'lodash.orderby';\n\nimport { HeNodeService } from './node.service';\n\nexport interface IStoredNode {\n  index: number;\n  type: NodeType;\n  id: string;\n}\n\ntype nodeStates = {\n  [dataState in DataState]?: JSONLD<NodeType>;\n};\n\ntype nodes = {\n  [nodeType in NodeType]?: (nodeStates & IStoredNode)[];\n};\n\ntype nodeLoadRequest = {\n  [dataState in DataState]: Observable<JSONLD<NodeType>>;\n};\n\ntype nodesLoadRequest = {\n  [nodeType in NodeType]?: {\n    id: string;\n    request: Observable<nodeStates & IStoredNode>;\n  }[];\n};\n\nconst defaultDataStates = [DataState.original, DataState.recalculated];\n\nexport const nodeTypeDataState: {\n  [type in NodeType]?: {\n    default: DataState[];\n    aggregated?: DataState[];\n  };\n} = {\n  [NodeType.Cycle]: {\n    default: defaultDataStates,\n    aggregated: [DataState.original]\n  },\n  [NodeType.ImpactAssessment]: {\n    default: defaultDataStates,\n    aggregated: [DataState.recalculated]\n  },\n  [NodeType.Site]: {\n    default: defaultDataStates,\n    aggregated: [DataState.original]\n  }\n};\n\nconst nodeTypeDataStates = (nodeType: NodeType, aggregated = false) => {\n  const dataStatesMapping = nodeTypeDataState[nodeType] || {\n    default: [DataState.original],\n    aggregated: [DataState.original]\n  };\n  return aggregated ? dataStatesMapping.aggregated : dataStatesMapping.default;\n};\n\nconst sortNodes = (values?: IStoredNode[]) =>\n  values?.length\n    ? orderBy(\n        values.filter(Boolean),\n        ['original.aggregated', 'original.site.@id', 'original.cycle.@id', 'original.@id'],\n        ['asc', 'asc', 'asc', 'asc']\n      )\n    : [];\n\nconst isAggregated = (id: string) => !!id.match(/^[a-zA-Z]+[-][a-zA-Z]+[-][\\d]{4,}[-][\\d]{4,}/g);\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class HeNodeStoreService {\n  private _nodesLoadRequests: nodesLoadRequest = {};\n  private _nodes: nodes = {};\n  private _nodes$ = new ReplaySubject<nodes>(1);\n\n  constructor(private nodeService: HeNodeService) {}\n\n  private findNodeIndex<T extends Pick<JSONLD<NodeType>, '@type' | '@id'>>(node: T) {\n    const nodes = this._nodes?.[node['@type']] || [];\n    return nodes.findIndex(n => n.type === node['@type'] && n.id === node['@id']);\n  }\n\n  private loadNode<T extends Pick<JSONLD<NodeType>, '@type' | '@id'>>(node: T) {\n    const aggregated = 'aggregated' in node ? (node.aggregated as boolean) : isAggregated(node['@id']);\n    const dataStates = nodeTypeDataStates(node['@type'], aggregated);\n    const index = this._nodesLoadRequests[node['@type']].length;\n\n    const request = forkJoin(\n      dataStates.reduce(\n        (prev, dataState) => ({\n          ...prev,\n          [dataState]: this.nodeService\n            .get$<JSONLD<NodeType>>({ ...node, dataState })\n            .pipe(catchError(() => of(undefined)))\n        }),\n        {} as nodeLoadRequest\n      )\n    ).pipe(\n      shareReplay({ bufferSize: 1, refCount: true }),\n      map(\n        (values: nodeStates) =>\n          Object.fromEntries(\n            Object.values(DataState).map(dataState => [\n              dataState,\n              values[dataState] || values[DataState.original] || node\n            ])\n          ) as nodeStates\n      ),\n      map(\n        values =>\n          ({\n            index,\n            type: node['@type'],\n            id: node['@id'],\n            ...values\n          }) as nodeStates & IStoredNode\n      )\n    );\n\n    this._nodesLoadRequests[node['@type']].push({\n      id: node['@id'],\n      request\n    });\n\n    request.subscribe(data => {\n      this._nodes[node['@type']][index] = data;\n      this._nodes$.next(this._nodes);\n    });\n\n    return request;\n  }\n\n  public addNode<T extends Pick<JSONLD<NodeType>, '@type' | '@id'>>(node: T) {\n    this._nodesLoadRequests[node['@type']] = this._nodesLoadRequests[node['@type']] || [];\n    this._nodes[node['@type']] = this._nodes[node['@type']] || [];\n\n    const existingRequest = this._nodesLoadRequests[node['@type']].find(({ id }) => id === node['@id']);\n    return existingRequest ? existingRequest.request : this.loadNode<T>(node);\n  }\n\n  public removeNodeByIndex(nodeType: NodeType, index: number) {\n    this._nodesLoadRequests[nodeType].splice(index, 1);\n    this._nodes[nodeType].splice(index, 1);\n    this._nodes$.next(this._nodes);\n  }\n\n  public removeNode<T extends JSONLD<NodeType>>(node: T) {\n    const index = this.findNodeIndex(node);\n    return index >= 0 ? this.removeNodeByIndex(node['@type'], index) : null;\n  }\n\n  public clearNodes() {\n    this._nodesLoadRequests = {};\n    this._nodes = {};\n    this._nodes$.next(this._nodes);\n  }\n\n  public nodes$() {\n    return this._nodes$.asObservable();\n  }\n\n  public sortedNodes$() {\n    return this.nodes$().pipe(\n      map(\n        nodes =>\n          Object.fromEntries(Object.entries(nodes).map(([nodeKey, values]) => [nodeKey, sortNodes(values)])) as nodes\n      )\n    );\n  }\n\n  public ids$(nodeType: NodeType) {\n    return this.nodes$().pipe(\n      mergeMap(values => values[nodeType]),\n      map(({ id }) => id),\n      toArray()\n    );\n  }\n\n  public find$<T extends JSONLD<NodeType>>(\n    nodeType: NodeType,\n    id?: string\n  ): Observable<{ [dataState in DataState]?: T }[]> {\n    return this.nodes$().pipe(map(values => ((values[nodeType] as any[]) || []).filter(node => !id || node.id === id)));\n  }\n\n  public findByState$<T extends JSONLD<NodeType>>(nodeType: NodeType, dataState: DataState, id?: string) {\n    return this.find$<T>(nodeType, id).pipe(map(values => values.map(v => v[dataState]).filter(Boolean)));\n  }\n}\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-store.service.js","sourceRoot":"","sources":["../../../src/node/node-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { JSONLD, NodeType } from '@hestia-earth/schema';\nimport { DataState } from '@hestia-earth/api';\nimport { catchError, map, mergeMap, shareReplay, toArray } from 'rxjs/operators';\nimport { Observable, ReplaySubject, forkJoin, of } from 'rxjs';\nimport orderBy from 'lodash.orderby';\n\nimport { HeNodeService } from './node.service';\n\nexport interface IStoredNode {\n  index: number;\n  type: NodeType;\n  id: string;\n}\n\ntype nodeStates = {\n  [dataState in DataState]?: JSONLD<NodeType>;\n};\n\ntype nodes = {\n  [nodeType in NodeType]?: (nodeStates & IStoredNode)[];\n};\n\ntype nodeLoadRequest = {\n  [dataState in DataState]: Observable<JSONLD<NodeType>>;\n};\n\ntype nodesLoadRequest = {\n  [nodeType in NodeType]?: {\n    id: string;\n    request: Observable<nodeStates & IStoredNode>;\n  }[];\n};\n\nconst defaultDataStates = [DataState.original, DataState.recalculated];\n\nexport const nodeTypeDataState: {\n  [type in NodeType]?: {\n    default: DataState[];\n    aggregated?: DataState[];\n  };\n} = {\n  [NodeType.Cycle]: {\n    default: defaultDataStates,\n    aggregated: [DataState.original]\n  },\n  [NodeType.ImpactAssessment]: {\n    default: defaultDataStates,\n    aggregated: [DataState.recalculated]\n  },\n  [NodeType.Site]: {\n    default: defaultDataStates,\n    aggregated: [DataState.original]\n  }\n};\n\nconst nodeTypeDataStates = (nodeType: NodeType, aggregated = false) => {\n  const dataStatesMapping = nodeTypeDataState[nodeType] || {\n    default: [DataState.original],\n    aggregated: [DataState.original]\n  };\n  return aggregated ? dataStatesMapping.aggregated : dataStatesMapping.default;\n};\n\nconst sortNodes = (values?: IStoredNode[]) =>\n  values?.length\n    ? orderBy(\n        values.filter(Boolean),\n        ['original.aggregated', 'original.site.@id', 'original.cycle.@id', 'original.@id'],\n        ['asc', 'asc', 'asc', 'asc']\n      )\n    : [];\n\nconst isAggregated = (id: string) => !!id?.match(/^[a-zA-Z]+[-][a-zA-Z]+[-][\\d]{4,}[-][\\d]{4,}/g);\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class HeNodeStoreService {\n  private _nodesLoadRequests: nodesLoadRequest = {};\n  private _nodes: nodes = {};\n  private _nodes$ = new ReplaySubject<nodes>(1);\n\n  constructor(private nodeService: HeNodeService) {}\n\n  private findNodeIndex<T extends Pick<JSONLD<NodeType>, '@type' | '@id'>>(node: T) {\n    const nodes = this._nodes?.[node['@type']] || [];\n    return nodes.findIndex(n => n.type === node['@type'] && n.id === node['@id']);\n  }\n\n  private loadNode<T extends Pick<JSONLD<NodeType>, '@type' | '@id'>>(node: T) {\n    const aggregated = 'aggregated' in node ? (node.aggregated as boolean) : isAggregated(node['@id']);\n    const dataStates = nodeTypeDataStates(node['@type'], aggregated);\n    const index = this._nodesLoadRequests[node['@type']].length;\n\n    const request = forkJoin(\n      dataStates.reduce(\n        (prev, dataState) => ({\n          ...prev,\n          [dataState]: this.nodeService\n            .get$<JSONLD<NodeType>>({ ...node, dataState })\n            .pipe(catchError(() => of(undefined)))\n        }),\n        {} as nodeLoadRequest\n      )\n    ).pipe(\n      shareReplay({ bufferSize: 1, refCount: true }),\n      map(\n        (values: nodeStates) =>\n          Object.fromEntries(\n            Object.values(DataState).map(dataState => [\n              dataState,\n              values[dataState] || values[DataState.original] || node\n            ])\n          ) as nodeStates\n      ),\n      map(\n        values =>\n          ({\n            index,\n            type: node['@type'],\n            id: node['@id'],\n            ...values\n          }) as nodeStates & IStoredNode\n      )\n    );\n\n    this._nodesLoadRequests[node['@type']].push({\n      id: node['@id'],\n      request\n    });\n\n    request.subscribe(data => {\n      this._nodes[node['@type']][index] = data;\n      this._nodes$.next(this._nodes);\n    });\n\n    return request;\n  }\n\n  public addNode<T extends Pick<JSONLD<NodeType>, '@type' | '@id'>>(node: T) {\n    this._nodesLoadRequests[node['@type']] = this._nodesLoadRequests[node['@type']] || [];\n    this._nodes[node['@type']] = this._nodes[node['@type']] || [];\n\n    const existingRequest = this._nodesLoadRequests[node['@type']].find(({ id }) => id === node['@id']);\n    return existingRequest ? existingRequest.request : this.loadNode<T>(node);\n  }\n\n  public removeNodeByIndex(nodeType: NodeType, index: number) {\n    this._nodesLoadRequests[nodeType].splice(index, 1);\n    this._nodes[nodeType].splice(index, 1);\n    this._nodes$.next(this._nodes);\n  }\n\n  public removeNode<T extends JSONLD<NodeType>>(node: T) {\n    const index = this.findNodeIndex(node);\n    return index >= 0 ? this.removeNodeByIndex(node['@type'], index) : null;\n  }\n\n  public clearNodes() {\n    this._nodesLoadRequests = {};\n    this._nodes = {};\n    this._nodes$.next(this._nodes);\n  }\n\n  public nodes$() {\n    return this._nodes$.asObservable();\n  }\n\n  public sortedNodes$() {\n    return this.nodes$().pipe(\n      map(\n        nodes =>\n          Object.fromEntries(Object.entries(nodes).map(([nodeKey, values]) => [nodeKey, sortNodes(values)])) as nodes\n      )\n    );\n  }\n\n  public ids$(nodeType: NodeType) {\n    return this.nodes$().pipe(\n      mergeMap(values => values[nodeType]),\n      map(({ id }) => id),\n      toArray()\n    );\n  }\n\n  public find$<T extends JSONLD<NodeType>>(\n    nodeType: NodeType,\n    id?: string\n  ): Observable<{ [dataState in DataState]?: T }[]> {\n    return this.nodes$().pipe(map(values => ((values[nodeType] as any[]) || []).filter(node => !id || node.id === id)));\n  }\n\n  public findByState$<T extends JSONLD<NodeType>>(nodeType: NodeType, dataState: DataState, id?: string) {\n    return this.find$<T>(nodeType, id).pipe(map(values => values.map(v => v[dataState]).filter(Boolean)));\n  }\n}\n"]}
|
|
@@ -7064,7 +7064,7 @@ const nodeTypeDataStates = (nodeType, aggregated = false) => {
|
|
|
7064
7064
|
const sortNodes = (values) => values?.length
|
|
7065
7065
|
? orderBy(values.filter(Boolean), ['original.aggregated', 'original.site.@id', 'original.cycle.@id', 'original.@id'], ['asc', 'asc', 'asc', 'asc'])
|
|
7066
7066
|
: [];
|
|
7067
|
-
const isAggregated = (id) => !!id
|
|
7067
|
+
const isAggregated = (id) => !!id?.match(/^[a-zA-Z]+[-][a-zA-Z]+[-][\d]{4,}[-][\d]{4,}/g);
|
|
7068
7068
|
class HeNodeStoreService {
|
|
7069
7069
|
constructor(nodeService) {
|
|
7070
7070
|
this.nodeService = nodeService;
|
|
@@ -8051,7 +8051,7 @@ const customErrorMessage = {
|
|
|
8051
8051
|
'should be linked to an existing node': (error, _errorCount, allErrors) => allErrors?.length
|
|
8052
8052
|
? `Your upload does not contain the following Nodes:
|
|
8053
8053
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8054
|
-
${unique(allErrors.map(({ params }) => `<li>${params?.node?.type} with ${code(`id=${params?.node?.id}`)}</li>`)).join('\n')}
|
|
8054
|
+
${unique(allErrors.map(({ params }) => `<li class="is-pre-wrap">${params?.node?.type} with ${code(`id=${params?.node?.id}`)}</li>`)).join('\n')}
|
|
8055
8055
|
</ul>
|
|
8056
8056
|
If you are trying to link to an existing Node on the Hestia platform, you must use ${code('@id')} field instead.
|
|
8057
8057
|
Otherwise you must include a full ${unique(allErrors.map(({ params }) => `${params?.node?.type} with id ${code(params?.node?.id)}.`)).join(', ')}`
|
|
@@ -8126,10 +8126,10 @@ const customErrorMessage = {
|
|
|
8126
8126
|
? `${code(toPrecision(params?.expected, 3))}, but the value in the upload is ${code(toPrecision(params?.current, 3))}.
|
|
8127
8127
|
${params?.threshold ? `Our threshold is ±${threshold(params?.threshold)}.` : ''}
|
|
8128
8128
|
Please either:
|
|
8129
|
-
<ul class="is-pl-3 is-list-style-decimal">
|
|
8130
|
-
<li>Check the ${params?.term.termType} value you provided;</li>
|
|
8131
|
-
<li>Check the data you provided which is the input into this model;</li>
|
|
8132
|
-
<li>Carefully read the documentation to understand if we used a default property as part of the calculations.</li>
|
|
8129
|
+
<ul class="is-pl-3 is-list-style-decimal is-nowrap">
|
|
8130
|
+
<li class="is-pre-wrap">Check the ${params?.term.termType} value you provided;</li>
|
|
8131
|
+
<li class="is-pre-wrap">Check the data you provided which is the input into this model;</li>
|
|
8132
|
+
<li class="is-pre-wrap">Carefully read the documentation to understand if we used a default property as part of the calculations.</li>
|
|
8133
8133
|
</ul>`
|
|
8134
8134
|
: 'not consistent with the model result.'}`,
|
|
8135
8135
|
'the measurement provided might be in error': ({ params }, errorCount) => `The expected value for ${code(params?.term.name)}
|
|
@@ -8184,10 +8184,10 @@ const customErrorMessage = {
|
|
|
8184
8184
|
? ` Instead use the ${termLink({ id: 'nitrogenContent', name: 'Nitrogen Content' })} Property on the ${code('kg')} term to define the nitrogen content of the ${code(params?.term?.termType)}.`
|
|
8185
8185
|
: ''}`,
|
|
8186
8186
|
'is missing required bibliographic information': () => `The automatic bibliography search failed for this Bibliography. Either:
|
|
8187
|
-
<ul class="is-pl-3 is-list-style-decimal">
|
|
8188
|
-
<li>Manually fill-in the <b>required</b> bibliographic information as per ${schemaLink(SchemaType.Bibliography, 'our schema')}.</li>
|
|
8189
|
-
<li>Provide the ${code('documentDOI')} as well as the ${code('title')}.</li>
|
|
8190
|
-
<li>Check the ${code('documentDOI')} and ${code('title')} for typos against the ${externalLink('https://www.mendeley.com', 'Mendeley catalogue')}.</li>
|
|
8187
|
+
<ul class="is-pl-3 is-list-style-decimal is-nowrap">
|
|
8188
|
+
<li class="is-pre-wrap">Manually fill-in the <b>required</b> bibliographic information as per ${schemaLink(SchemaType.Bibliography, 'our schema')}.</li>
|
|
8189
|
+
<li class="is-pre-wrap">Provide the ${code('documentDOI')} as well as the ${code('title')}.</li>
|
|
8190
|
+
<li class="is-pre-wrap">Check the ${code('documentDOI')} and ${code('title')} for typos against the ${externalLink('https://www.mendeley.com', 'Mendeley catalogue')}.</li>
|
|
8191
8191
|
</ul>`,
|
|
8192
8192
|
'should be lower than max size': ({ params }) => `The boundary or region is >${params?.expected}km2 and is too large to reliably gap fill Measurements.
|
|
8193
8193
|
If you are able to use a more specific region or smaller boundary, please do.`,
|
|
@@ -8207,6 +8207,9 @@ const customErrorMessage = {
|
|
|
8207
8207
|
'can only have 1 tillage practice without a value': ({ params }) => `It is not possible for a Cycle to have the following tillage Practices:
|
|
8208
8208
|
${(params?.current ?? []).map(({ name }) => name).join(' and ')} at the same time.
|
|
8209
8209
|
If multiple tillage practices did occur, please specify the percentage of area they occurred on.`,
|
|
8210
|
+
'cannot use no tillage if depth or number of tillages is not 0': () => `This Practice cannot have a value of ${code(100)} if the Tillage depth is higher than ${code(0)} or the Number of tillages is higher than ${code(0)}. Please resolve this conflict.`,
|
|
8211
|
+
'cannot use full tillage if depth or number of tillages is 0': () => `This Practice cannot have a value of ${code(100)} if the Tillage depth is equal to ${code(0)} or the Number of tillages is equal to ${code(0)}. Please resolve this conflict.`,
|
|
8212
|
+
'must use no tillage when number of tillages is 0': () => `You cannot use a tillage term other than No tillage with a value of ${code(100)} if the Number of tillages has been set to ${code(0)}. Please resolve this conflict.`,
|
|
8210
8213
|
'can not be linked to the same Cycle': () => 'You can not link an Input to the Impact Assessment of the same Cycle.',
|
|
8211
8214
|
// deprecated, remove when message is not being used anymore
|
|
8212
8215
|
'must be 0 for product value 0': ({ dataPath, params }, errorCount) => `If the amount produced is zero, the ${code(dataPath?.split('.').pop())} of ${errorCount === 1 ? code(params?.term.name) : 'that product'} must also be zero.`,
|
|
@@ -8260,22 +8263,25 @@ const customErrorMessage = {
|
|
|
8260
8263
|
The quantity must include both above and below ground crop residue, where the sum of above ground crop residue and below ground crop residue must be greater than zero.
|
|
8261
8264
|
This can be added using the terms:
|
|
8262
8265
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8263
|
-
<li>${termLink({ id: 'belowGroundCropResidue', name: 'Below ground crop residue' })}; and</li>
|
|
8264
|
-
<li>${termLink({
|
|
8266
|
+
<li class="is-pre-wrap">${termLink({ id: 'belowGroundCropResidue', name: 'Below ground crop residue' })}; and</li>
|
|
8267
|
+
<li class="is-pre-wrap">${termLink({
|
|
8268
|
+
id: 'aboveGroundCropResidueTotal',
|
|
8269
|
+
name: 'Above ground crop residue total'
|
|
8270
|
+
})}.</li>
|
|
8265
8271
|
</ul>
|
|
8266
8272
|
<br/>
|
|
8267
8273
|
The fate can be added using:
|
|
8268
8274
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8269
|
-
<li>the ${glossaryTypeLink(TermTermType.cropResidueManagement)} practices; and/or</li>
|
|
8270
|
-
<li>the ${glossaryTypeLink(TermTermType.cropResidue)} products</li>
|
|
8275
|
+
<li class="is-pre-wrap">the ${glossaryTypeLink(TermTermType.cropResidueManagement)} practices; and/or</li>
|
|
8276
|
+
<li class="is-pre-wrap">the ${glossaryTypeLink(TermTermType.cropResidue)} products</li>
|
|
8271
8277
|
</ul>
|
|
8272
8278
|
`,
|
|
8273
8279
|
'should specify the fate of cropResidue': () => `You have not specified the fate of the crop residue.
|
|
8274
8280
|
Adding this information will improve emissions and soil carbon stock calculations.
|
|
8275
8281
|
The fate can be added using:
|
|
8276
8282
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8277
|
-
<li>the ${glossaryTypeLink(TermTermType.cropResidueManagement)} practices; and/or</li>
|
|
8278
|
-
<li>the ${glossaryTypeLink(TermTermType.cropResidue)} products;</li>
|
|
8283
|
+
<li class="is-pre-wrap">the ${glossaryTypeLink(TermTermType.cropResidueManagement)} practices; and/or</li>
|
|
8284
|
+
<li class="is-pre-wrap">the ${glossaryTypeLink(TermTermType.cropResidue)} products;</li>
|
|
8279
8285
|
</ul>
|
|
8280
8286
|
Remember to set ${code('completeness.cropResidue')} to ${code(true)} if both the above and below ground crop residue quantities and fates are specified.`,
|
|
8281
8287
|
'should have the same privacy as the related source': ({ params }) => `To link to a ${(params?.defaultSource || params?.source)?.dataPrivate ? 'private' : 'public'} Source,
|
|
@@ -8306,12 +8312,12 @@ const customErrorMessage = {
|
|
|
8306
8312
|
You do not need to set a ${code('value')} for the Product, but adding a ${code('value')} is desirable.`,
|
|
8307
8313
|
'value should sum to 100 across all values': ({ params }) => `The total value of the following terms should sum up to a value of 100%:
|
|
8308
8314
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8309
|
-
${(params.termIds || []).map(id => `<li>${code(id)}</li>`).join('')}
|
|
8315
|
+
${(params.termIds || []).map(id => `<li class="is-pre-wrap">${code(id)}</li>`).join('')}
|
|
8310
8316
|
</ul>
|
|
8311
8317
|
Make sure to add any missing term if needed and/or adjust the values of the existing terms you already recorded.`,
|
|
8312
8318
|
'value should sum to maximum 100 across all values': ({ params }) => `The total value of the following terms should sum up to a maximum value of 100%:
|
|
8313
8319
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8314
|
-
${(params.termIds || []).map(id => `<li>${code(id)}</li>`).join('')}
|
|
8320
|
+
${(params.termIds || []).map(id => `<li class="is-pre-wrap">${code(id)}</li>`).join('')}
|
|
8315
8321
|
</ul>
|
|
8316
8322
|
Make sure to add any missing term if needed and/or adjust the values of the existing terms you already recorded.`,
|
|
8317
8323
|
'rice products not allowed for this water regime practice': ({ params }) => `This practice is not allowed with the products ${params.products?.map(p => code(p.name || p['@id']))}.
|
|
@@ -8355,16 +8361,17 @@ const customErrorMessage = {
|
|
|
8355
8361
|
?.map(code)
|
|
8356
8362
|
.join(', ')}. Please consider any of the following suggestions to resolve this conflict:
|
|
8357
8363
|
<ul class="is-pl-3 is-list-style-disc is-nowrap">
|
|
8358
|
-
<li>You can amend the Cycles' ${schemaLink('Cycle#startDate', 'startDate')} and ${schemaLink('Cycle#endDate', 'endDate')} to ensure that they do not overlap anymore.
|
|
8359
|
-
<li>You can break down your Cycles into shorter Cycles to ensure that they do not overlap anymore.
|
|
8360
|
-
<li>You can merge the overlapping Cycles into one overall Cycle if the Products of each Cycle are grown at the same time on the same Site.
|
|
8364
|
+
<li class="is-pre-wrap">You can amend the Cycles' ${schemaLink('Cycle#startDate', 'startDate')} and ${schemaLink('Cycle#endDate', 'endDate')} to ensure that they do not overlap anymore.
|
|
8365
|
+
<li class="is-pre-wrap">You can break down your Cycles into shorter Cycles to ensure that they do not overlap anymore.
|
|
8366
|
+
<li class="is-pre-wrap">You can merge the overlapping Cycles into one overall Cycle if the Products of each Cycle are grown at the same time on the same Site.
|
|
8361
8367
|
This is relevant if intercropping is used, for instance.</li>
|
|
8362
|
-
<li>You can create a different Site for each overlapping Cycle.
|
|
8368
|
+
<li class="is-pre-wrap">You can create a different Site for each overlapping Cycle.
|
|
8363
8369
|
This is appropriate if a field is divided into different plots, each dedicated to growing a different Product; each plot would be considered a unique Site on the platform.</li>
|
|
8364
8370
|
</ul>
|
|
8365
8371
|
`,
|
|
8366
|
-
'
|
|
8367
|
-
Please create different Sites for the following Cycles: ${params.ids?.map(code).join(', ')}
|
|
8372
|
+
'cycles linked together cannot be added to the same site': ({ params }) => `Cycles linked together by an Impact Assessment cannot take place on the same Site.
|
|
8373
|
+
Please create different Sites for the following Cycles: ${params.ids?.map(code).join(', ')}.`,
|
|
8374
|
+
'is not an allowed animalProduct': () => `The ${glossaryTypeLink(TermTermType.liveAnimal)} producing this Product is not recorded in the ${schemaLink('Cycle#animals', 'Animal')} blank nodes. Either change this product or add the missing ${glossaryTypeLink(TermTermType.liveAnimal)} to the ${schemaLink('Cycle#animals', 'Animal')} blank nodes.`
|
|
8368
8375
|
};
|
|
8369
8376
|
const parseDefaultMessage = (message) => `<span class="is-capitalized-first-letter">${message?.startsWith('should have required property')
|
|
8370
8377
|
? message.replace("'", '<code>').replace("'", '</code>')
|