solid-panes
Version:
Solid-compatible Panes: applets and views for the mashlib and databrowser
177 lines (173 loc) • 8.54 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.createApplicationTable = createApplicationTable;
exports.createContainer = createContainer;
exports.createText = createText;
var _rdflib = require("rdflib");
var _solidUi = require("solid-ui");
var _solidLogic = require("solid-logic");
var _trustedApplications = require("./trustedApplications.utils");
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
function createApplicationTable(subject) {
var applicationsTable = createElement('table', {
"class": 'results'
});
// creating headers
var header = createContainer('tr', [createText('th', 'Application URL'), createText('th', 'Access modes'), createText('th', 'Actions')]);
applicationsTable.appendChild(header);
// creating rows
_solidLogic.store.each(subject, _solidUi.ns.acl('trustedApp'), undefined, undefined).flatMap(function (app) {
return _solidLogic.store.each(app, _solidUi.ns.acl('origin'), undefined, undefined).map(function (origin) {
return {
appModes: _solidLogic.store.each(app, _solidUi.ns.acl('mode'), undefined, undefined),
origin: origin
};
});
}).sort(function (a, b) {
return a.origin.value < b.origin.value ? -1 : 1;
}).forEach(function (_ref) {
var appModes = _ref.appModes,
origin = _ref.origin;
return applicationsTable.appendChild(createApplicationEntry(subject, origin, appModes, updateTable));
});
// adding a row for new applications
applicationsTable.appendChild(createApplicationEntry(subject, null, [_solidUi.ns.acl('Read')], updateTable));
return applicationsTable;
function updateTable() {
applicationsTable.parentElement.replaceChild(createApplicationTable(subject), applicationsTable);
}
}
function createApplicationEntry(subject, origin, appModes, updateTable) {
var trustedApplicationState = {
origin: origin,
appModes: appModes,
formElements: {
modes: [],
origin: undefined
}
};
return createContainer('tr', [createContainer('td', [createContainer('form', [createElement('input', {
"class": 'textinput',
placeholder: 'Write new URL here',
value: origin ? origin.value : ''
}, {}, function (element) {
trustedApplicationState.formElements.origin = element;
})], {}, {
submit: addOrEditApplication
})]), createContainer('td', [createContainer('form', createModesInput(trustedApplicationState), {}, {
submit: addOrEditApplication
})]), createContainer('td', [createContainer('form', origin ? [createText('button', 'Update', {
"class": 'controlButton',
style: 'background: LightGreen;'
}), createText('button', 'Delete', {
"class": 'controlButton',
style: 'background: LightCoral;'
}, {
click: removeApplication
})] : [createText('button', 'Add', {
"class": 'controlButton',
style: 'background: LightGreen;'
})], {}, {
submit: addOrEditApplication
})])]);
function addOrEditApplication(event) {
event.preventDefault();
var origin;
try {
origin = (0, _rdflib.sym)(trustedApplicationState.formElements.origin.value);
} catch (err) {
return alert('Please provide an application URL you want to trust');
}
var modes = trustedApplicationState.formElements.modes.filter(function (checkbox) {
return checkbox.checked;
}).map(function (checkbox) {
return checkbox.value;
});
var deletions = (0, _trustedApplications.getStatementsToDelete)(trustedApplicationState.origin || origin, subject, _solidLogic.store, _solidUi.ns);
var additions = (0, _trustedApplications.getStatementsToAdd)(origin, (0, _trustedApplications.generateRandomString)(), modes, subject, _solidUi.ns);
if (!_solidLogic.store.updater) {
throw new Error('Store has no updater');
}
_solidLogic.store.updater.update(deletions, additions, handleUpdateResponse);
}
function removeApplication(event) {
event.preventDefault();
var origin;
try {
origin = (0, _rdflib.sym)(trustedApplicationState.formElements.origin.value);
} catch (err) {
return alert('Please provide an application URL you want to remove trust from');
}
var deletions = (0, _trustedApplications.getStatementsToDelete)(origin, subject, _solidLogic.store, _solidUi.ns);
if (!_solidLogic.store.updater) {
throw new Error('Store has no updater');
}
_solidLogic.store.updater.update(deletions, [], handleUpdateResponse);
}
function handleUpdateResponse(uri, success, errorBody) {
if (success) {
return updateTable();
}
console.error(uri, errorBody);
}
}
function createElement(elementName) {
var attributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
var eventListeners = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var onCreated = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;
var element = document.createElement(elementName);
if (onCreated) {
onCreated(element);
}
Object.keys(attributes).forEach(function (attName) {
element.setAttribute(attName, attributes[attName]);
});
Object.keys(eventListeners).forEach(function (eventName) {
element.addEventListener(eventName, eventListeners[eventName]);
});
return element;
}
function createContainer(elementName, children) {
var attributes = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var eventListeners = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
var onCreated = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
var element = createElement(elementName, attributes, eventListeners, onCreated);
children.forEach(function (child) {
return element.appendChild(child);
});
return element;
}
function createText(elementName, textContent) {
var attributes = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var eventListeners = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
var onCreated = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
var element = createElement(elementName, attributes, eventListeners, onCreated);
element.textContent = textContent;
return element;
}
function createModesInput(_ref2) {
var appModes = _ref2.appModes,
formElements = _ref2.formElements;
return ['Read', 'Write', 'Append', 'Control'].map(function (mode) {
var isChecked = appModes.some(function (appMode) {
return appMode.value === _solidUi.ns.acl(mode).value;
});
return createContainer('label', [createElement('input', _objectSpread(_objectSpread({
type: 'checkbox'
}, isChecked ? {
checked: ''
} : {}), {}, {
value: _solidUi.ns.acl(mode).uri
}), {}, function (element) {
return formElements.modes.push(element);
}), createText('span', mode)]);
});
}
//# sourceMappingURL=trustedApplications.dom.js.map