UNPKG

solid-panes

Version:

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

177 lines (173 loc) 8.54 kB
"use strict"; 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