import { JsonObject } from "../../Core/Json";
import anyTrait from "../Decorators/anyTrait";
import CatalogMemberReferenceTraits from "./CatalogMemberReferenceTraits";
import MagdaDistributionFormatTraits from "./MagdaDistributionFormatTraits";
import mixTraits from "../mixTraits";
import objectArrayTrait from "../Decorators/objectArrayTrait";
import primitiveTrait from "../Decorators/primitiveTrait";
import UrlTraits from "./UrlTraits";
import { traitClass } from "../Trait";
@traitClass({
description: `Creates one catalog item from url that points to a magda record.
Note:
The url points to a magda server.
A magda record identified by recordId must be mappable.`,
example: {
type: "magda",
url: "https://data.gov.au",
name: "Magda example",
recordId: "dist-sa-97d6773f-6ce8-4b0b-a2a1-c2687448c672",
id: "some unique id"
}
})
export default class MagdaReferenceTraits extends mixTraits(
CatalogMemberReferenceTraits,
UrlTraits
) {
@primitiveTrait({
name: "Record ID",
description: "The ID of the Magda record referred to by this reference.",
type: "string"
})
recordId?: string;
@anyTrait({
name: "Magda Record Data",
description:
"The available representation of the Magda record as returned by " +
"the Magda registry API. This representation may not include all " +
"aspects and it may not be dereferenced."
})
magdaRecord?: JsonObject;
@anyTrait({
name: "Override",
description:
"The properties to apply to the dereferenced item, overriding properties that " +
"come from Magda itself."
})
override?: JsonObject;
@objectArrayTrait({
name: "Distribution Formats",
description:
"The supported distribution formats and their mapping to Terria types. " +
"These are listed in order of preference.",
type: MagdaDistributionFormatTraits,
idProperty: "id"
})
distributionFormats?: MagdaDistributionFormatTraits[];
@anyTrait({
name: "AddOrOverrideAspects",
description:
"The properties to apply to the dereferenced item, overriding the record aspects"
})
addOrOverrideAspects?: JsonObject;
}