mashlib 1.7.22-f2c8fbbb → 1.8.0

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/LICENSE.md CHANGED
File without changes
package/README.md CHANGED
@@ -39,51 +39,70 @@ Check out [SolidOS Pod](https://solidos.solidcommunity.net/Team/docs/solidos.htm
39
39
 
40
40
  # Documentation
41
41
 
42
- ## Different implemnetation
42
+ ## Different implementations
43
43
 
44
44
  ### SolidOS Databrowser Webapp
45
45
 
46
46
  The `static/browse.html` page is compiled one to one into the `dist` (output) folder of mashlib and makes mashlib available stand-alone as the SolidOS Databrowser Webapp.
47
47
 
48
- You can see and try out a SolidOS Databrowser Webapp deployment under this link: <https://solid.github.io/mashlib/dist/browse.html>
48
+ You can see and try out a SolidOS Databrowser Webapp deployment at <https://solid.github.io/mashlib/dist/browse.html>.
49
49
 
50
- `browse.html`serves as a perfect example for: Solid WebID authentication and how to make use of mashlib function and variables.
50
+ `browse.html`serves as a perfect example for Solid WebID authentication and for making use of mashlib functions and variables.
51
51
 
52
52
  ### SolidOS Databrowser Frontend
53
53
 
54
- The `src/databrowser.html`page is compiled into the SolidOS Databrowser Frontend which is displayed for each WebID on [solidcommunity.net](https://solidcommunity.net/). This is the case because the [solidcommunity.net](https://solidcommunity.net/) Solid Server is configured with SolidOS as its frontend.
54
+ The `src/databrowser.html`page is compiled into the SolidOS Databrowser Frontend which is displayed for each WebID on [solidcommunity.net](https://solidcommunity.net/). This is the case because the [solidcommunity.net](https://solidcommunity.net/) Solid Server is configured with SolidOS as its front-end.
55
55
 
56
- More information about the SolidOS Frontend and how to use it visit the [User Guide](https://github.com/solid/userguide).
56
+ More information about the SolidOS Front-end and how to use it visit the [User Guide](https://github.com/solid/userguide).
57
57
 
58
58
  ### SolidOS Data-Kitchen
59
59
 
60
60
  SolidOS Data-Kitchen uses `mashlib.js`as a direct import in its source code. Visit the code at [SolidOS Data-Kitchen GitHub](https://github.com/solid/data-kitchen).
61
61
 
62
- ## Mashlib global variables and funtions
62
+ ## Mashlib global variables and functions
63
63
 
64
- If one wants to use mashlib as a direct import (as a package dependency or script import) one needs to know how they immediate available global variables and functions.
64
+ If one wants to use mashlib as a direct import (as a package dependency or script import), one needs to know which global variables and functions are available.
65
65
 
66
- The availability of these global variables depends on how the sub-modules are imported and exported but also on where the variables are instanciated. For a basic theoretical read please read [this resource](https://www.javatpoint.com/javascript-global-variable).
66
+ The availability of these global variables depends on how the sub-modules are imported and exported and on where the variables are instantiated. For a basic theoretical read, please see [this resource](https://www.javatpoint.com/javascript-global-variable).
67
67
 
68
- What does `global` mean in mashlib? We mean the `global object` which depends on different environments. In mashlib, for now, we use the `window`context which means these variables will not work in non-window contexts such as Node.js environments if directly used. (This does not mean you cannot use mashlib in Node.js environments -> just import it through npm). We will switch this at some point to the [`globalThis`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/globalThis).
68
+ What does `global` mean in mashlib? We mean the `global object` which depends on different environments. In mashlib, for now, we use the `window` context which means these variables will not work if directly used in non-window contexts such as `Node.js` environments. (This does not mean you cannot use mashlib in `Node.js` environments; just import it through `npm`). At some point, we will switch this to the [`globalThis`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/globalThis).
69
69
 
70
- Next we list the most important window context/global variables and which sub-repos are they exported from:
70
+ These are the most important window context/global variables and the sub-repos from which they are exported:
71
71
 
72
- - [**solid-logic**](https://github.com/solid/solid-logic/blob/f606b31382a416ee6188930c3ca05cb4ae73cbda/src/index.ts#L29) exports among others: solidLogicSingleton, authn, authSession, store, chat, profile;
73
- - [**pane-registry**](https://github.com/solid/pane-registry) is exported entirely through the pane-registry variable;
74
- - [**solid-ui**](https://github.com/solid/solid-ui/blob/c5a8888d6cb61363bc0445be007e3c96de593338/src/index.ts#L79) exports among others: authn, store, rdf, dom under the UI variable;
75
- - [**solid-panes**](https://github.com/solid/solid-panes/blob/033f48f8987364cb131455b13e8b0637da95a5ab/src/index.ts#L53) exports getOutliner and the entire solid-ui through the UI variable, and solid-panes itself can be used through the `panes` variable.
72
+ - [**solid-logic**](https://github.com/solid/solid-logic/blob/f606b31382a416ee6188930c3ca05cb4ae73cbda/src/index.ts#L29) exports among others: `solidLogicSingleton`, `authn`, `authSession`, `store`, `chat`, `profile`
73
+ - [**pane-registry**](https://github.com/solid/pane-registry) is exported entirely through the pane-registry variable
74
+ - [**solid-ui**](https://github.com/solid/solid-ui/blob/c5a8888d6cb61363bc0445be007e3c96de593338/src/index.ts#L79) exports among others: authn, store, rdf, dom under the `UI` variable
75
+ - [**solid-panes**](https://github.com/solid/solid-panes/blob/033f48f8987364cb131455b13e8b0637da95a5ab/src/index.ts#L53) exports getOutliner and the entire solid-ui through the `UI` variable, and solid-panes itself can be used through the `panes` variable
76
76
 
77
77
  For backward compatibility reasons, there are now different ways to make use of the same variables from mashlib. For example:
78
78
 
79
- - to make use of the UI (solid-ui) one can use `UI` or `panes.UI`;
80
- - authentication session, part of solid-logic, can be called as `authSession` or `UI.authn.authSession` or `panes.UI.authn.authSession`;
81
- - the store (from solid-logic) can be used as `store` or `UI.store` or `panes.UI.store`;
79
+ - to make use of the UI (solid-ui) one can use `UI` or `panes.UI`
80
+ - authentication session, part of solid-logic, can be called as `authSession` or `UI.authn.authSession` or `panes.UI.authn.authSession`
81
+ - the store (from solid-logic) can be used as `store` or `UI.store` or `panes.UI.store`
82
82
  - rdflib is entirely acessible as `UI.rdf` or `panes.UI.rdf`
83
83
  - the currentUser function is called as `authn.currentUser()` or `UI.auth.currentUser()` or `panes.UI.authn.currentUser()`
84
- - and to make use of the login pop up one needs to call `UI.login.loginStatusBox`function.
84
+ - to make use of the login pop-up, one needs to call the `UI.login.loginStatusBox` function
85
85
 
86
- You can see an example usage in the [SolidOS Databrowser Webapp code](https://github.com/solid/mashlib/blob/main/static/browse.html#L11).
86
+ You can see example usage in the [SolidOS Databrowser Webapp code](https://github.com/solid/mashlib/blob/main/static/browse.html#L11).
87
+
88
+ ## Code changes due to moving authn from solid-ui to solid-logic
89
+
90
+ Some packages have been moved and with them some functions too. Here we report on these changes:
91
+
92
+ ### Solid-ui & Solid-logic related:
93
+
94
+ * There is no more `authn` as you might have known it in solid-ui pre mashlib version 1.7.18 (solid-ui 2.4.16).
95
+ * Some functions in solid-ui which initially were found under `solid-ui/authn` are now under `solid-ui/login`.
96
+ * Two functions were renamed:
97
+ * logInLoadPreferences -> ensureLoadedPreferences
98
+ * logInLoadProfile -> ensureLoadedProfile
99
+ * logIn -> ensureLoggedIn
100
+
101
+ Functions that moved:
102
+
103
+ * `currentUser`, `checkUser`, `saveUser`, `offlineTestID` are now part of `solid-logic/authn/SolidAuthnLogic.ts`-> this is because `authn` itself moved to solid-logic.
104
+ * `setACLUserPublic`, `fetchACLRel` are not part of `solid-logic/src/acl/aclLogic.ts/` and are exported in [index.ts](https://github.com/solid/solid-logic/blob/f606b31382a416ee6188930c3ca05cb4ae73cbda/src/index.ts#L12).
105
+ * `loadIndex`, `loadTypeIndexes`, `ensureTypeIndexes`, `registerInTypeIndex` and are exported in [index.ts](https://github.com/solid/solid-logic/blob/f606b31382a416ee6188930c3ca05cb4ae73cbda/src/index.ts#L16).
87
106
 
88
107
  ## The databrowser hack: upgrading your browser
89
108
 
@@ -99,6 +118,7 @@ How does the data browser work?
99
118
  1. The server supplies the actual data of the to-do list or whatever it was.
100
119
  1. The `mashlib.js` code provides an editable visualization on the data.
101
120
 
102
- The mashlib part of SolidOS Databrowser Frontend is *read-write*. Where the user is allowed to edit: it lets them edit the data and create new things. It is *live* in that often the databrowser signed up (using a websocket) for any changes which other users make, so users' screens are synchronized.
121
+ The mashlib part of SolidOS Databrowser Frontend is *read-write;* that is, the user is allowed to edit data and create new things. It is *live,* in that often the databrowser subscribed (using a websocket) for any changes which other users make, so users' screens are synchronized.
122
+
123
+ A major limitation of this data browser hack is that current web browsers are made to distrust any code loaded from one domain that uses data from another domain. This makes it hard, strangely complicated, and sometimes impossible to do some things.
103
124
 
104
- A major limitation of their data browser hack is that current web browsers are made to distrust any code loaded from one domain that uses data from another domain. This makes it hard, strangely complicated, and sometimes impossible to do some things.
package/dist/browse.html CHANGED
File without changes
@@ -1,3 +1,3 @@
1
1
  <!doctype html><html><head><meta charset="utf-8"/><title>SolidOS Web App</title><script>document.addEventListener('DOMContentLoaded', function() {
2
2
  panes.runDataBrowser()
3
- })</script><link href="/mash.css" rel="stylesheet"></head><body class="db-layout"><header class="db-layout__header header" id="PageHeader"></header><div class="TabulatorOutline db-layout__content" id="DummyUUID" role="main"><table id="outline"></table><div id="GlobalDashboard"></div></div><footer class="db-layout__footer" id="PageFooter"></footer><script src="/mashlib.min.js"></script></body></html>
3
+ })</script><link href="/mash.css" rel="stylesheet"></head><body id="PageBody"><header id="PageHeader"></header><div class="TabulatorOutline" id="DummyUUID" role="main"><table id="outline"></table><div id="GlobalDashboard"></div></div><footer id="PageFooter"></footer><script src="/mashlib.min.js"></script></body></html>