@muze-nl/simplystore 0.1.8 → 0.2.1

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 CHANGED
@@ -91,7 +91,7 @@ Given a dataset like this (jsontag):
91
91
  You can post to the /query/ endpoint with javascript queries like these:
92
92
 
93
93
  ```
94
- data.persons
94
+ from(data.persons)
95
95
  .where({
96
96
  name: 'John'
97
97
  })
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@muze-nl/simplystore",
3
- "version": "0.1.8",
3
+ "version": "0.2.1",
4
4
  "main": "src/server.mjs",
5
5
  "type": "module",
6
6
  "scripts": {
@@ -16,7 +16,7 @@
16
16
  "homepage": "https://github.com/simplyedit/simplystore#readme",
17
17
  "dependencies": {
18
18
  "@muze-nl/jsontag": "^0.8.4",
19
- "array-where-select": "^0.1.1",
19
+ "array-where-select": "^0.2.1",
20
20
  "codemirror": "^6.0.1",
21
21
  "express": "^4.18.1",
22
22
  "json-pointer": "^0.6.2",
package/src/server.mjs CHANGED
@@ -4,7 +4,7 @@ import pointer from 'json-pointer'
4
4
  import JSONTag from '@muze-nl/jsontag'
5
5
  import {JSONPath} from 'jsonpath-plus'
6
6
  import {VM} from 'vm2'
7
- import _ from 'array-where-select'
7
+ import {_,from} from 'array-where-select'
8
8
  import { fileURLToPath } from 'url'
9
9
  import path from 'path'
10
10
 
@@ -194,14 +194,14 @@ async function main(options) {
194
194
  data: result,
195
195
  meta: meta,
196
196
  _: _,
197
+ from: from,
197
198
  console: connectConsole(res),
198
199
  JSONTag: JSONTag,
199
200
  request: {
200
201
  method: req.method,
201
202
  url: req.originalUrl,
202
203
  query: req.query
203
- },
204
- Array: Array
204
+ }
205
205
  },
206
206
  wasm: false
207
207
  })
package/todo.txt ADDED
@@ -0,0 +1,151 @@
1
+ jsontag rest api server UI
2
+
3
+ net als graphql een default query UI versturen op een get requestr met accept text/html
4
+
5
+ dit vormt ook een stuk documentatie
6
+
7
+ dus drie onderdelen:
8
+ - edit scherm voor query
9
+ - resultaten van query
10
+ - help / documentatie / bladeren
11
+
12
+ 1) korte inleiding / beschrijving van de api
13
+ linkt door naar uitgebreidere help en voorbeeld queries
14
+ 2) edit scherm
15
+ 3) resultaten
16
+ 4) referentie / help
17
+
18
+ +--------------------------+
19
+ | Beschrijving van de api |
20
+ +---------------+----------+
21
+ | editor |resultaten|
22
+ | |en help |
23
+ +---------------+----------+
24
+ | errors |console |
25
+ +--------------------------+
26
+
27
+ in localstorage/local filesystem een bibliotheek van code bijhouden, waar je doorheen kunt bladeren en die je kunt importeren/includen
28
+ bij get request worden deze imports opgezocht en ingevoegd.
29
+
30
+ help beschrijft schema's en standaard aanwezige functies en indexen
31
+
32
+ console op de server
33
+
34
+ console.log/warning/error functies maken
35
+ die sturen een console header in de response
36
+ die headers toon je in de console drawer
37
+
38
+ request object in vm2
39
+ JSONTag in vm2
40
+
41
+ simplyStore als basis voor een eigen server gebruiken
42
+
43
+ dus:
44
+ import simplyStore from 'simplyStore'
45
+
46
+ simplyStore.plugin=iets
47
+
48
+ simplyStore.run({
49
+ ...options
50
+ })
51
+
52
+ simplyStore is een express applicatie
53
+ dus die returnen uit de simplyStore library export?
54
+
55
+ nu wordt daar main() aangeroepen,
56
+ wat als je daar server.run van maakt
57
+ en export default server doet?
58
+
59
+ alle configurabele opties moet je dan aan de run() functie mee kunnen geven
60
+
61
+ queries opslaan in localstorage en weer opvragen (en verwijderen)
62
+ meerdere queries in tabs open hebben staan, makkelijk switchen
63
+
64
+ elke succesvolle query in een log opslaan, lokaal
65
+ met ctrl-up/down er doorheen bladeren en weer verder gaan/opnieuw runnen, aanpassingen weer in de log opslaan, maar zonder andere queries uit de log te gooien
66
+ query log clearen op commando
67
+
68
+ syntax controle van de javascript, met highlighten van fouten in de editor
69
+
70
+ -----
71
+
72
+ save query
73
+ load query (undo to show previous contents?)
74
+ show console (single console right side only)
75
+ show errors in console
76
+ manual with code samples
77
+ movies.json movies+actors+directors?
78
+
79
+ jsontag viewer
80
+ - uitklappen van <link>s
81
+ - andere weergaves op basis van <tag>
82
+
83
+ ---
84
+
85
+ import server from 'simplystore'
86
+
87
+ server.get('/pad/', (req,res) => {
88
+
89
+ })
90
+
91
+ server.run({
92
+ dataspace: JSONTag.parse(file),
93
+ port: 3000,
94
+ wwwroot: process.cwd()+'/www'
95
+ })
96
+
97
+ ---
98
+
99
+ simplystore als npm package
100
+ default wwwroot op basis van de filename/pad van de server.mjs
101
+ import { fileURLToPath } from 'url'
102
+ const __dirname = dirname(fileURLToPath(import.meta.url))
103
+
104
+ ----
105
+
106
+ jsontag.parse meta.index bevat lege objecten... fix dat
107
+ test maken
108
+ controleren dat het stuk is
109
+ fixen
110
+ als niet stuk, dan zit het in de simplystore kant?
111
+
112
+ console drawer maken in simplystore ui
113
+
114
+ simplystore main scherm designen voor '/'
115
+
116
+ help scherm ontwerpen voor simplystore
117
+ help vullen
118
+ jsontag
119
+ root, data en array-where-select
120
+ request
121
+ meta
122
+ accept header application/json of application/jsontag
123
+
124
+ ---
125
+
126
+ select({
127
+ $type: _.$type,
128
+ $class: _.$class,
129
+ $$ref: _.$$ref
130
+ })
131
+
132
+ meta.index.id.get('iets').deref()?. -> index(id)?.
133
+
134
+ <object base="url">{
135
+
136
+ }
137
+ <array base="url">[
138
+
139
+ ]
140
+ als root object in alle resultaten
141
+ automatisch door JSONTag.stringify toe laten voegen
142
+
143
+ ---
144
+
145
+ ldk_vakleergebied -> ldkVakleergebied bij tojsontag.mjs
146
+
147
+ graphqlQuery -> storeQuery
148
+
149
+ opendata.*.js -> queries naar store queries
150
+ rest server -> storeQuery gebruiken waar gezet
151
+