issue-pane 2.4.20-9a4e6f86 → 2.4.20-e157e68e

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/Makefile CHANGED
@@ -1,6 +1,8 @@
1
1
  # Wrap TTL files into JS files for bundling with library
2
2
 
3
- ,all : wf.js trackerSettingsForm.js trackerInstancesForm.js ui.js
3
+ # unused: trackerInstancesForm.js
4
+
5
+ ,all : wf.js trackerSettingsForm.js ui.js
4
6
 
5
7
  #individualForm.js : individualForm.ttl
6
8
  # (echo 'module.exports = `' ; cat individualForm.ttl; echo '`') > individualForm.js
package/csvButton.js ADDED
@@ -0,0 +1,98 @@
1
+ // A Button to copy the state of the tracker in CSV format
2
+ // Comma-separated Values
3
+ //
4
+ // Yes this mixes the layers but that is not all bad if it gets it in one file
5
+ // one can look at
6
+
7
+ import { icons, ns, utils, widgets } from 'solid-ui'
8
+ import { store } from 'solid-logic'
9
+
10
+ export function csvText(store, tracker) {
11
+ function encode(value) {
12
+ // https://www.rfc-editor.org/rfc/rfc4180
13
+ const stripped = value.replace('\n', ' ')
14
+ if (!stripped.contains(',')) {
15
+ return stripped
16
+ } // If contains comma then put in quotes and double up internal quotes
17
+ return '"' + stripped.replace('"', '""') + '"'
18
+ }
19
+
20
+ function columnText(task, column) {
21
+ let thing
22
+ if (column.predicate) {
23
+ thing = store.any(task, column.predicate)
24
+ }
25
+ else if (column.category) {
26
+ const types = store.each(task, ns.rdf('type'))
27
+ for (const t of types) {
28
+ if (store.holds(t, ns.rdfs('subClassOf'), column.category)){
29
+ thing = t
30
+ }
31
+ }
32
+ if (!thing) throw new Error('wot no category', column.category)
33
+ } else {
34
+ throw new Error('wot no pred or cat', column)
35
+ }
36
+ return utils.label(thing)
37
+ }
38
+
39
+ function taskLine(task) {
40
+ return columns.map(column => columnText(task, column))
41
+ .map(encode)
42
+ .join(',')
43
+ + '/n'
44
+ }
45
+ const stateStore = store.any(tracker, ns.wf('stateStore'))
46
+ const tasks = store.any(null, ns.wf('tracker'), tracker, stateStore)
47
+
48
+ let columns = [
49
+ /* like:
50
+ { label: 'Name', predicate: ns.dct('title') },
51
+ { label: 'State', category: ns.wf('Task') }
52
+ */
53
+ ]
54
+ const states = store.any(tracker, ns.wf('issueClass')) // Main states are subclasses of this class
55
+ const categories = store.each(tracker, ns.wf('issueCategory')) | []
56
+ const classifications = [states ] + categories
57
+ for (const c in classifications){
58
+ const column = { label: utils.label(c), category: c}
59
+ console.log(' CSV: found column from classifications', column)
60
+ columns.append(column) // Classes are different
61
+ }
62
+
63
+ // const propertyList = ns.wf('propertyList')
64
+ const form = store.any(tracker, ns.wf('extrasEntryForm'), null, tracker.doc())
65
+ if (form) {
66
+ const parts = store.any(form, ns.ui('parts'), null, form.doc())
67
+ const fields = parts.elements
68
+ for (const field of fields) {
69
+ const prop = store.any(field,ns.ui('property'))
70
+ const lab = utils.label(prop)
71
+ const column = {label: lab, predicate: prop}
72
+ console.log(' CSV: found column from form', column)
73
+ columns.append(column)
74
+ }
75
+ }
76
+ const header = columns.map(col => col.label).join(',') + '\n'
77
+ // Order tasks?? By Creation date? By Status?
78
+ const body = tasks.map(taskLine)
79
+ return header + body
80
+ }
81
+
82
+ export function csvButton (dom, tracker) {
83
+ const wrapper = dom.createElement('div')
84
+ // Add a button
85
+ const button = widgets.button(dom, icons.iconBase + 'noun_479395.svg',
86
+ 'Copy as CSV', async _event => {
87
+ const csv = csvText(store, tracker)
88
+ var copyEvent = new ClipboardEvent('copy');
89
+ copyEvent.clipboardData.items.add(csv, 'text/csv');
90
+ copyEvent.clipboardData.items.add(csv, 'text/plain');
91
+ dom.dispatchEvent(copyEvent);
92
+ alert('Copy dispatched.')
93
+ })
94
+
95
+ wrapper.appendChild(button)
96
+ return wrapper
97
+ }
98
+
package/issuePane.js CHANGED
@@ -1,4 +1,4 @@
1
- /* Issue Tracker Pane
1
+ /* Issue Tracker Pane
2
2
  **
3
3
  ** This solid view allows a user to interact with an issue tracker, or individual issue,
4
4
  ** to change its state according to an ontology, comment on it, etc.
@@ -11,6 +11,7 @@ import { board } from './board' // @@ will later be in solid-UI
11
11
  import { renderIssue, renderIssueCard, getState, exposeOverlay } from './issue'
12
12
  import { newTrackerButton } from './newTracker'
13
13
  import { newIssueForm } from './newIssue'
14
+ import { csvButton } from './csvButton'
14
15
  import { trackerSettingsFormText } from './trackerSettingsForm.js'
15
16
  // import { trackerInstancesFormText } from './trackerInstancesForm.js'
16
17
 
@@ -355,6 +356,7 @@ export default {
355
356
  }
356
357
  function renderSettings (tracker) {
357
358
  const settingsDiv = dom.createElement('div')
359
+ settingsDiv.appendChild(csvButton(dom, tracker)) // Button to copy the tracker as a CSV file
358
360
  const states = kb.any(tracker, ns.wf('issueClass'))
359
361
  const views = [tableView, states] // Possible default views
360
362
  .concat(kb.each(tracker, ns.wf('issueCategory')))
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "issue-pane",
3
- "version": "2.4.20-9a4e6f86",
3
+ "version": "2.4.20-e157e68e",
4
4
  "description": "Solid-compatible Panes: issue editor",
5
5
  "main": "./issuePane.js",
6
6
  "scripts": {
@@ -0,0 +1,238 @@
1
+ #Processed by Id
2
+ # using base file:///Users/timbl_1/src/github.com/solidos/solidos/workspaces/issue-pane/test/big-tracker-config.ttl
3
+ @prefix : <tracker.n3#> .
4
+ @prefix ca: <https://olarkin.inrupt.net/profile/card#> .
5
+ @prefix con: <http://www.w3.org/2000/10/swap/pim/contact#> .
6
+ @prefix doap: <http://usefulinc.com/ns/doap#> .
7
+ @prefix flow: <http://www.w3.org/2005/01/wf/flow#> .
8
+ @prefix ical: <http://www.w3.org/2002/12/cal/ical#> .
9
+ @prefix owl: <http://www.w3.org/2002/07/owl#> .
10
+ @prefix ui: <http://www.w3.org/ns/ui#> .
11
+
12
+ :Accepted a <http://www.w3.org/2000/01/rdf-schema#Class>;
13
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Will go ahead. We are working on this";
14
+ <http://www.w3.org/2000/01/rdf-schema#label> "Accepted, in progress";
15
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
16
+ :MotherIssue;
17
+ ui:sortOrder 50 .
18
+
19
+ :Action a <http://www.w3.org/2000/01/rdf-schema#Class>;
20
+ <http://www.w3.org/2000/01/rdf-schema#label> "action";
21
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
22
+ ui:backgroundColor "#eeeeff";
23
+ ui:sortOrder 80 .
24
+
25
+ :AttendConference a <http://www.w3.org/2000/01/rdf-schema#Class>;
26
+ <http://www.w3.org/2000/01/rdf-schema#label> "attend conference";
27
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
28
+ ui:backgroundColor "#fcfce8";
29
+ ui:sortOrder 50 .
30
+
31
+ :Book a <http://www.w3.org/2000/01/rdf-schema#Class>;
32
+ <http://www.w3.org/2000/01/rdf-schema#label> "book";
33
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
34
+ ui:backgroundColor "#eeffee";
35
+ ui:sortOrder 70 .
36
+
37
+ :CommercialSpeaking a <http://www.w3.org/2000/01/rdf-schema#Class>;
38
+ <http://www.w3.org/2000/01/rdf-schema#label> "commercial speaking";
39
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
40
+ ui:backgroundColor "#ffcbad";
41
+ ui:sortOrder 30 .
42
+
43
+ :Declined a <http://www.w3.org/2000/01/rdf-schema#Class>;
44
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Declined";
45
+ <http://www.w3.org/2000/01/rdf-schema#label> "declined";
46
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Closed,
47
+ :MotherIssue;
48
+ ui:sortOrder 30 .
49
+
50
+ :Discussing a <http://www.w3.org/2000/01/rdf-schema#Class>;
51
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Being discussed";
52
+ <http://www.w3.org/2000/01/rdf-schema#label> "in discussion";
53
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
54
+ :MotherIssue;
55
+ ui:sortOrder 80 .
56
+
57
+ :Done a <http://www.w3.org/2000/01/rdf-schema#Class>;
58
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Completed.";
59
+ <http://www.w3.org/2000/01/rdf-schema#label> "done";
60
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Closed,
61
+ :MotherIssue;
62
+ ui:sortOrder 20 .
63
+
64
+ :Film a <http://www.w3.org/2000/01/rdf-schema#Class>;
65
+ <http://www.w3.org/2000/01/rdf-schema#label> "film";
66
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
67
+ ui:backgroundColor "#eeffff";
68
+ ui:sortOrder 80 .
69
+
70
+ :HonoraryDegree a <http://www.w3.org/2000/01/rdf-schema#Class>;
71
+ <http://www.w3.org/2000/01/rdf-schema#label> "honorary degree";
72
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
73
+ ui:backgroundColor "#ffa8ab";
74
+ ui:sortOrder 40 .
75
+
76
+ :Meeting a <http://www.w3.org/2000/01/rdf-schema#Class>;
77
+ <http://www.w3.org/2000/01/rdf-schema#label> "meeting request";
78
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
79
+ ui:backgroundColor "#e8e8ff";
80
+ ui:sortOrder 60 .
81
+
82
+ :MotherIssue a <http://www.w3.org/2000/01/rdf-schema#Class>;
83
+ <http://www.w3.org/2000/01/rdf-schema#label> "Request";
84
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Task;
85
+ owl:disjointUnionOf (
86
+ :New
87
+ :Discussing
88
+ :Pending
89
+ :Negotiating
90
+ :Accepted
91
+ :Urgent
92
+ :ToBeDeclined
93
+ :Watchlist
94
+ :Declined
95
+ :Obsolete
96
+ :Done ) .
97
+
98
+ :Negotiating a <http://www.w3.org/2000/01/rdf-schema#Class>;
99
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Being negotiated";
100
+ <http://www.w3.org/2000/01/rdf-schema#label> "negotiating";
101
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
102
+ :MotherIssue;
103
+ ui:sortOrder 60 .
104
+
105
+ :New a <http://www.w3.org/2000/01/rdf-schema#Class>;
106
+ <http://www.w3.org/2000/01/rdf-schema#comment> """Has not been looked at.
107
+ This is the initial state normally when an issue is created.""";
108
+ <http://www.w3.org/2000/01/rdf-schema#label> "new";
109
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
110
+ :MotherIssue;
111
+ ui:sortOrder 90 .
112
+
113
+ :NonProfitSpeaking a <http://www.w3.org/2000/01/rdf-schema#Class>;
114
+ <http://www.w3.org/2000/01/rdf-schema#label> "non-profit speaking";
115
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
116
+ ui:backgroundColor "#fffed0";
117
+ ui:sortOrder 20 .
118
+
119
+ :Obsolete a <http://www.w3.org/2000/01/rdf-schema#Class>;
120
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Overtaken by time or events.";
121
+ <http://www.w3.org/2000/01/rdf-schema#label> "obsolete/missed";
122
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Closed,
123
+ :MotherIssue;
124
+ ui:sortOrder 10 .
125
+
126
+
127
+ :OtherRequest a <http://www.w3.org/2000/01/rdf-schema#Class>;
128
+ <http://www.w3.org/2000/01/rdf-schema#label> "other";
129
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
130
+ ui:backgroundColor "#eeeeee";
131
+ ui:sortOrder 90 .
132
+
133
+ :Pending a <http://www.w3.org/2000/01/rdf-schema#Class>;
134
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Waiting for someone else's input.";
135
+ <http://www.w3.org/2000/01/rdf-schema#label> "pending others";
136
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
137
+ :MotherIssue;
138
+ ui:sortOrder 75 .
139
+
140
+ :PressRequest a <http://www.w3.org/2000/01/rdf-schema#Class>;
141
+ <http://www.w3.org/2000/01/rdf-schema#label> "press";
142
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> :RequestCategory;
143
+ ui:backgroundColor "#dccdfc";
144
+ ui:sortOrder 10 .
145
+
146
+ :RequestCategory <http://www.w3.org/2000/01/rdf-schema#label> "category";
147
+ owl:disjointUnionOf (
148
+ :PressRequest
149
+ :NonProfitSpeaking
150
+ :CommercialSpeaking
151
+ :HonoraryDegree
152
+ :AttendConference
153
+ :Meeting
154
+ :Book
155
+ :Film
156
+ :Action
157
+ :OtherRequest ) .
158
+
159
+ :RequestExtrasForm a ui:Form,
160
+ ui:Group;
161
+ <http://purl.org/dc/elements/1.1/title> "Extra details of a request";
162
+ ui:parts (
163
+ [
164
+ a ui:Heading;
165
+ ui:contents "Details:"@en;
166
+ ui:sequence 10 ]
167
+ [
168
+ a ui:DateField;
169
+ ui:property flow:earliestDate;
170
+ ui:sequence 20 ]
171
+ [
172
+ a ui:DateField;
173
+ ui:property flow:latestDate;
174
+ ui:sequence 40 ]
175
+ [
176
+ a ui:Comment;
177
+ ui:contents "The earliest and latest dates are the window for the event, or both the same if fixed."@en;
178
+ ui:sequence 60;
179
+ ui:style "background-color: #ffe;" ]
180
+ [
181
+ a ui:SingleLineTextField;
182
+ ui:property ical:location;
183
+ ui:seuqence 70;
184
+ ui:size 30 ]
185
+ [
186
+ a ui:DateField;
187
+ ui:property flow:dateReceived;
188
+ ui:sequence 80 ]
189
+ [
190
+ a ui:MultiLineTextField;
191
+ ui:property <http://www.w3.org/2000/01/rdf-schema#comment>;
192
+ ui:sequence 90 ] ) .
193
+
194
+
195
+ :ToBeDeclined a <http://www.w3.org/2000/01/rdf-schema#Class>;
196
+ <http://www.w3.org/2000/01/rdf-schema#comment> "To be declined";
197
+ <http://www.w3.org/2000/01/rdf-schema#label> "to be declined";
198
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
199
+ :MotherIssue;
200
+ ui:sortOrder 40 .
201
+
202
+ :Urgent a <http://www.w3.org/2000/01/rdf-schema#Class>;
203
+ <http://www.w3.org/2000/01/rdf-schema#comment> "Needs urgent attention";
204
+ <http://www.w3.org/2000/01/rdf-schema#label> "URGENT";
205
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
206
+ :MotherIssue;
207
+ ui:sortOrder 55 .
208
+
209
+ :Watchlist a <http://www.w3.org/2000/01/rdf-schema#Class>;
210
+ <http://www.w3.org/2000/01/rdf-schema#comment> "We will keep this in mind.";
211
+ <http://www.w3.org/2000/01/rdf-schema#label> "watch list";
212
+ <http://www.w3.org/2000/01/rdf-schema#subClassOf> flow:Open,
213
+ :MotherIssue;
214
+ ui:sortOrder 35 .
215
+
216
+ :this a flow:Tracker;
217
+ <http://purl.org/dc/terms/title> "The Big Request Tracker";
218
+ <http://www.w3.org/2000/01/rdf-schema#label> "Request Tracker";
219
+ flow:allowSubIssues :false;
220
+ flow:assigneeClass <http://xmlns.com/foaf/0.1/Person>;
221
+ flow:defaultView flow:TableView;
222
+ flow:description "Requests";
223
+ flow:extrasEntryForm :RequestExtrasForm;
224
+ flow:initialState :New;
225
+ flow:issueCategory :RequestCategory;
226
+ flow:issueClass :MotherIssue;
227
+ flow:propertyList (
228
+ flow:earliestDate
229
+ flow:latestDate
230
+ ical:location
231
+ <http://www.w3.org/2000/01/rdf-schema#comment>
232
+ flow:assignee );
233
+ flow:stateStore <state.n3> .
234
+
235
+ <tracker.n3> <http://www.w3.org/2000/01/rdf-schema#comment> """This file defines a tracker for requests.
236
+ """;
237
+ <http://www.w3.org/2000/01/rdf-schema#label> "A tracker definition file for requests" .
238
+
@@ -0,0 +1,78 @@
1
+ @prefix : <#>.
2
+ @prefix dc: <http://purl.org/dc/elements/1.1/>.
3
+ @prefix dct: <http://purl.org/dc/terms/>.
4
+ @prefix foaf: <http://xmlns.com/foaf/0.1/>.
5
+ @prefix owl: <http://www.w3.org/2002/07/owl#>.
6
+ @prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
7
+ @prefix ui: <http://www.w3.org/ns/ui#>.
8
+ @prefix wf: <http://www.w3.org/2005/01/wf/flow#>.
9
+ @prefix xsd: <http://www.w3.org/2001/XMLSchema#>.
10
+ @prefix c: </profile/card#>.
11
+
12
+ :Classification
13
+ rdfs:label "Category";
14
+ owl:disjointUnionOf
15
+ ( :Specification :Tests :Servers :Clients :DeveloperTools :Vertical ).
16
+ :Clients
17
+ rdfs:comment "Client side frameworks, SDKs and operating systems";
18
+ rdfs:label "Clients";
19
+ rdfs:subClassOf :Classification.
20
+ :DeveloperTools rdfs:label "Developer tools"; rdfs:subClassOf :Classification.
21
+
22
+ :InProgress
23
+ rdfs:label "In progress";
24
+ rdfs:subClassOf wf:Open, :States;
25
+ ui:backgroundColor "#f9ee71"^^xsd:color.
26
+ :NextSession
27
+ rdfs:label "To be done this month";
28
+ rdfs:subClassOf wf:Open, :States;
29
+ ui:backgroundColor "#91fdb9"^^xsd:color.
30
+ :Released
31
+ rdfs:label "Released";
32
+ rdfs:subClassOf wf:Open, :States;
33
+ ui:backgroundColor "#e2a7fb"^^xsd:color.
34
+ :Research
35
+ rdfs:label "Research";
36
+ rdfs:subClassOf wf:Open, :States;
37
+ ui:backgroundColor "#ffffff"^^xsd:color.
38
+ :Servers
39
+ rdfs:label "Solid Server implementations"; rdfs:subClassOf :Classification.
40
+ :Someday
41
+ rdfs:label "Someday pile";
42
+ rdfs:subClassOf wf:Open, :States;
43
+ ui:backgroundColor "#e3e3e3"^^xsd:color.
44
+ :Specification
45
+ rdfs:label "Parts of the Solid specification"; rdfs:subClassOf :Classification.
46
+ :States
47
+ rdfs:label "Task";
48
+ owl:disjointUnionOf
49
+ ( :Research :Someday :ToBeDone :NextSession :InProgress :Works :Released ).
50
+ :Tests rdfs:label "Test suites"; rdfs:subClassOf :Classification.
51
+
52
+ :this
53
+ a wf:Tracker;
54
+ dc:author c:me;
55
+ dc:created "2020-07-21T14:00:20Z"^^xsd:dateTime;
56
+ dct:title "Solid Ecosystem: Roadmap";
57
+ wf:assigneeClass foaf:Person;
58
+ wf:defaultView :Classification;
59
+ wf:description
60
+ """A roadmap for the whole Solid ecosystem.
61
+ See also other linked roadmaps for parts of the ecosystem like the SolidOS, Spec, open source projects, etc.
62
+
63
+
64
+ """;
65
+ wf:initialState :Someday;
66
+ wf:issueCategory :Classification;
67
+ wf:issueClass :States;
68
+ wf:stateStore <state.ttl>.
69
+ :ToBeDone
70
+ rdfs:label "To Be Done";
71
+ rdfs:subClassOf wf:Open, :States;
72
+ ui:backgroundColor "#e0ffeb"^^xsd:color.
73
+ :Vertical rdfs:label "Apps and Verticals"; rdfs:subClassOf :Classification.
74
+
75
+ :Works
76
+ rdfs:label "Code runs";
77
+ rdfs:subClassOf wf:Open, :States;
78
+ ui:backgroundColor "#dcdbff"^^xsd:color.