_URI
modifier>}\n defaultValue={dataColumn.publishTopic}\n onChange={e => updateColumn(dataColumn, 'publishTopic', e.target.value || undefined)} />\n {props.zodIssue.code}
\n {' at '}\n {location}
\n When there is a query-variable-name
{headVar} | \n ))}\n
---|
{row[header]} | \n ))}\n
\n {this.props.label} \n \n \n {minValue} \n \n {maxValue} \n ({value}) \n | \n
{headVar} | \n ))}\n
---|
{value} | \n })}\n
\n ?collectionType
variables now support the following: rdf:List
{' '}\n (full uri: 'http://www.w3.org/1999/02/22-rdf-syntax-ns#List')\n
\n ?sparqlParameter \n | \n \n String literal with the name of the SparQL parameter used in the published snippet (?subj ). Do not include the ? .\n | \n
---|---|
\n ?property \n | \n \n String literal with the label of the filterable property.\n | \n
\n ?propertyURI \n | \n \n String literal with the URI of the filterable property.\n | \n
\n ?value \n | \n \n For checkboxes, radiobuttons, search: string literal with the label of the filterable values. \n For range or daterange: \"min\" or \"max\" to indicate if it's the min or max value.\n | \n
\n ?valueURI \n | \n \n For checkboxes, radiobuttons, search: string URI or literal of the filterable values. \n For range: number literal of the min or max value. \n For daterange: date literal of the min or max value like \"2023-01-01T00:00:00Z\"^^xsd:dateTime .\n | \n
\n ?type \n | \n \n Either \"checkboxes\" , \"radiobuttons\" , \"search\" , \"range\" or \"daterange\" .\n | \n
\n ?defaultExpanded \n | \n \n Whether to expand the filter by default. Either true or false .\n | \n
\n ?defaultVisible \n | \n \n Whether the filter is shown by default. Either true or false . If false , it can be added by the user via the Add button.\n | \n
\n The results of this query are displayed in the table in the same order\n as they are returned from the triplestore.\n
\n\n It is possible to modify a cell by selecting sparql-variables with the\n following name-shape {'?{identifier}_{modifier}'}
.\n Rows have an empty identifier, e.g. {'?_{modifier}'}
.\n
\n The following {'modifier'}
s have been implemented:\n
URI
: makes the cell clickable. On click it publishes this value to the global \"publish topic\",\n or the column-configuration-specific `publishTopic` (the latter overrides the former).{\" \"}\n If this modifier is used, then URL
should not be used as you cannot have both behaviours.{\" \"}\n An error-notification is clearly visible on your screen if both modifiers are active.\n URL
: makes the cell clickable. On click it opens a new browser-tab/window with this value as its URL.{\" \"}\n If this modifier is used, then URL
should not be used as you cannot have both behaviours.{\" \"}\n An error-notification is clearly visible on your screen if both modifiers are active.\n ICON
: name of the icon, this can be an icon from{\" \"}\n fontawesome, {\" \"}\n Radix Icons, or{\" \"}\n MUI Icons\n fa-user
, fa-minus-circle
, radix-layers
, radix-dots-horizontal
, mui-add
.\n ICONCOLOR
: css color of the icon. Examples: blue
, rgba(128, 128, 0, 0.5)
, #ffee33
\n ICONSIZE
: css size of the icon. Examples: 15px
, 16pt
, 2rem
\n TEXTCOLOR
: css color of the text. Examples: blue
, rgba(128, 128, 0, 0.5)
, #ffee33
\n \n The visible columns and the order of columns are explicitly decided by the SPARQL column tabs.\n Use the 'Auto fill' button to automatically populate them based on variables in\n your SELECT
statement.\n
\n If you see a column with the '🔗' symbol, it means it is linked to a valid SPARQL variable.
\n Columns with the '⛓️💥' symbol are not linked to a valid SPARQL variable.\n
\n You can also create additional columns which are not linked to a specific SPARQL variable,\n but can be used to trigger an action.\n\n
\"publish\"
and \"start-rule\"
{'{{placeholders}}'}
, from any row's SPARQL column variable or global pubsub variables\n An advanced example for an action column:
\n
{JSON.stringify(example, null, 4)}\n \n
the uploadany file uri of the uploaded ifc file and its derivations (like frag and LD) will be connected via the wistor#belongsTo Parameter to this parameter value
)} \n },\n {\n name: 'uploadconversionjson',\n type: 'json',\n label: 'conversion to LD and viewer options in JSON',\n helpComponent: UploadConversionJsonHelp\n },\n {\n name: 'bimlegalfrag',\n type: 'boolean',\n label: 'create a IFCSpace frag file only'\n },\n {\n name: 'AfterUploadIFCUriSelection',\n type: 'text',\n label: 'parameter that will be filled with the IFCupload uri',\n helpComponent: function () {return (After a succesful upload the uploadany file uri will be set to this parameter. This can be handy to automaticially select the uploaded file
)}\n },\n PublishUtils.getTimestampParametersDef(),\n PublishUtils.getRunRuleParametersDef(),\n {\n name: 'files prefix',\n type: 'text',\n label: 'prefix for all ifc files (e.g. http://wistor.nl/servlets/cgi/download/repo/) ',\n },\n {\n name: 'ifcfiles',\n type: 'array',\n label: 'comma separated url(s) to IFC files to display. parameters can be used here referring to (wistor) download locations using the wistor download servlet',\n },\n {\n name: 'Visualisation mode',\n type: 'select',\n label: '2d of 3d modus',\n options: [\n {\n label: '3D',\n value: '3D',\n },\n {\n label: '2D',\n value: '2D',\n }\n ]},\n {\n name: 'objectVisualisationMode',\n type: 'select',\n label: 'options to visualise IFC data icw Sparql results',\n options: [\n {\n label: 'normal (no sparql necessary)',\n value: 'normal',\n },\n {\n label: 'show only sparql results ',\n value: 'sparqlonly',\n },\n {\n label: 'show all transparent (sparql results in color) ',\n value: 'transparent',\n }\n ]},\n {\n name: 'query',\n type: 'yasgui',\n label: 'use parameter ?guid (necessary to link?) ?uri (handy for publishing) ?hidden (false/true) ?alpha ?color (create a color based upon this value) ?colorHex ?label (popup label) ',\n defaultQuery:\"\"\n },\n {\n name: 'predefinedColors',\n type: 'json',\n label: 'JSON-object linking ?color labels to actual CSS-style colors. Example: { \"Walls\": \"#3366ff\", \"Floors\": \"red\" }',\n },\n {\n name: 'publishVariable',\n type: 'text',\n label: 'sparql parameter name for publishing select event result. Arguably we need GUIDS to link data to the viewer. Perhaps GUID based interaction (publish guids instead of URIs is handier)',\n },\n {\n name: 'subscribeVariable',\n type: 'text',\n label: 'Published variabele on which to listen for selection.',\n },\n {\n name: 'zoomOnSelectionChange',\n type: 'boolean',\n label: 'Automatically zoom in to selection when selection variable has changed.',\n },\n {\n name: 'zoomToSelection',\n type: 'boolean',\n label: 'Automatically zoom in to selection when changing selection interactively.',\n },\n {\n name: 'resetSelectionOnSparqlUpdate',\n type: 'boolean',\n label: 'Reset selection on SPARQL update.',\n },\n {\n name: 'multipleselect',\n type: 'boolean',\n label: 'allow multiple selections. parameters are filled as comma separated values',\n },\n \n PublishUtils.getMultipleValueFormatOptions(),\n {\n name: 'bimlegaleditorversion',\n type: 'boolean',\n label: 'allow other scripts to interact with special functions for bim-legal',\n },\n \n /*,\n {\n name: 'clearParameter',\n type: 'text',\n label: 'clears widget when parameter changes'\n }*/\n ],\n }\n }\n}\n\nconst UPLOADCONVERSIONJSON_DEFAULT = {\n \"categoriesToInclude\": [\n \"IFCELEMENT\", \"IFCSITE\", \"IFCPROJECT\", \"IFCBUILDING\", \"IFCBUILDINGSTOREY\", \"IFCGROUP\", \"IFCZONE\"\n ],\n \"relationsToInclude\": [\n \"IsDefinedBy\",\n \"ContainedInStructure\",\n \"ContainsElements\",\n \"Decomposes\",\n \"IsDecomposedBy\",\n \"IsGroupedBy\",\n \"HasAssignments\",\n ],\n \"includeElementsWithoutRelations\": true,\n \"psetNameRegex\": null\n}\n\nconst UPLOADCONVERSIONJSON_EVERYTHING = {\n \"categoriesToInclude\": [\n \"IFCELEMENT\", \"IFCSITE\", \"IFCPROJECT\", \"IFCBUILDING\", \"IFCBUILDINGSTOREY\", \"IFCGROUP\"\n ],\n \"relationsToInclude\": [\n \"IsDecomposedBy\",\n \"Decomposes\",\n \"AssociatedTo\",\n \"HasAssociations\",\n \"ClassificationForObjects\",\n \"IsGroupedBy\",\n \"HasAssignments\",\n \"IsDefinedBy\",\n \"DefinesOcurrence\",\n \"IsTypedBy\",\n \"Types\",\n \"Defines\",\n \"ContainedInStructure\",\n \"ContainsElements\",\n \"HasControlElements\",\n \"AssignedToFlowElement\",\n \"ConnectedTo\",\n \"ConnectedFrom\",\n \"ReferencedBy\",\n \"Declares\",\n \"HasContext\",\n \"Controls\",\n \"IsNestedBy\",\n \"Nests\"\n ],\n \"includeElementsWithoutRelations\": true,\n \"psetNameRegex\": null\n}\n\nconst UPLOADCONVERSIONJSON_PSETS = {\n \"categoriesToInclude\": [\n \"IFCELEMENT\"\n ],\n \"relationsToInclude\": [\n \"IsDefinedBy\",\n ],\n \"includeElementsWithoutRelations\": false,\n \"psetNameRegex\": null\n}\n\nconst UPLOADCONVERSIONJSON_BIMLEGAL = {\n \"categoriesToInclude\": [\n \"IFCSPACE\", \"IFCSITE\", \"IFCPROJECT\", \"IFCBUILDING\", \"IFCBUILDINGSTOREY\"\n ],\n \"relationsToInclude\": [\n \"IsDefinedBy\",\n \"ContainsElements\",\n \"ContainedInStructure\"\n ],\n \"includeElementsWithoutRelations\": true,\n \"psetNameRegex\": null\n}\n\nfunction UploadConversionJsonHelp() {\n return (\ncategoriesToInclude
: list of IFC object categories to include in export, like
.\n IFCELEMENT is a shortcut for all categories that have{' '}\n \n IfcElement\n {' '}\n as superclass. Should be in UPPERCASE. If this is not set or null, all non-orphaned elements are included.\n categoriesToView
: list of IFC object categories to show in the viewer, like
.\n IFCELEMENT is a shortcut for all categories that have{' '}\n \n IfcElement\n {' '}\n as superclass. Should be in UPPERCASE. If this is not set or null, nothing will be shown.\n relationsToInclude
: defines relations to include (according the relation name in IFC). Is case\n sensitive. Use IsDefinedBy for property set relations. If this is not set or null, all supported relations are\n included.\n includeElementsWithoutRelations
: boolean whether to include elements where zero relations where\n found according to the relationsToInclude & psetNameRegex settings.\n psetNameRegex
: regex to only export property sets relations with a specific name. If this is not\n set, null, or empty, all property sets are included.\n This viewer does not exist or has been deleted. Please contact an admin if this is a problem.
\n )\n\n var me = this\n document.st = function () {\n viewer.notShowTop = false\n me.setState({ notShowTop: false })\n }\n document.preview = function () {\n getViewProps(this.props).mode = 'preview'\n me.setState({ mode: 'preview' })\n }\n document.edit = function () {\n getViewProps(this.props).mode = 'edit'\n me.setState({ mode: 'edit' })\n }\n\n let notification = this.state.notification\n const { mode, projectPath, viewerPath } = getViewProps(this.props)\n\n let showBottom = viewer.notShowBottom\n if (showBottom == null) {\n showBottom = true\n } else {\n showBottom = !showBottom\n }\n\n let showTop = viewer.notShowTop\n if (showTop == null) {\n showTop = true\n } else {\n showTop = !showTop\n }\n\n let css = viewer.css\n if (css) {\n try {\n css = JSON.parse(css)\n } catch (error) {\n css = {}\n }\n } else {\n css = {}\n }\n\n const { repo: repoName } = this.viewerParams(viewer)\n\n return (\n{label}
\n\n )}\n {columnNames.map((columnName, index) => ( \n | {this.getHeader(columnName)} | \n ))}\n {hasDeleteColumn && (\ndelete | \n )}\n
---|---|---|
{index + 1} | \n )}\n\n {columnNames.map((columnName, index) => {\n const value = item[columnName] || ''\n const uri = item[columnName + 'URI']\n const url = item[columnName + 'URL']\n const icon = item[columnName + 'Icon']\n const iconSize = item[columnName + 'IconSize']\n const iconColor = item[columnName + 'IconColor']\n\n const content = (() => {\n if (icon) return (\n\n {(uri || url)\n ? {\n if (uri) return `${styles.link} ${styles.inlineblock} ${uri === selectedUri ? styles.highlight : ''}`\n if (url) return `${styles.link} ${styles.inlineblock}`\n throw new Error('this should be unreachable')\n })()}\n onClick={() => {\n if (uri) return this.onClick(uri)\n if (url) return this.openLink(url)\n throw new Error('this should be unreachable')\n }}\n dangerouslySetInnerHTML={this.props.ashtml ? {__html: content} : undefined}\n >\n {this.props.ashtml ? undefined : content}\n \n : this.props.ashtml\n ? \n : content\n }\n | \n )\n })}\n\n {hasDeleteColumn && (\nthis.deleteClick(item)} key={index} className={styles.iconcenter+\" \"+center}>\n {crossDel}\n | \n )}\n\n
{label}
\n{headVar} | \n ))}\n
---|
\n {JSON.stringify(props.appVariables, undefined, '\\n\\t').slice(1,-1)}\n\n )\n}\n\nfunction mapStateToProps(state: any) {\n return { appVariables: state.pubsub }\n}\n\nexport const AppVariables = connect(mapStateToProps)(AppVariablesComponent)\n","import { useEffect, useState } from 'react'\nimport { resolveTemplateString } from '../helpers/resolve-template-string'\nimport { OpaqueSparqlResults } from '../helpers/sparqlResultHelpers'\nimport { SparqlTemplate } from '../helpers/SparqlManager'\n\ntype PublishFn = (topic: string, value: unknown) => void\n\nexport function SparqlTriggerExecutor(props: {\n endpoint: string\n sparqlTemplate: string\n templateId: string\n pubVars: Record