UNPKG

@inrupt/solid-client

Version:
215 lines (212 loc) • 10.5 kB
import { internal_throwIfNotThing, internal_cloneThing, internal_toNode } from './thing.internal.mjs'; import { internal_isValidUrl, asNamedNode, serializeDatetime, serializeDecimal, serializeInteger, normalizeLocale, xmlSchemaTypes, serializeBoolean } from '../datatypes.mjs'; import { DataFactory } from '../rdfjs.mjs'; import { ValidPropertyUrlExpectedError, isThing, ValidValueUrlExpectedError } from './thing.mjs'; /** * Copyright 2020 Inrupt Inc. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to use, * copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the * Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /** * Create a new Thing with a URL added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setUrl]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add a URL value to. * @param property Property for which to add the given URL value. * @param url URL to add to `thing` for the given `property`. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ const addUrl = (thing, property, url) => { internal_throwIfNotThing(thing); if (!internal_isValidUrl(property)) { throw new ValidPropertyUrlExpectedError(property); } const predicateNode = asNamedNode(property); const newThing = internal_cloneThing(thing); if (!isThing(url) && !internal_isValidUrl(url)) { throw new ValidValueUrlExpectedError(url); } newThing.add(DataFactory.quad(internal_toNode(newThing), predicateNode, internal_toNode(url))); return newThing; }; /** @hidden Alias for [[addUrl]] for those who prefer IRI terminology. */ const addIri = addUrl; /** * Create a new Thing with a boolean added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setBoolean]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add a boolean value to. * @param property Property for which to add the given boolean value. * @param value Boolean to add to `thing` for the given `property`. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ const addBoolean = (thing, property, value) => { internal_throwIfNotThing(thing); return addLiteralOfType(thing, property, serializeBoolean(value), xmlSchemaTypes.boolean); }; /** * Create a new Thing with a datetime added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setDatetime]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add a datetime value to. * @param property Property for which to add the given datetime value. * @param value Datetime to add to `thing` for the given `property`. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ const addDatetime = (thing, property, value) => { internal_throwIfNotThing(thing); return addLiteralOfType(thing, property, serializeDatetime(value), xmlSchemaTypes.dateTime); }; /** * Create a new Thing with a decimal added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setDecimal]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add a decimal value to. * @param property Property for which to add the given decimal value. * @param value Decimal to add to `thing` for the given `property`. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ const addDecimal = (thing, property, value) => { internal_throwIfNotThing(thing); return addLiteralOfType(thing, property, serializeDecimal(value), xmlSchemaTypes.decimal); }; /** * Create a new Thing with an integer added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setInteger]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add an integer value to. * @param property Property for which to add the given integer value. * @param value Integer to add to `thing` for the given `property`. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ const addInteger = (thing, property, value) => { internal_throwIfNotThing(thing); return addLiteralOfType(thing, property, serializeInteger(value), xmlSchemaTypes.integer); }; /** * Create a new Thing with a localised string added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setStringWithLocale]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add a localised string value to. * @param property Property for which to add the given string value. * @param value String to add to `thing` for the given `property`. * @param locale Locale of the added string. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ function addStringWithLocale(thing, property, value, locale) { internal_throwIfNotThing(thing); const literal = DataFactory.literal(value, normalizeLocale(locale)); return addLiteral(thing, property, literal); } /** * Create a new Thing with an unlocalised string added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setStringNoLocale]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @param thing Thing to add an unlocalised string value to. * @param property Property for which to add the given string value. * @param value String to add to `thing` for the given `property`. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ const addStringNoLocale = (thing, property, value) => { internal_throwIfNotThing(thing); return addLiteralOfType(thing, property, value, xmlSchemaTypes.string); }; /** * Create a new Thing with a Named Node added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setNamedNode]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @ignore This should not be needed due to the other add*() functions. If you do find yourself needing it, please file a feature request for your use case. * @param thing The [[Thing]] to add a Named Node to. * @param property Property for which to add a value. * @param value The Named Node to add. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ function addNamedNode(thing, property, value) { internal_throwIfNotThing(thing); return addTerm(thing, property, value); } /** * Create a new Thing with a Literal added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setLiteral]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @ignore This should not be needed due to the other add*() functions. If you do find yourself needing it, please file a feature request for your use case. * @param thing The [[Thing]] to add a Literal to. * @param property Property for which to add a value. * @param value The Literal to add. * @returns A new Thing equal to the input Thing with the given value added for the given Property. */ function addLiteral(thing, property, value) { internal_throwIfNotThing(thing); return addTerm(thing, property, value); } /** * Creates a new Thing with a Term added for a Property. * * This preserves existing values for the given Property. To replace them, see [[setTerm]]. * * The original `thing` is not modified; this function returns a cloned Thing with updated values. * * @ignore This should not be needed due to the other add*() functions. If you do find yourself needing it, please file a feature request for your use case. * @param thing The [[Thing]] to add a Term to. * @param property Property for which to add a value. * @param value The Term to add. * @returns A new Thing equal to the input Thing with the given value added for the given Property. * @since 0.3.0 */ function addTerm(thing, property, value) { internal_throwIfNotThing(thing); if (!internal_isValidUrl(property)) { throw new ValidPropertyUrlExpectedError(property); } const predicateNode = asNamedNode(property); const newThing = internal_cloneThing(thing); newThing.add(DataFactory.quad(internal_toNode(newThing), predicateNode, value)); return newThing; } function addLiteralOfType(thing, property, value, type) { const literal = DataFactory.literal(value, DataFactory.namedNode(type)); return addLiteral(thing, property, literal); } export { addBoolean, addDatetime, addDecimal, addInteger, addIri, addLiteral, addNamedNode, addStringNoLocale, addStringWithLocale, addTerm, addUrl };