solid-ui 2.4.22-9cc2af16 → 2.4.22-a5a36443
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/README.md +23 -58
- package/dist/main.js +321 -176
- package/dist/main.js.map +1 -1
- package/lib/utils/label.js +1 -1
- package/lib/utils/label.js.map +1 -1
- package/lib/versionInfo.js +5 -5
- package/lib/versionInfo.js.map +1 -1
- package/lib/widgets/buttons.d.ts.map +1 -1
- package/lib/widgets/buttons.js +2 -0
- package/lib/widgets/buttons.js.map +1 -1
- package/lib/widgets/forms.js +313 -170
- package/lib/widgets/forms.js.map +1 -1
- package/package.json +1 -1
package/dist/main.js
CHANGED
|
@@ -15172,7 +15172,7 @@ function slice(s, suffix) {
|
|
|
15172
15172
|
|
|
15173
15173
|
function getWellKnownLabel(thing) {
|
|
15174
15174
|
return _solidLogic.store.any(thing, UI.ns.ui('label')) || // Prioritize ui:label
|
|
15175
|
-
_solidLogic.store.any(thing, UI.ns.link('message')) || _solidLogic.store.any(thing, UI.ns.vcard('fn')) || _solidLogic.store.any(thing, UI.ns.foaf('name')) || _solidLogic.store.any(thing, UI.ns.dct('title')) || _solidLogic.store.any(thing, UI.ns.dc('title')) || _solidLogic.store.any(thing, UI.ns.rss('title')) || _solidLogic.store.any(thing, UI.ns.contact('fullName')) || _solidLogic.store.any(thing, _solidLogic.store.sym('http://www.w3.org/2001/04/roadmap/org#name')) || _solidLogic.store.any(thing, UI.ns.cal('summary')) || _solidLogic.store.any(thing, UI.ns.foaf('nick')) || _solidLogic.store.any(thing, UI.ns.as('name')) || _solidLogic.store.any(thing, UI.ns.schema('name')) || _solidLogic.store.any(thing, UI.ns.rdfs('label'));
|
|
15175
|
+
_solidLogic.store.any(thing, UI.ns.link('message')) || _solidLogic.store.any(thing, UI.ns.vcard('fn')) || _solidLogic.store.any(thing, UI.ns.foaf('name')) || _solidLogic.store.any(thing, UI.ns.dct('title')) || _solidLogic.store.any(thing, UI.ns.dc('title')) || _solidLogic.store.any(thing, UI.ns.rss('title')) || _solidLogic.store.any(thing, UI.ns.contact('fullName')) || _solidLogic.store.any(thing, _solidLogic.store.sym('http://www.w3.org/2001/04/roadmap/org#name')) || _solidLogic.store.any(thing, UI.ns.cal('summary')) || _solidLogic.store.any(thing, UI.ns.foaf('nick')) || _solidLogic.store.any(thing, UI.ns.as('name')) || _solidLogic.store.any(thing, UI.ns.schema('name')) || _solidLogic.store.any(thing, UI.ns.rdfs('label')) || _solidLogic.store.any(thing, _solidLogic.store.sym('http://www.w3.org/2004/02/skos/core#prefLabel'));
|
|
15176
15176
|
}
|
|
15177
15177
|
//# sourceMappingURL=label.js.map
|
|
15178
15178
|
|
|
@@ -15192,11 +15192,11 @@ Object.defineProperty(exports, "__esModule", ({
|
|
|
15192
15192
|
}));
|
|
15193
15193
|
exports.versionInfo = void 0;
|
|
15194
15194
|
var versionInfo = {
|
|
15195
|
-
buildTime: '2022-05-
|
|
15196
|
-
commit: '
|
|
15195
|
+
buildTime: '2022-05-20T09:44:30Z',
|
|
15196
|
+
commit: 'a5a36443be6e25d047585d79bb83eb6d7ec33b35',
|
|
15197
15197
|
npmInfo: {
|
|
15198
15198
|
'solid-ui': '2.4.22',
|
|
15199
|
-
npm: '6.14.
|
|
15199
|
+
npm: '6.14.17',
|
|
15200
15200
|
ares: '1.18.1',
|
|
15201
15201
|
brotli: '1.0.9',
|
|
15202
15202
|
cldr: '40.0',
|
|
@@ -15205,12 +15205,12 @@ var versionInfo = {
|
|
|
15205
15205
|
modules: '83',
|
|
15206
15206
|
napi: '8',
|
|
15207
15207
|
nghttp2: '1.42.0',
|
|
15208
|
-
node: '14.19.
|
|
15208
|
+
node: '14.19.2',
|
|
15209
15209
|
openssl: '1.1.1n',
|
|
15210
15210
|
tz: '2021a3',
|
|
15211
15211
|
unicode: '14.0',
|
|
15212
15212
|
uv: '1.42.0',
|
|
15213
|
-
v8: '8.4.371.23-node.
|
|
15213
|
+
v8: '8.4.371.23-node.87',
|
|
15214
15214
|
zlib: '1.2.11'
|
|
15215
15215
|
}
|
|
15216
15216
|
};
|
|
@@ -16280,6 +16280,7 @@ function openHrefInOutlineMode(e) {
|
|
|
16280
16280
|
|
|
16281
16281
|
if (dom.outlineManager) {
|
|
16282
16282
|
// @@ TODO Remove the use of document as a global object
|
|
16283
|
+
// TODO fix dependency cycle to solid-panes by calling outlineManager
|
|
16283
16284
|
;
|
|
16284
16285
|
dom.outlineManager.GotoSubject(_solidLogic.store.sym(uri), true, undefined, true, undefined);
|
|
16285
16286
|
} else if (window && window.panes && window.panes.getOutliner) {
|
|
@@ -16407,6 +16408,7 @@ function linkButton(dom, object) {
|
|
|
16407
16408
|
b.textContent = 'Goto ' + utils.label(object);
|
|
16408
16409
|
b.addEventListener('click', function (_event) {
|
|
16409
16410
|
// b.parentNode.removeChild(b)
|
|
16411
|
+
// TODO fix dependency cycle to solid-panes by calling outlineManager
|
|
16410
16412
|
;
|
|
16411
16413
|
dom.outlineManager.GotoSubject(object, true, undefined, true, undefined);
|
|
16412
16414
|
}, true);
|
|
@@ -17147,6 +17149,7 @@ exports.findClosest = findClosest;
|
|
|
17147
17149
|
exports.formsFor = formsFor;
|
|
17148
17150
|
exports.makeDescription = makeDescription;
|
|
17149
17151
|
exports.makeSelectForCategory = makeSelectForCategory;
|
|
17152
|
+
exports.makeSelectForChoice = makeSelectForChoice;
|
|
17150
17153
|
exports.makeSelectForNestedCategory = makeSelectForNestedCategory;
|
|
17151
17154
|
exports.makeSelectForOptions = makeSelectForOptions;
|
|
17152
17155
|
exports.newButton = newButton;
|
|
@@ -17258,14 +17261,16 @@ _fieldFunction.field[ns.ui('Form').uri] = _fieldFunction.field[ns.ui('Group').ur
|
|
|
17258
17261
|
var ui = ns.ui;
|
|
17259
17262
|
if (container) container.appendChild(box); // Prevent loops
|
|
17260
17263
|
|
|
17264
|
+
if (!form) return;
|
|
17261
17265
|
var key = subject.toNT() + '|' + form.toNT();
|
|
17262
17266
|
|
|
17263
17267
|
if (already[key]) {
|
|
17264
17268
|
// been there done that
|
|
17265
|
-
box.appendChild(dom.createTextNode('Group: see above ' + key));
|
|
17266
|
-
|
|
17269
|
+
box.appendChild(dom.createTextNode('Group: see above ' + key)); // TODO fix dependency cycle to solid-panes by calling outlineManager
|
|
17270
|
+
// const plist = [$rdf.st(subject, ns.owl('sameAs'), subject)] // @@ need prev subject
|
|
17271
|
+
// dom.outlineManager.appendPropertyTRs(box, plist)
|
|
17272
|
+
// dom.appendChild(plist)
|
|
17267
17273
|
|
|
17268
|
-
dom.outlineManager.appendPropertyTRs(box, plist);
|
|
17269
17274
|
return box;
|
|
17270
17275
|
}
|
|
17271
17276
|
|
|
@@ -17366,47 +17371,43 @@ _fieldFunction.field[ns.ui('Options').uri] = function (dom, container, already,
|
|
|
17366
17371
|
values = kb.each(subject, dependingOn);
|
|
17367
17372
|
}
|
|
17368
17373
|
|
|
17369
|
-
|
|
17370
|
-
|
|
17371
|
-
|
|
17372
|
-
for (var i = 0; i < cases.length; i++) {
|
|
17373
|
-
var c = cases[i];
|
|
17374
|
-
var tests = kb.each(c, ui('for'), null, formDoc); // There can be multiple 'for'
|
|
17374
|
+
for (var i = 0; i < cases.length; i++) {
|
|
17375
|
+
var c = cases[i];
|
|
17376
|
+
var tests = kb.each(c, ui('for'), null, formDoc); // There can be multiple 'for'
|
|
17375
17377
|
|
|
17376
|
-
|
|
17378
|
+
var match = false;
|
|
17377
17379
|
|
|
17378
|
-
|
|
17379
|
-
|
|
17380
|
-
|
|
17380
|
+
for (var j = 0; j < tests.length; j++) {
|
|
17381
|
+
var _iterator = _createForOfIteratorHelper(values),
|
|
17382
|
+
_step;
|
|
17381
17383
|
|
|
17382
|
-
|
|
17383
|
-
|
|
17384
|
-
|
|
17385
|
-
|
|
17384
|
+
try {
|
|
17385
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
17386
|
+
var value = _step.value;
|
|
17387
|
+
var test = tests[j];
|
|
17386
17388
|
|
|
17387
|
-
|
|
17388
|
-
|
|
17389
|
-
}
|
|
17389
|
+
if (value.sameTerm(tests) || value.termType === test.termType && value.value === test.value) {
|
|
17390
|
+
match = true;
|
|
17390
17391
|
}
|
|
17391
|
-
} catch (err) {
|
|
17392
|
-
_iterator.e(err);
|
|
17393
|
-
} finally {
|
|
17394
|
-
_iterator.f();
|
|
17395
17392
|
}
|
|
17393
|
+
} catch (err) {
|
|
17394
|
+
_iterator.e(err);
|
|
17395
|
+
} finally {
|
|
17396
|
+
_iterator.f();
|
|
17396
17397
|
}
|
|
17398
|
+
}
|
|
17397
17399
|
|
|
17398
|
-
|
|
17399
|
-
|
|
17400
|
-
|
|
17401
|
-
if (!_field3) {
|
|
17402
|
-
box.appendChild((0, _error.errorMessageBlock)(dom, 'No "use" part for case in form ' + form));
|
|
17403
|
-
return box;
|
|
17404
|
-
} else {
|
|
17405
|
-
appendForm(dom, box, already, subject, _field3, dataDoc, callbackFunction);
|
|
17406
|
-
}
|
|
17400
|
+
if (match) {
|
|
17401
|
+
var _field3 = kb.the(c, ui('use'));
|
|
17407
17402
|
|
|
17408
|
-
|
|
17403
|
+
if (!_field3) {
|
|
17404
|
+
box.appendChild((0, _error.errorMessageBlock)(dom, 'No "use" part for case in form ' + form));
|
|
17405
|
+
return box;
|
|
17406
|
+
} else {
|
|
17407
|
+
appendForm(dom, box, already, subject, _field3, dataDoc, callbackFunction);
|
|
17409
17408
|
}
|
|
17409
|
+
|
|
17410
|
+
break;
|
|
17410
17411
|
}
|
|
17411
17412
|
} // @@ Add box.refresh() to sync fields with values
|
|
17412
17413
|
|
|
@@ -17694,7 +17695,7 @@ _fieldFunction.field[ns.ui('Multiple').uri] = function (dom, container, already,
|
|
|
17694
17695
|
// delete button and move buttons
|
|
17695
17696
|
|
|
17696
17697
|
if (kb.updater.editable(dataDoc.uri)) {
|
|
17697
|
-
buttons.deleteButtonWithCheck(dom, subField,
|
|
17698
|
+
buttons.deleteButtonWithCheck(dom, subField, multipleUIlabel, deleteThisItem);
|
|
17698
17699
|
|
|
17699
17700
|
if (ordered) {
|
|
17700
17701
|
// Add controsl in a frame
|
|
@@ -17745,7 +17746,7 @@ _fieldFunction.field[ns.ui('Multiple').uri] = function (dom, container, already,
|
|
|
17745
17746
|
|
|
17746
17747
|
var _shim = dom.createElement('div');
|
|
17747
17748
|
|
|
17748
|
-
_shim.appendChild(subField); // Subfield has its own
|
|
17749
|
+
_shim.appendChild(subField); // Subfield has its own layout
|
|
17749
17750
|
|
|
17750
17751
|
|
|
17751
17752
|
frame.appendChild(_shim);
|
|
@@ -17794,6 +17795,8 @@ _fieldFunction.field[ns.ui('Multiple').uri] = function (dom, container, already,
|
|
|
17794
17795
|
return shim;
|
|
17795
17796
|
}
|
|
17796
17797
|
|
|
17798
|
+
var multipleUIlabel = kb.any(form, ui('label'));
|
|
17799
|
+
if (!multipleUIlabel) multipleUIlabel = utils.label(property);
|
|
17797
17800
|
var min = kb.any(form, ui('min')); // This is the minimum number -- default 0
|
|
17798
17801
|
|
|
17799
17802
|
min = min ? 0 + min.value : 0;
|
|
@@ -17834,10 +17837,9 @@ _fieldFunction.field[ns.ui('Multiple').uri] = function (dom, container, already,
|
|
|
17834
17837
|
img.setAttribute('src', plusIconURI); // plus sign
|
|
17835
17838
|
|
|
17836
17839
|
img.setAttribute('style', 'margin: 0.2em; width: 1.5em; height:1.5em');
|
|
17837
|
-
img.title = 'Click to add
|
|
17838
|
-
var prompt =
|
|
17839
|
-
prompt.textContent = (values.length === 0 ? 'Add
|
|
17840
|
-
|
|
17840
|
+
img.title = 'Click to add another ' + multipleUIlabel;
|
|
17841
|
+
var prompt = dom.createElement('span');
|
|
17842
|
+
prompt.textContent = (values.length === 0 ? 'Add another ' : 'Add ') + multipleUIlabel;
|
|
17841
17843
|
tail.addEventListener('click', /*#__PURE__*/function () {
|
|
17842
17844
|
var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5(_eventNotUsed) {
|
|
17843
17845
|
return _regenerator["default"].wrap(function _callee5$(_context5) {
|
|
@@ -17859,6 +17861,7 @@ _fieldFunction.field[ns.ui('Multiple').uri] = function (dom, container, already,
|
|
|
17859
17861
|
return _ref3.apply(this, arguments);
|
|
17860
17862
|
};
|
|
17861
17863
|
}(), true);
|
|
17864
|
+
tail.appendChild(prompt);
|
|
17862
17865
|
}
|
|
17863
17866
|
|
|
17864
17867
|
function createListIfNecessary() {
|
|
@@ -18133,23 +18136,26 @@ _fieldFunction.field[ns.ui('Classifier').uri] = function (dom, container, alread
|
|
|
18133
18136
|
** -- radio buttons
|
|
18134
18137
|
** -- auto-complete typing
|
|
18135
18138
|
**
|
|
18136
|
-
**
|
|
18139
|
+
** TODO: according to ontology ui:choice can also have ns.ui('default') - this is not implemented yet
|
|
18137
18140
|
*/
|
|
18138
18141
|
|
|
18139
18142
|
|
|
18140
18143
|
_fieldFunction.field[ns.ui('Choice').uri] = function (dom, container, already, subject, form, dataDoc, callbackFunction) {
|
|
18141
18144
|
var ui = ns.ui;
|
|
18142
18145
|
var kb = _solidLogic.store;
|
|
18143
|
-
var multiple = false;
|
|
18144
18146
|
var formDoc = form.doc ? form.doc() : null; // @@ if blank no way to know
|
|
18145
18147
|
|
|
18148
|
+
var multiSelect = false;
|
|
18146
18149
|
var p;
|
|
18147
|
-
var box = dom.createElement('div');
|
|
18150
|
+
var box = dom.createElement('div');
|
|
18151
|
+
box.setAttribute('class', 'choiceBox'); // Set flexDirection column?
|
|
18148
18152
|
|
|
18149
18153
|
if (container) container.appendChild(box);
|
|
18150
18154
|
var lhs = dom.createElement('div');
|
|
18155
|
+
lhs.setAttribute('class', 'formFieldName choiceBox-label');
|
|
18151
18156
|
box.appendChild(lhs);
|
|
18152
18157
|
var rhs = dom.createElement('div');
|
|
18158
|
+
rhs.setAttribute('class', 'formFieldValue choiceBox-selectBox');
|
|
18153
18159
|
box.appendChild(rhs);
|
|
18154
18160
|
var property = kb.any(form, ui('property'));
|
|
18155
18161
|
|
|
@@ -18168,79 +18174,79 @@ _fieldFunction.field[ns.ui('Choice').uri] = function (dom, container, already, s
|
|
|
18168
18174
|
|
|
18169
18175
|
var follow = kb.anyJS(form, ui('follow'), null, formDoc); // data doc moves to new subject?
|
|
18170
18176
|
|
|
18171
|
-
var possible = [];
|
|
18172
|
-
var possibleProperties;
|
|
18173
|
-
var firstSelectOptionText = '* Select from ' + utils.label(subject, true) + ' *';
|
|
18174
18177
|
var opts = {
|
|
18175
18178
|
form: form,
|
|
18176
18179
|
subForm: subForm,
|
|
18177
|
-
|
|
18178
|
-
firstSelectOptionText: firstSelectOptionText,
|
|
18180
|
+
multiSelect: multiSelect,
|
|
18179
18181
|
disambiguate: false
|
|
18180
18182
|
};
|
|
18181
|
-
possible = kb.each(undefined, ns.rdf('type'), uiFrom, formDoc);
|
|
18182
18183
|
|
|
18183
|
-
|
|
18184
|
-
possible
|
|
18185
|
-
|
|
18184
|
+
function getSelectorOptions() {
|
|
18185
|
+
var possible = [];
|
|
18186
|
+
var possibleProperties;
|
|
18187
|
+
possible = kb.each(undefined, ns.rdf('type'), uiFrom, formDoc);
|
|
18186
18188
|
|
|
18189
|
+
for (var x in kb.findMembersNT(uiFrom)) {
|
|
18190
|
+
possible.push(kb.fromNT(x));
|
|
18191
|
+
} // Use rdfs
|
|
18187
18192
|
|
|
18188
|
-
if (uiFrom.sameTerm(ns.rdfs('Class'))) {
|
|
18189
|
-
for (p in buttons.allClassURIs()) {
|
|
18190
|
-
possible.push(kb.sym(p));
|
|
18191
|
-
} // log.debug("%%% Choice field: possible.length 2 = "+possible.length)
|
|
18192
18193
|
|
|
18193
|
-
|
|
18194
|
-
|
|
18194
|
+
if (uiFrom.sameTerm(ns.rdfs('Class'))) {
|
|
18195
|
+
for (p in buttons.allClassURIs()) {
|
|
18196
|
+
possible.push(kb.sym(p));
|
|
18197
|
+
} // log.debug("%%% Choice field: possible.length 2 = "+possible.length)
|
|
18195
18198
|
|
|
18196
|
-
|
|
18197
|
-
|
|
18198
|
-
}
|
|
18199
|
+
} else if (uiFrom.sameTerm(ns.rdf('Property'))) {
|
|
18200
|
+
possibleProperties = buttons.propertyTriage(kb);
|
|
18199
18201
|
|
|
18200
|
-
|
|
18201
|
-
|
|
18202
|
-
|
|
18202
|
+
for (p in possibleProperties.op) {
|
|
18203
|
+
possible.push(kb.fromNT(p));
|
|
18204
|
+
}
|
|
18203
18205
|
|
|
18204
|
-
|
|
18205
|
-
|
|
18206
|
-
|
|
18206
|
+
for (p in possibleProperties.dp) {
|
|
18207
|
+
possible.push(kb.fromNT(p));
|
|
18208
|
+
}
|
|
18207
18209
|
|
|
18208
|
-
|
|
18209
|
-
|
|
18210
|
-
|
|
18210
|
+
opts.disambiguate = true; // This is a big class, and the labels won't be enough.
|
|
18211
|
+
} else if (uiFrom.sameTerm(ns.owl('ObjectProperty'))) {
|
|
18212
|
+
possibleProperties = buttons.propertyTriage(kb);
|
|
18213
|
+
|
|
18214
|
+
for (p in possibleProperties.op) {
|
|
18215
|
+
possible.push(kb.fromNT(p));
|
|
18216
|
+
}
|
|
18211
18217
|
|
|
18212
|
-
|
|
18213
|
-
|
|
18214
|
-
|
|
18218
|
+
opts.disambiguate = true;
|
|
18219
|
+
} else if (uiFrom.sameTerm(ns.owl('DatatypeProperty'))) {
|
|
18220
|
+
possibleProperties = buttons.propertyTriage(kb);
|
|
18215
18221
|
|
|
18216
|
-
|
|
18217
|
-
|
|
18222
|
+
for (p in possibleProperties.dp) {
|
|
18223
|
+
possible.push(kb.fromNT(p));
|
|
18224
|
+
}
|
|
18225
|
+
|
|
18226
|
+
opts.disambiguate = true;
|
|
18218
18227
|
}
|
|
18219
18228
|
|
|
18220
|
-
|
|
18221
|
-
|
|
18229
|
+
var object = kb.any(subject, property);
|
|
18230
|
+
if (object) possible.push(object);
|
|
18231
|
+
return sortByLabel(possible);
|
|
18232
|
+
} // TODO: this checks for any occurrence, regardless of true or false setting
|
|
18222
18233
|
|
|
18223
|
-
var sortedPossible = sortByLabel(possible); // TODO: this checks for any occurance regardles if it is set to true or false
|
|
18224
18234
|
|
|
18225
18235
|
if (kb.any(form, ui('canMintNew'))) {
|
|
18226
18236
|
opts.mint = '* Create new *'; // @@ could be better
|
|
18227
18237
|
}
|
|
18228
18238
|
|
|
18229
|
-
var selector
|
|
18230
|
-
rhs.appendChild(selector);
|
|
18231
|
-
var object;
|
|
18232
|
-
|
|
18233
|
-
if (selector.currentURI) {
|
|
18234
|
-
object = $rdf.sym(selector.currentURI);
|
|
18235
|
-
} else {
|
|
18236
|
-
object = kb.any(subject, property);
|
|
18237
|
-
}
|
|
18239
|
+
var selector;
|
|
18238
18240
|
|
|
18239
|
-
|
|
18240
|
-
|
|
18241
|
-
|
|
18242
|
-
|
|
18241
|
+
rhs.refresh = function () {
|
|
18242
|
+
var selectorOptions = getSelectorOptions();
|
|
18243
|
+
selector = makeSelectForChoice(dom, rhs, kb, subject, property, selectorOptions, uiFrom, opts, dataDoc, callbackFunction);
|
|
18244
|
+
rhs.innerHTML = '';
|
|
18245
|
+
rhs.appendChild(selector);
|
|
18246
|
+
};
|
|
18243
18247
|
|
|
18248
|
+
rhs.refresh();
|
|
18249
|
+
if (selector && selector.refresh) selector.refresh();
|
|
18244
18250
|
return box;
|
|
18245
18251
|
};
|
|
18246
18252
|
/**
|
|
@@ -18461,7 +18467,8 @@ function promptForNew(dom, kb, subject, predicate, theClass, form, dataDoc, call
|
|
|
18461
18467
|
b.setAttribute('type', 'button');
|
|
18462
18468
|
b.setAttribute('style', 'float: right;');
|
|
18463
18469
|
b.innerHTML = 'Goto ' + utils.label(theClass);
|
|
18464
|
-
b.addEventListener('click',
|
|
18470
|
+
b.addEventListener('click', // TODO fix dependency cycle to solid-panes by calling outlineManager
|
|
18471
|
+
function (_e) {
|
|
18465
18472
|
dom.outlineManager.GotoSubject(theClass, true, undefined, true, undefined);
|
|
18466
18473
|
}, false);
|
|
18467
18474
|
return box;
|
|
@@ -18596,17 +18603,15 @@ function makeDescription(dom, kb, subject, predicate, dataDoc, callbackFunction)
|
|
|
18596
18603
|
// @param subject - a term, the subject of the statement(s) being edited.
|
|
18597
18604
|
// @param predicate - a term, the predicate of the statement(s) being edited
|
|
18598
18605
|
// @param possible - a list of terms, the possible value the object can take
|
|
18599
|
-
// @param options.
|
|
18600
|
-
// @param options.firstSelectOptionText - a string to be displayed as the
|
|
18606
|
+
// @param options.nullLabel - a string to be displayed as the
|
|
18601
18607
|
// option for none selected (for non multiple)
|
|
18602
|
-
// @param options.mint - User may create thing if this sent to the prompt string eg "New foo"
|
|
18603
18608
|
// @param options.subForm - If mint, then the form to be used for minting the new thing
|
|
18604
18609
|
// @param dataDoc - The web document being edited
|
|
18605
18610
|
// @param callbackFunction - takes (boolean ok, string errorBody)
|
|
18606
18611
|
*/
|
|
18607
18612
|
|
|
18608
18613
|
|
|
18609
|
-
function makeSelectForOptions(dom, kb, subject, predicate, possible,
|
|
18614
|
+
function makeSelectForOptions(dom, kb, subject, predicate, possible, options, dataDoc, callbackFunction) {
|
|
18610
18615
|
log.debug('Select list length now ' + possible.length);
|
|
18611
18616
|
var n = 0;
|
|
18612
18617
|
var uris = {}; // Count them
|
|
@@ -18623,7 +18628,7 @@ function makeSelectForOptions(dom, kb, subject, predicate, possible, uiFrom, opt
|
|
|
18623
18628
|
} // uris is now the set of possible options
|
|
18624
18629
|
|
|
18625
18630
|
|
|
18626
|
-
if (n === 0
|
|
18631
|
+
if (n === 0) {
|
|
18627
18632
|
return (0, _error.errorMessageBlock)(dom, "Can't do selector with no options, subject= " + subject + ' property = ' + predicate + '.');
|
|
18628
18633
|
}
|
|
18629
18634
|
|
|
@@ -18649,6 +18654,8 @@ function makeSelectForOptions(dom, kb, subject, predicate, possible, uiFrom, opt
|
|
|
18649
18654
|
actual = getActual();
|
|
18650
18655
|
|
|
18651
18656
|
var onChange = function onChange(_e) {
|
|
18657
|
+
select.disabled = true; // until data written back - gives user feedback too
|
|
18658
|
+
|
|
18652
18659
|
var ds = [];
|
|
18653
18660
|
var is = [];
|
|
18654
18661
|
|
|
@@ -18658,43 +18665,18 @@ function makeSelectForOptions(dom, kb, subject, predicate, possible, uiFrom, opt
|
|
|
18658
18665
|
}
|
|
18659
18666
|
};
|
|
18660
18667
|
|
|
18661
|
-
var newObject;
|
|
18662
|
-
|
|
18663
18668
|
for (var _i = 0; _i < select.options.length; _i++) {
|
|
18664
18669
|
var opt = select.options[_i];
|
|
18665
|
-
|
|
18666
|
-
if (opt.selected && opt.AJAR_mint) {
|
|
18667
|
-
// not sure if this 'if' is used because I cannot find mintClass
|
|
18668
|
-
if (options.mintClass) {
|
|
18669
|
-
var thisForm = promptForNew(dom, kb, subject, predicate, options.mintClass, null, dataDoc, function (ok, body) {
|
|
18670
|
-
if (!ok) {
|
|
18671
|
-
callbackFunction(ok, body, {
|
|
18672
|
-
change: 'new'
|
|
18673
|
-
}); // @@ if ok, need some form of refresh of the select for the new thing
|
|
18674
|
-
}
|
|
18675
|
-
});
|
|
18676
|
-
select.parentNode.appendChild(thisForm);
|
|
18677
|
-
newObject = thisForm.AJAR_subject;
|
|
18678
|
-
} else {
|
|
18679
|
-
newObject = newThing(dataDoc);
|
|
18680
|
-
}
|
|
18681
|
-
|
|
18682
|
-
is.push($rdf.st(subject, predicate, kb.sym(newObject), dataDoc));
|
|
18683
|
-
if (uiFrom) is.push($rdf.st(newObject, ns.rdf('type'), kb.sym(uiFrom), dataDoc)); // not sure if this 'if' is used because I cannot find mintStatementsFun
|
|
18684
|
-
|
|
18685
|
-
if (options.mintStatementsFun) {
|
|
18686
|
-
is = is.concat(options.mintStatementsFun(newObject));
|
|
18687
|
-
}
|
|
18688
|
-
|
|
18689
|
-
select.currentURI = newObject;
|
|
18690
|
-
}
|
|
18691
|
-
|
|
18692
18670
|
if (!opt.AJAR_uri) continue; // a prompt or mint
|
|
18693
18671
|
|
|
18694
18672
|
if (opt.selected && !(opt.AJAR_uri in actual)) {
|
|
18695
18673
|
// new class
|
|
18696
18674
|
is.push($rdf.st(subject, predicate, kb.sym(opt.AJAR_uri), dataDoc));
|
|
18697
|
-
|
|
18675
|
+
}
|
|
18676
|
+
|
|
18677
|
+
if (!opt.selected && opt.AJAR_uri in actual) {
|
|
18678
|
+
// old class
|
|
18679
|
+
removeValue(kb.sym(opt.AJAR_uri));
|
|
18698
18680
|
}
|
|
18699
18681
|
|
|
18700
18682
|
if (opt.selected) select.currentURI = opt.AJAR_uri;
|
|
@@ -18714,29 +18696,25 @@ function makeSelectForOptions(dom, kb, subject, predicate, possible, uiFrom, opt
|
|
|
18714
18696
|
sel = sel.superSelect;
|
|
18715
18697
|
}
|
|
18716
18698
|
|
|
18717
|
-
log.info('selectForOptions: data doc = ' + dataDoc);
|
|
18699
|
+
log.info('selectForOptions: data doc = ' + dataDoc);
|
|
18700
|
+
kb.updater.update(ds, is, function (uri, ok, body) {
|
|
18701
|
+
actual = getActual(); // refresh
|
|
18718
18702
|
|
|
18719
|
-
removeNextSiblingsAfterElement(select);
|
|
18720
|
-
addSubFormChoice(dom, select.parentNode, {}, $rdf.sym(select.currentURI), options.subForm, dataDoc, function (ok, body) {
|
|
18721
18703
|
if (ok) {
|
|
18722
|
-
|
|
18723
|
-
actual = getActual(); // refresh
|
|
18724
|
-
|
|
18725
|
-
if (!success) select.parentNode.appendChild((0, _error.errorMessageBlock)(dom, 'Error updating select: ' + errorBody));
|
|
18726
|
-
});
|
|
18727
|
-
if (callbackFunction) callbackFunction(ok, {
|
|
18728
|
-
widget: 'select',
|
|
18729
|
-
event: 'new'
|
|
18730
|
-
});
|
|
18704
|
+
select.disabled = false; // data written back
|
|
18731
18705
|
} else {
|
|
18732
|
-
select.parentNode.appendChild((0, _error.errorMessageBlock)(dom, 'Error updating data in
|
|
18706
|
+
return select.parentNode.appendChild((0, _error.errorMessageBlock)(dom, 'Error updating data in select: ' + body));
|
|
18733
18707
|
}
|
|
18708
|
+
|
|
18709
|
+
if (callbackFunction) callbackFunction(ok, {
|
|
18710
|
+
widget: 'select',
|
|
18711
|
+
event: 'change'
|
|
18712
|
+
});
|
|
18734
18713
|
});
|
|
18735
18714
|
};
|
|
18736
18715
|
|
|
18737
18716
|
var select = dom.createElement('select');
|
|
18738
18717
|
select.setAttribute('style', style.formSelectSTyle);
|
|
18739
|
-
if (options.multiple) select.setAttribute('multiple', 'true');
|
|
18740
18718
|
select.currentURI = null;
|
|
18741
18719
|
|
|
18742
18720
|
select.refresh = function () {
|
|
@@ -18779,22 +18757,11 @@ function makeSelectForOptions(dom, kb, subject, predicate, possible, uiFrom, opt
|
|
|
18779
18757
|
select.appendChild(option);
|
|
18780
18758
|
}
|
|
18781
18759
|
|
|
18782
|
-
if (
|
|
18783
|
-
var mint = dom.createElement('option');
|
|
18784
|
-
mint.appendChild(dom.createTextNode(options.mint));
|
|
18785
|
-
mint.AJAR_mint = true; // Flag it
|
|
18786
|
-
|
|
18787
|
-
select.insertBefore(mint, select.firstChild);
|
|
18788
|
-
}
|
|
18789
|
-
|
|
18790
|
-
if (!select.currentURI && !options.multiple) {
|
|
18760
|
+
if (!select.currentURI) {
|
|
18791
18761
|
var prompt = dom.createElement('option');
|
|
18792
|
-
prompt.appendChild(dom.createTextNode(options.
|
|
18793
|
-
prompt.disabled = true;
|
|
18794
|
-
prompt.value = true;
|
|
18795
|
-
prompt.hidden = true;
|
|
18796
|
-
prompt.selected = true;
|
|
18762
|
+
prompt.appendChild(dom.createTextNode(options.nullLabel));
|
|
18797
18763
|
select.insertBefore(prompt, select.firstChild);
|
|
18764
|
+
prompt.selected = true;
|
|
18798
18765
|
}
|
|
18799
18766
|
|
|
18800
18767
|
if (editable) {
|
|
@@ -18813,27 +18780,16 @@ function makeSelectForOptions(dom, kb, subject, predicate, possible, uiFrom, opt
|
|
|
18813
18780
|
function makeSelectForCategory(dom, kb, subject, category, dataDoc, callbackFunction) {
|
|
18814
18781
|
var du = kb.any(category, ns.owl('disjointUnionOf'));
|
|
18815
18782
|
var subs;
|
|
18816
|
-
var multiple = false;
|
|
18817
18783
|
|
|
18818
18784
|
if (!du) {
|
|
18819
18785
|
subs = kb.each(undefined, ns.rdfs('subClassOf'), category);
|
|
18820
|
-
multiple = true;
|
|
18821
18786
|
} else {
|
|
18822
18787
|
subs = du.elements;
|
|
18823
18788
|
}
|
|
18824
18789
|
|
|
18825
18790
|
log.debug('Select list length ' + subs.length);
|
|
18826
|
-
|
|
18827
|
-
|
|
18828
|
-
return (0, _error.errorMessageBlock)(dom, "Can't do " + (multiple ? 'multiple ' : '') + 'selector with no subclasses of category: ' + category);
|
|
18829
|
-
}
|
|
18830
|
-
|
|
18831
|
-
if (subs.length === 1) {
|
|
18832
|
-
return (0, _error.errorMessageBlock)(dom, "Can't do " + (multiple ? 'multiple ' : '') + 'selector with only 1 subclass of category: ' + category + ':' + subs[1]);
|
|
18833
|
-
}
|
|
18834
|
-
|
|
18835
|
-
return makeSelectForOptions(dom, kb, subject, ns.rdf('type'), subs, null, {
|
|
18836
|
-
multiple: multiple
|
|
18791
|
+
return makeSelectForOptions(dom, kb, subject, ns.rdf('type'), subs, {
|
|
18792
|
+
nullLabel: '* Select type *'
|
|
18837
18793
|
}, dataDoc, callbackFunction);
|
|
18838
18794
|
}
|
|
18839
18795
|
/** Make SELECT element to select subclasses recurively
|
|
@@ -18867,8 +18823,7 @@ function makeSelectForNestedCategory(dom, kb, subject, category, dataDoc, callba
|
|
|
18867
18823
|
function onChange(ok, body) {
|
|
18868
18824
|
if (ok) update();
|
|
18869
18825
|
callbackFunction(ok, body);
|
|
18870
|
-
}
|
|
18871
|
-
|
|
18826
|
+
}
|
|
18872
18827
|
|
|
18873
18828
|
var select = makeSelectForCategory(dom, kb, subject, category, dataDoc, onChange);
|
|
18874
18829
|
container.appendChild(select);
|
|
@@ -19023,6 +18978,196 @@ function newThing(doc) {
|
|
|
19023
18978
|
var now = new Date();
|
|
19024
18979
|
return $rdf.sym(doc.uri + '#' + 'id' + ('' + now.getTime()));
|
|
19025
18980
|
}
|
|
18981
|
+
/** Make SELECT element to select options
|
|
18982
|
+
//
|
|
18983
|
+
// @param subject - a term, the subject of the statement(s) being edited.
|
|
18984
|
+
// @param predicate - a term, the predicate of the statement(s) being edited
|
|
18985
|
+
// @param possible - a list of terms, the possible value the object can take
|
|
18986
|
+
// @param options.multiSelect - Boolean - Whether more than one at a time is allowed
|
|
18987
|
+
// @param options.uiMultipleInUse - signals that the ui:choise is used with a ui:multiple
|
|
18988
|
+
// @param options.mint - User may create thing if this sent to the prompt string eg "New foo"
|
|
18989
|
+
// @param options.subForm - If mint, then the form to be used for minting the new thing
|
|
18990
|
+
// @param dataDoc - The web document being edited
|
|
18991
|
+
// @param callbackFunction - takes (boolean ok, string errorBody)
|
|
18992
|
+
*/
|
|
18993
|
+
|
|
18994
|
+
|
|
18995
|
+
function makeSelectForChoice(dom, container, kb, subject, predicate, possible, uiFrom, options, dataDoc, callbackFunction) {
|
|
18996
|
+
var n = 0;
|
|
18997
|
+
var uris = {}; // Count them
|
|
18998
|
+
|
|
18999
|
+
var editable = kb.updater.editable(dataDoc.uri);
|
|
19000
|
+
|
|
19001
|
+
for (var i = 0; i < possible.length; i++) {
|
|
19002
|
+
var sub = possible[i]; // @@ Maybe; make this so it works with blank nodes too
|
|
19003
|
+
|
|
19004
|
+
if (!sub.uri) debug.warn("makeSelectForOptions: option does not have an uri: ".concat(sub, ", with predicate: ").concat(predicate));
|
|
19005
|
+
if (!sub.uri || sub.uri in uris) continue;
|
|
19006
|
+
uris[sub.uri] = true;
|
|
19007
|
+
n++;
|
|
19008
|
+
} // uris is now the set of possible options
|
|
19009
|
+
|
|
19010
|
+
|
|
19011
|
+
if (n === 0 && !options.mint) {
|
|
19012
|
+
return (0, _error.errorMessageBlock)(dom, "Can't do selector with no options, subject= " + subject + ' property = ' + predicate + '.');
|
|
19013
|
+
}
|
|
19014
|
+
|
|
19015
|
+
log.debug('makeSelectForOptions: dataDoc=' + dataDoc);
|
|
19016
|
+
|
|
19017
|
+
function determinFirstSelectOption() {
|
|
19018
|
+
var firstSelectOptionText = '--- classify ---';
|
|
19019
|
+
var option = dom.createElement('option');
|
|
19020
|
+
|
|
19021
|
+
if (predicate && !(predicate.termType === 'BlankNode')) {
|
|
19022
|
+
firstSelectOptionText = '* Select for property: ' + utils.label(predicate) + ' *';
|
|
19023
|
+
}
|
|
19024
|
+
|
|
19025
|
+
if (subject && !(subject.termType === 'BlankNode')) {
|
|
19026
|
+
firstSelectOptionText = '* Select for ' + utils.label(subject, true) + ' *';
|
|
19027
|
+
}
|
|
19028
|
+
|
|
19029
|
+
option.appendChild(dom.createTextNode(firstSelectOptionText));
|
|
19030
|
+
option.disabled = true;
|
|
19031
|
+
option.value = true;
|
|
19032
|
+
option.hidden = true;
|
|
19033
|
+
option.selected = true;
|
|
19034
|
+
return option;
|
|
19035
|
+
}
|
|
19036
|
+
|
|
19037
|
+
var onChange = function onChange(_e) {
|
|
19038
|
+
select.refresh();
|
|
19039
|
+
};
|
|
19040
|
+
|
|
19041
|
+
var select = dom.createElement('select');
|
|
19042
|
+
select.setAttribute('style', style.formSelectSTyle);
|
|
19043
|
+
if (options.multiSelect) select.setAttribute('multiSelect', 'true');
|
|
19044
|
+
select.currentURI = null;
|
|
19045
|
+
|
|
19046
|
+
for (var uri in uris) {
|
|
19047
|
+
select.appendChild(createOption(uri));
|
|
19048
|
+
}
|
|
19049
|
+
|
|
19050
|
+
if (editable && options.mint) {
|
|
19051
|
+
var mint = dom.createElement('option');
|
|
19052
|
+
mint.appendChild(dom.createTextNode(options.mint));
|
|
19053
|
+
mint.AJAR_mint = true; // Flag it
|
|
19054
|
+
|
|
19055
|
+
select.insertBefore(mint, select.firstChild);
|
|
19056
|
+
}
|
|
19057
|
+
|
|
19058
|
+
if (select.children.length === 0) select.insertBefore(determinFirstSelectOption(), select.firstChild);
|
|
19059
|
+
|
|
19060
|
+
select.refresh = function () {
|
|
19061
|
+
select.disabled = true; // unlocked any conflict we had got into
|
|
19062
|
+
|
|
19063
|
+
var ds = [];
|
|
19064
|
+
var is = [];
|
|
19065
|
+
|
|
19066
|
+
var removeValue = function removeValue(t) {
|
|
19067
|
+
if (kb.holds(subject, predicate, t, dataDoc)) {
|
|
19068
|
+
ds.push($rdf.st(subject, predicate, t, dataDoc));
|
|
19069
|
+
}
|
|
19070
|
+
};
|
|
19071
|
+
|
|
19072
|
+
var newObject;
|
|
19073
|
+
|
|
19074
|
+
for (var _i3 = 0; _i3 < select.options.length; _i3++) {
|
|
19075
|
+
var opt = select.options[_i3];
|
|
19076
|
+
|
|
19077
|
+
if (opt.selected && opt.AJAR_mint) {
|
|
19078
|
+
// not sure if this 'if' is used because I cannot find mintClass
|
|
19079
|
+
if (options.mintClass) {
|
|
19080
|
+
var thisForm = promptForNew(dom, kb, subject, predicate, options.mintClass, null, dataDoc, function (ok, body) {
|
|
19081
|
+
if (!ok) {
|
|
19082
|
+
callbackFunction(ok, body, {
|
|
19083
|
+
change: 'new'
|
|
19084
|
+
}); // @@ if ok, need some form of refresh of the select for the new thing
|
|
19085
|
+
}
|
|
19086
|
+
});
|
|
19087
|
+
select.parentNode.appendChild(thisForm);
|
|
19088
|
+
newObject = thisForm.AJAR_subject;
|
|
19089
|
+
} else {
|
|
19090
|
+
newObject = newThing(dataDoc);
|
|
19091
|
+
}
|
|
19092
|
+
|
|
19093
|
+
is.push($rdf.st(subject, predicate, kb.sym(newObject), dataDoc));
|
|
19094
|
+
if (uiFrom) is.push($rdf.st(newObject, ns.rdf('type'), kb.sym(uiFrom), dataDoc)); // not sure if this 'if' is used because I cannot find mintStatementsFun
|
|
19095
|
+
|
|
19096
|
+
if (options.mintStatementsFun) {
|
|
19097
|
+
is = is.concat(options.mintStatementsFun(newObject));
|
|
19098
|
+
}
|
|
19099
|
+
|
|
19100
|
+
select.currentURI = newObject;
|
|
19101
|
+
}
|
|
19102
|
+
|
|
19103
|
+
if (!opt.AJAR_uri) continue; // a prompt or mint
|
|
19104
|
+
|
|
19105
|
+
if (opt.selected) select.currentURI = opt.AJAR_uri;
|
|
19106
|
+
}
|
|
19107
|
+
|
|
19108
|
+
var sel = select.subSelect; // All subclasses must also go
|
|
19109
|
+
|
|
19110
|
+
while (sel && sel.currentURI) {
|
|
19111
|
+
removeValue(kb.sym(sel.currentURI));
|
|
19112
|
+
sel = sel.subSelect;
|
|
19113
|
+
}
|
|
19114
|
+
|
|
19115
|
+
sel = select.superSelect; // All superclasses are redundant
|
|
19116
|
+
|
|
19117
|
+
while (sel && sel.currentURI) {
|
|
19118
|
+
removeValue(kb.sym(sel.currentURI));
|
|
19119
|
+
sel = sel.superSelect;
|
|
19120
|
+
}
|
|
19121
|
+
|
|
19122
|
+
log.info('selectForOptions: data doc = ' + dataDoc);
|
|
19123
|
+
|
|
19124
|
+
if (select.currentURI) {
|
|
19125
|
+
removeNextSiblingsAfterElement(select);
|
|
19126
|
+
addSubFormChoice(dom, container, {}, $rdf.sym(select.currentURI), options.subForm, dataDoc, function (ok, body) {
|
|
19127
|
+
if (ok) {
|
|
19128
|
+
kb.updater.update(ds, is, function (uri, success, errorBody) {
|
|
19129
|
+
if (!success) container.appendChild((0, _error.errorMessageBlock)(dom, 'Error updating select: ' + errorBody));
|
|
19130
|
+
});
|
|
19131
|
+
if (callbackFunction) callbackFunction(ok, {
|
|
19132
|
+
widget: 'select',
|
|
19133
|
+
event: 'new'
|
|
19134
|
+
}); // widgets.refreshTree(container)
|
|
19135
|
+
} else {
|
|
19136
|
+
container.appendChild((0, _error.errorMessageBlock)(dom, 'Error updating data in field of select: ' + body));
|
|
19137
|
+
}
|
|
19138
|
+
});
|
|
19139
|
+
}
|
|
19140
|
+
|
|
19141
|
+
select.disabled = false;
|
|
19142
|
+
};
|
|
19143
|
+
|
|
19144
|
+
function createOption(uri) {
|
|
19145
|
+
var option = dom.createElement('option');
|
|
19146
|
+
var c = kb.sym(uri);
|
|
19147
|
+
|
|
19148
|
+
if (options.disambiguate) {
|
|
19149
|
+
option.appendChild(dom.createTextNode(utils.labelWithOntology(c, true))); // Init. cap
|
|
19150
|
+
} else {
|
|
19151
|
+
option.appendChild(dom.createTextNode(utils.label(c, true))); // Init.
|
|
19152
|
+
}
|
|
19153
|
+
|
|
19154
|
+
var backgroundColor = kb.any(c, kb.sym('http://www.w3.org/ns/ui#backgroundColor'));
|
|
19155
|
+
|
|
19156
|
+
if (backgroundColor) {
|
|
19157
|
+
option.setAttribute('style', 'background-color: ' + backgroundColor.value + '; ');
|
|
19158
|
+
}
|
|
19159
|
+
|
|
19160
|
+
option.AJAR_uri = uri;
|
|
19161
|
+
if (c.toString() === '' + select.currentURI) option.selected = true;
|
|
19162
|
+
return option;
|
|
19163
|
+
}
|
|
19164
|
+
|
|
19165
|
+
if (editable) {
|
|
19166
|
+
select.addEventListener('change', onChange, false);
|
|
19167
|
+
}
|
|
19168
|
+
|
|
19169
|
+
return select;
|
|
19170
|
+
} // makeSelectForChoice
|
|
19026
19171
|
//# sourceMappingURL=forms.js.map
|
|
19027
19172
|
|
|
19028
19173
|
/***/ }),
|