UNPKG

solid-panes

Version:

Solid-compatible Panes: applets and views for the mashlib and databrowser

74 lines (70 loc) 3.78 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.defaultPane = void 0; var UI = _interopRequireWildcard(require("solid-ui")); var $rdf = _interopRequireWildcard(require("rdflib")); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } /* Default Pane ** ** This outline pane contains the properties which are ** normally displayed to the user. See also: internalPane ** This pane hides the ones considered too low-level for the normal user. */ const ns = UI.ns; const defaultPane = exports.defaultPane = { icon: UI.icons.originalIconBase + 'about.png', name: 'default', audience: [ns.solid('Developer')], label: function (_subject) { return 'about '; }, render: function (subject, context) { const dom = context.dom; const filter = function (pred, inverse) { if (typeof context.session.paneRegistry.byName('internal').predicates[pred.uri] !== 'undefined') { return false; } if (inverse && pred.uri === 'http://www.w3.org/1999/02/22-rdf-syntax-ns#type') { return false; } return true; }; const outliner = context.getOutliner(dom); const kb = context.session.store; // var outline = outliner; // @@ UI.log.info('@defaultPane.render, dom is now ' + dom.location); subject = kb.canon(subject); const div = dom.createElement('div'); div.setAttribute('class', 'defaultPane'); // appendRemoveIcon(div, subject, div) let plist = kb.statementsMatching(subject); outliner.appendPropertyTRs(div, plist, false, filter); plist = kb.statementsMatching(undefined, undefined, subject); outliner.appendPropertyTRs(div, plist, true, filter); if (subject.termType === 'Literal' && subject.value.slice(0, 7) === 'http://') { outliner.appendPropertyTRs(div, [$rdf.st(kb.sym(subject.value), UI.ns.link('uri'), subject)], true, filter); } if (subject.termType === 'NamedNode' && kb.updater.editable($rdf.Util.uri.docpart(subject.uri), kb) || subject.termType === 'BlankNode' && kb.anyStatementMatching(subject) && kb.anyStatementMatching(subject).why && kb.anyStatementMatching(subject).why.uri && kb.updater.editable(kb.anyStatementMatching(subject).why.uri) // check the document containing something about of the bnode @@ what about as object? /* ! && HCIoptions["bottom insert highlights"].enabled */) { const holdingTr = dom.createElement('tr'); // these are to minimize required changes const holdingTd = dom.createElement('td'); // in userinput.js holdingTd.setAttribute('colspan', '2'); holdingTd.setAttribute('notSelectable', 'true'); const img = dom.createElement('img'); img.src = UI.icons.originalIconBase + 'tango/22-list-add-new.png'; img.addEventListener('click', function addNewTripleIconMouseDownListener(e) { outliner.UserInput.addNewPredicateObject(e); e.stopPropagation(); e.preventDefault(); }); img.className = 'bottom-border-active'; // img.addEventListener('click', thisOutline.UserInput.addNewPredicateObject,false) div.appendChild(holdingTr).appendChild(holdingTd).appendChild(img); } return div; } }; // ends