UNPKG

60.8 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3require("source-map-support/register");
4// TODO should I get rid of the lib above for production browser build?
5var lodash_1 = require("lodash");
6var fp_1 = require("lodash/fp");
7var hl = require("highland");
8var VError = require("verror");
9var cxml_xpath_1 = require("../spinoffs/cxml-xpath");
10var GPML2013a = require("../../xmlns/pathvisio.org/GPML/2013a");
11var GPMLDefaults = require("../GPMLDefaults");
12var Processor_1 = require("../Processor");
13var edge_1 = require("../edge/edge");
14var group_1 = require("../group");
15var gpml_utilities_1 = require("../gpml-utilities");
16var VOCABULARY_NAME_TO_IRI = require("../spinoffs/VOCABULARY_NAME_TO_IRI.json");
17var GPML2013aKeyMappings = require("./KeyMappings.json");
18var GPML2013aKeyValueMappings = require("./KeyValueConverters");
19var GPML2013aValueMappings = require("./ValueMappings.json");
20var GPML2013aValueConverters = require("./ValueConverters");
21// TODO get text alignment correctly mapped to Box Model CSS terms
22var iassign = require("immutable-assign");
23iassign.setOption({
24 // Deep freeze both input and output. Used in development to make sure they don't change.
25 // TODO watch issue and re-enable when addressed: https://github.com/engineforce/ImassignM/issues/11
26 //freeze: true,
27 ignoreIfNoChange: true
28});
29exports.RECURSION_LIMIT = 1000;
30function partitionStream(s, partitioner) {
31 var yes = s.fork().filter(function (x) { return partitioner(x); });
32 var no = s.fork().filter(function (x) { return !partitioner(x); });
33 return [yes, no];
34}
35function extendDeep(targetOrTargetArray, source) {
36 var target = fp_1.isArray(targetOrTargetArray)
37 ? targetOrTargetArray[0]
38 : targetOrTargetArray;
39 // TODO: We run into problems if we try to extend both
40 // GraphicalLine and Interaction, because they share
41 // EdgeGraphicsType. To avoid an infinite recursion of
42 // extending, I'm using a short-term solution of just
43 // marking whether a target has been extended, and
44 // if so, skipping it.
45 // Look into a better way of handling this.
46 if (!target.hasOwnProperty("_extended")) {
47 fp_1.toPairsIn(target)
48 .filter(function (_a) {
49 var targetKey = _a[0], targetValue = _a[1];
50 return source.hasOwnProperty(targetKey) && fp_1.isObject(source[targetKey]);
51 })
52 .forEach(function (_a) {
53 var targetKey = _a[0], targetValue = _a[1];
54 extendDeep(targetValue, source[targetKey]);
55 });
56 lodash_1.assign(target.constructor.prototype, source);
57 target._extended = true;
58 }
59}
60var stringifyKeyValue = fp_1.curry(function (source, key) {
61 return source.hasOwnProperty(key)
62 ? fp_1.startCase(key) + ": " + source[key]
63 : null;
64});
65extendDeep(GPML2013a.document.Pathway.constructor.prototype, GPMLDefaults.Pathway);
66extendDeep(GPML2013a.DataNodeType.prototype, GPMLDefaults.DataNode);
67extendDeep(GPML2013a.GraphicalLineType.prototype, GPMLDefaults.GraphicalLine);
68extendDeep(GPML2013a.GroupType.prototype, GPMLDefaults.Group);
69extendDeep(GPML2013a.InteractionType.prototype, GPMLDefaults.Interaction);
70extendDeep(GPML2013a.LabelType.prototype, GPMLDefaults.Label);
71extendDeep(GPML2013a.ShapeType.prototype, GPMLDefaults.Shape);
72extendDeep(GPML2013a.StateType.prototype, GPMLDefaults.State);
73extendDeep(GPML2013a.EdgeGraphicsType.prototype.Anchor, GPMLDefaults.Anchor);
74// TODO specify types
75function toPvjson(inputStreamWithMessedUpRDFIDs, pathwayIri) {
76 // NOTE: GPML2013a incorrectly uses "rdf:id" instead of "rdf:ID".
77 // We need to fix this error so that CXML can process the GPML.
78 var inputStream = hl(inputStreamWithMessedUpRDFIDs)
79 .splitBy(' rdf:id="')
80 .intersperse(' rdf:ID="');
81 var selectorToCXML = {
82 // TODO why does TS require that we use the Pathway's "constructor.prototype"
83 // instead of just the Pathway?
84 // Why does Pathway.Graphics not need that?
85 // Why do many of the other require using the prototype?
86 //
87 "/Pathway/@*": GPML2013a.document.Pathway.constructor.prototype,
88 "/Pathway/Comment": GPML2013a.document.Pathway.Comment[0],
89 "/Pathway/Graphics/@*": GPML2013a.document.Pathway.Graphics,
90 "/Pathway/DataNode": GPML2013a.DataNodeType.prototype,
91 "/Pathway/State": GPML2013a.StateType.prototype,
92 "/Pathway/Interaction": GPML2013a.InteractionType.prototype,
93 "/Pathway/GraphicalLine": GPML2013a.GraphicalLineType.prototype,
94 "/Pathway/Label": GPML2013a.LabelType.prototype,
95 "/Pathway/Shape": GPML2013a.ShapeType.prototype,
96 "/Pathway/Group": GPML2013a.GroupType.prototype,
97 "/Pathway/InfoBox": GPML2013a.InfoBoxType.prototype,
98 "/Pathway/Legend": GPML2013a.LegendType.prototype,
99 "/Pathway/Biopax/bp:PublicationXref": GPML2013a.document.Pathway.Biopax.PublicationXref[0],
100 "/Pathway/Biopax/bp:openControlledVocabulary": GPML2013a.document.Pathway.Biopax.openControlledVocabulary[0]
101 };
102 var cxmlXPath = new cxml_xpath_1.CXMLXPath(inputStream, GPML2013a, {
103 bp: "http://www.biopax.org/release/biopax-level3.owl#"
104 //rdf: "http://www.w3.org/1999/02/22-rdf-syntax-ns#"
105 });
106 var cxmlSources = cxmlXPath.parse(selectorToCXML);
107 var processor = new Processor_1.Processor(GPML2013aKeyMappings, GPML2013aKeyValueMappings, GPML2013aValueMappings, GPML2013aValueConverters);
108 var fillInGPMLPropertiesFromParent = processor.fillInGPMLPropertiesFromParent, getPvjsonEntityLatestByGraphId = processor.getPvjsonEntityLatestByGraphId, graphIdsByGraphRef = processor.graphIdsByGraphRef, graphIdToZIndex = processor.graphIdToZIndex, getGPMLElementByGraphId = processor.getGPMLElementByGraphId, preprocessGPMLElement = processor.preprocessGPMLElement, processGPMLAndPropertiesAndType = processor.processGPMLAndPropertiesAndType, processProperties = processor.processProperties, processPropertiesAndType = processor.processPropertiesAndType, setPvjsonEntity = processor.setPvjsonEntity;
109 if (pathwayIri) {
110 processor.output = iassign(processor.output, function (o) {
111 return o.pathway;
112 }, function (pathway) {
113 pathway.id = pathwayIri;
114 return pathway;
115 });
116 }
117 var sortByZIndex = gpml_utilities_1.sortByMap(graphIdToZIndex);
118 var pathwayMetadataStream = hl([
119 cxmlSources["/Pathway/@*"].doto(function (pathway) {
120 if (gpml_utilities_1.supportedNamespaces.indexOf(pathway._namespace) === -1) {
121 // TODO should we do anything further?
122 throw new Error("Unsupported namespace: " + pathway._namespace);
123 }
124 }),
125 cxmlSources["/Pathway/Graphics/@*"]
126 ])
127 .merge()
128 .map(processProperties)
129 .reduce({}, function (acc, metadataChunk) {
130 return fp_1.assign(acc, metadataChunk);
131 })
132 .map(function (metadata) {
133 processor.output = iassign(processor.output, function (o) {
134 return o.pathway;
135 }, function (pathway) {
136 var mergedPathway = fp_1.assign(pathway, metadata);
137 // NOTE: GPML schema specifies that name is required
138 var name = mergedPathway.name;
139 var splitName = name.split(" (");
140 if (!!splitName &&
141 splitName.length === 2 &&
142 !!name.match(/\(/g) &&
143 name.match(/\(/g).length === 1 &&
144 !!name.match(/\)/g) &&
145 name.match(/\)/g).length === 1) {
146 mergedPathway.standardName = splitName[0];
147 mergedPathway.displayName = splitName[1].replace(")", "");
148 }
149 else {
150 mergedPathway.standardName = name;
151 mergedPathway.displayName = name;
152 }
153 var stringifyKeyValueForPathway = stringifyKeyValue(mergedPathway);
154 mergedPathway.textContent = fp_1.compact([
155 stringifyKeyValueForPathway("name"),
156 stringifyKeyValueForPathway("license"),
157 stringifyKeyValueForPathway("lastModified"),
158 stringifyKeyValueForPathway("organism")
159 ]).join("\n");
160 var context = [
161 "https://cdn.rawgit.com/wikipathways/WpVocabularies/7a46a05/contexts/pvjs.jsonld"
162 ];
163 if (!!mergedPathway.id) {
164 context.push({
165 "@base": mergedPathway.id + "/"
166 });
167 }
168 else {
169 // If there's no pathway IRI specified, we at least give the user a URL
170 // to search WikiPathways. This way, the user at least has a chance of
171 // to search WikiPathways to possibly find the source for this data.
172 // NOTE: GPML schema specifies that organism is optional
173 var organismIriComponent = mergedPathway.hasOwnProperty("organism")
174 ? "&species=" + mergedPathway.organism
175 : "";
176 mergedPathway.isSimilarTo = encodeURI("http://wikipathways.org/index.php/Special:SearchPathways?query=" + name + organismIriComponent + "&doSearch=1");
177 }
178 return fp_1.assign({
179 "@context": context
180 }, mergedPathway);
181 });
182 return processor.output;
183 })
184 .errors(function (err) {
185 throw new VError(err, " when processing pathwayMetadataStream\n\t\t\t\t");
186 });
187 var pathwayCommentStream = hl(cxmlSources["/Pathway/Comment"]).map(function (Comment) {
188 processor.output = iassign(processor.output, function (o) {
189 return o.pathway;
190 }, function (pathway) {
191 var comments = pathway.comments || [];
192 comments.push(processProperties(Comment));
193 pathway.comments = comments;
194 return pathway;
195 });
196 return processor.output;
197 });
198 var dataNodeStream = cxmlSources["/Pathway/DataNode"]
199 .map(processGPMLAndPropertiesAndType("DataNode"))
200 .map(function (entity) {
201 // TODO fix type def for unionLSV so I don't have to use "as"
202 entity.type = gpml_utilities_1.unionLSV(entity.type, entity.wpType);
203 return entity;
204 });
205 var stateStream = cxmlSources["/Pathway/State"]
206 .map(preprocessGPMLElement)
207 .flatMap(function (gpmlState) {
208 return hl(getGPMLElementByGraphId(gpmlState.GraphRef)).map(function (gpmlDataNode) {
209 return fillInGPMLPropertiesFromParent(gpmlDataNode, gpmlState);
210 });
211 })
212 .map(processPropertiesAndType("State"));
213 var shapeStream = cxmlSources["/Pathway/Shape"]
214 .map(processGPMLAndPropertiesAndType("Shape"))
215 .map(function (pvjsonEntity) {
216 var cellularComponent = pvjsonEntity.cellularComponent;
217 // CellularComponent is not a BioPAX term, but "PhysicalEntity" is.
218 if (!!cellularComponent) {
219 pvjsonEntity.type = gpml_utilities_1.unionLSV(pvjsonEntity.type, "PhysicalEntity", "CellularComponent", cellularComponent);
220 }
221 return pvjsonEntity;
222 });
223 var labelStream = cxmlSources["/Pathway/Label"].map(processGPMLAndPropertiesAndType("Label"));
224 var gpmlInteractionStream = cxmlSources["/Pathway/Interaction"].map(preprocessGPMLElement);
225 var gpmlGraphicalLineStream = cxmlSources["/Pathway/GraphicalLine"].map(preprocessGPMLElement);
226 var edgeStream = hl([
227 gpmlInteractionStream
228 .fork()
229 .map(edge_1.preprocessGPML)
230 .map(processPropertiesAndType("Interaction")),
231 gpmlGraphicalLineStream
232 .fork()
233 .map(edge_1.preprocessGPML)
234 .map(processPropertiesAndType("GraphicalLine"))
235 ]).merge();
236 var anchorStream = hl([
237 gpmlInteractionStream.fork(),
238 gpmlGraphicalLineStream.fork()
239 ])
240 .merge()
241 .filter(function (gpmlEdge) {
242 return (gpml_utilities_1.isDefinedCXML(gpmlEdge.Graphics) &&
243 gpml_utilities_1.isDefinedCXML(gpmlEdge.Graphics.Anchor));
244 })
245 .flatMap(function (gpmlEdge) {
246 var GraphId = gpmlEdge.GraphId, Graphics = gpmlEdge.Graphics;
247 var fillInGPMLPropertiesFromEdge = fillInGPMLPropertiesFromParent(gpmlEdge);
248 var gpmlAnchors = Graphics.Anchor;
249 return hl(gpmlAnchors)
250 .map(function (gpmlAnchor) {
251 var anchorShape = gpmlAnchor.Shape;
252 if (anchorShape === "None") {
253 // NOTE: For Anchors with Shape="None", PathVisio-Java displays
254 // the anchor as a 4x4 square when nothing is connected,
255 // but does not display it when something is connected.
256 // TODO: right now, PathVisio-Java writes out GPML such that the
257 // Anchor only has a GraphId when an Edge connects to this Anchor,
258 // but we may not be able to rely on this in the future.
259 if (gpml_utilities_1.isDefinedCXML(gpmlAnchor.GraphId)) {
260 lodash_1.assign(gpmlAnchor.Graphics, {
261 Height: 0,
262 Width: 0
263 });
264 }
265 else {
266 gpmlAnchor.Shape = "Rectangle";
267 lodash_1.assign(gpmlAnchor.Graphics, {
268 Height: 4,
269 Width: 4
270 });
271 }
272 }
273 else if (anchorShape === "Circle") {
274 lodash_1.assign(gpmlAnchor.Graphics, {
275 Height: 8,
276 Width: 8
277 });
278 }
279 else {
280 throw new Error("Anchor Shape \"" + anchorShape + "\" is not supported.");
281 }
282 return gpmlAnchor;
283 })
284 .map(preprocessGPMLElement)
285 .map(function (gpmlAnchor) {
286 var filledInAnchor = fillInGPMLPropertiesFromEdge(gpmlAnchor);
287 filledInAnchor.GraphRef = GraphId;
288 return filledInAnchor;
289 })
290 .map(processPropertiesAndType("Anchor"));
291 });
292 var groupStream = cxmlSources["/Pathway/Group"]
293 .map(group_1.preprocessGPML(processor))
294 .filter(function (Group) { return !!Group.Contains; })
295 .map(processGPMLAndPropertiesAndType("Group"));
296 var EDGES = ["Interaction", "GraphicalLine"];
297 var NODES = ["DataNode", "Shape", "Label", "State", "Group"];
298 function postprocessAll(s) {
299 /*
300 // We are sorting the elements by the order in which we must do their
301 // post-processing, e.g., if one edge is attached to another edge via
302 // an anchor, we must post-process the edge with the anchor before we
303 // post-process the other edge.
304 const isProcessableTests = [
305 curry(function(sortedIds: string[], pvjsonEntity: PvjsonEntity) {
306 // In this test, we ensure the entity
307 // 1) is not a group AND
308 // 2) is not attached to a group and not to an edge
309 // (ie., it is not attached to anything, or
310 // it is attached to something, but that something is neither a group nor an edge)
311
312 return (
313 pvjsonEntity.gpmlElementName !== "Group" &&
314 unionLSV(
315 pvjsonEntity["isAttachedToOrVia"],
316 pvjsonEntity["isAttachedTo"]
317 )
318 .map(
319 (isAttachedToOrViaId: string) =>
320 processor.output.entitiesById[isAttachedToOrViaId].gpmlElementName
321 )
322 .filter(
323 // Entity is attached to neither a group nor an edge.
324 // (Testing that entity is not attached to an edge at all,
325 // whether directly or indirectly via an anchor.)
326 isAttachedToOrViaGpmlElementName =>
327 ["Group", "Interaction", "GraphicalLine", "Anchor"].indexOf(
328 isAttachedToOrViaGpmlElementName
329 ) > -1
330 ).length === 0
331 );
332 }),
333 curry(function(sortedIds: string[], pvjsonEntity: PvjsonEntity) {
334 const gpmlElementName = pvjsonEntity.gpmlElementName;
335 if (
336 ["Interaction", "GraphicalLine", "State", "Anchor"].indexOf(
337 gpmlElementName
338 ) > -1
339 ) {
340 // This entity is an edge, a state or an anchor.
341 // All entities to which this entity is attached must be processable
342 // before it is itself processable.
343 // That means all entities to which this entity is attached to must
344 // be processed before it can be processed.
345 const isAttachedToIds = unionLSV(
346 pvjsonEntity["isAttachedTo"],
347 pvjsonEntity["isAttachedToOrVia"]
348 ) as string[];
349 const isAttachedToInSortedIds = isAttachedToIds.filter(
350 // entity with this id is sortedIds
351 isAttachedToId => sortedIds.indexOf(isAttachedToId) > -1
352 );
353 return isAttachedToIds.length === isAttachedToInSortedIds.length;
354 } else if (gpmlElementName === "Group") {
355 // is processable when group does not contain an entity that is not processable
356 return (
357 arrayify(pvjsonEntity["contains"])
358 .map(isAttachedToId => processor.output.entitiesById[isAttachedToId])
359 .filter(
360 candidateEntity => sortedIds.indexOf(candidateEntity.id) > -1
361 ).length > 0
362 );
363 }
364 })
365 ];
366 //*/
367 function sortUnsortedRecursive(_a, i) {
368 var sortedIds = _a.sortedIds, unsorted = _a.unsorted;
369 if (i === void 0) { i = 0; }
370 // TODO is there something better we can do than use RECURSION_LIMIT?
371 // WP2037 revision 90015 won't terminate without a limit, but converts
372 // OK with the limit set.
373 if (unsorted.length === 0 || i > exports.RECURSION_LIMIT) {
374 return { sortedIds: sortedIds, unsorted: unsorted };
375 }
376 i += 1;
377 return sortUnsortedRecursive(sortUnsortedOnce({ sortedIds: sortedIds, unsorted: unsorted }), i);
378 }
379 function sortUnsortedOnce(_a) {
380 var sortedIds = _a.sortedIds, unsorted = _a.unsorted;
381 var _b = fp_1.partition(function (pvjsonEntity) {
382 var dependencies = gpml_utilities_1.unionLSV(pvjsonEntity.contains, pvjsonEntity["isAttachedToOrVia"], pvjsonEntity.isAttachedTo);
383 return (
384 /*
385 dependencies
386 .map((id: string) => processor.output.entitiesById[id])
387 .indexOf(undefined) === -1 &&
388 //*/
389 fp_1.intersection(dependencies, sortedIds).length === dependencies.length);
390 }, unsorted), sortedOnThisIteration = _b[0], stillUnsorted = _b[1];
391 sortedOnThisIteration
392 .forEach(function (pvjsonEntity) {
393 sortedIds.push(pvjsonEntity.id);
394 });
395 return {
396 sortedIds: sortedIds,
397 unsorted: stillUnsorted
398 };
399 }
400 return (s
401 .reduce({
402 sortedIds: [],
403 unsorted: []
404 }, function (_a, pvjsonEntity) {
405 var sortedIds = _a.sortedIds, unsorted = _a.unsorted;
406 unsorted.push(pvjsonEntity);
407 return sortUnsortedOnce({ sortedIds: sortedIds, unsorted: unsorted });
408 })
409 .map(sortUnsortedRecursive)
410 .map(function (acc) {
411 var sortedIds = acc.sortedIds, unsorted = acc.unsorted;
412 return sortedIds
413 .map(function (id) { return processor.output.entitiesById[id]; })
414 .concat(unsorted);
415 })
416 .sequence());
417 }
418 var pvjsonEntityStream = hl([
419 hl([dataNodeStream, stateStream, shapeStream, labelStream]).merge(),
420 hl([edgeStream, anchorStream]).merge(),
421 groupStream
422 ])
423 .sequence()
424 .doto(setPvjsonEntity)
425 .through(postprocessAll)
426 .flatMap(function (pvjsonEntity) {
427 var id = pvjsonEntity.id, zIndex = pvjsonEntity.zIndex;
428 // TODO we might want to sort by other criteria, such as
429 // to order a State above its DataNode, which would be
430 // ordered above its Group, if any
431 var insertEntityIdAndSortByZIndex = fp_1.flow([
432 gpml_utilities_1.insertIfNotExists(id),
433 sortByZIndex
434 ]);
435 var finalSortedStream;
436 if (gpml_utilities_1.isPvjsonEdgeOrBurr(pvjsonEntity)) {
437 var isAttachedTo = pvjsonEntity.isAttachedTo;
438 gpml_utilities_1.arrayify(isAttachedTo).forEach(function (graphRef) {
439 var graphRefs = graphIdsByGraphRef[graphRef] || [];
440 if (graphRefs.indexOf(id) === -1) {
441 graphRefs.push(id);
442 }
443 graphIdsByGraphRef[graphRef] = graphRefs;
444 });
445 if (gpml_utilities_1.isPvjsonBurr(pvjsonEntity)) {
446 finalSortedStream = hl(getPvjsonEntityLatestByGraphId(isAttachedTo)).map(function (referencedEntity) {
447 if (gpml_utilities_1.isPvjsonNode(referencedEntity)) {
448 var attachmentDisplay = pvjsonEntity.attachmentDisplay;
449 var _a = attachmentDisplay.relativeOffset, relativeOffsetScalarX = _a[0], relativeOffsetScalarY = _a[1];
450 attachmentDisplay.offset = [
451 relativeOffsetScalarX * referencedEntity.width,
452 relativeOffsetScalarY * referencedEntity.height
453 ];
454 pvjsonEntity.attachmentDisplay = fp_1.omit(["relativeOffset"], attachmentDisplay);
455 }
456 setPvjsonEntity(pvjsonEntity);
457 // NOTE: burrs are not added to the property "contained".
458 // Rather, they are added to the property "burrs".
459 referencedEntity.burrs = referencedEntity.burrs || [];
460 insertEntityIdAndSortByZIndex(referencedEntity.burrs);
461 setPvjsonEntity(referencedEntity);
462 return processor.output;
463 });
464 }
465 else if (gpml_utilities_1.isPvjsonEdge(pvjsonEntity)) {
466 try {
467 var pvjsonEdge = edge_1.postprocessPVJSON(processor.output.entitiesById, pvjsonEntity);
468 processor.output = iassign(processor.output, function (o) {
469 return o.pathway.contains;
470 }, insertEntityIdAndSortByZIndex);
471 setPvjsonEntity(pvjsonEdge);
472 finalSortedStream = hl([processor.output]);
473 }
474 catch (err) {
475 return hl.fromError(err);
476 }
477 }
478 else {
479 return hl.fromError(new VError("\n\t\t\t\t\t\t\tUnexpected entity type.\n\t\t\t\t\t\t\tOnly Edge or Burr should return true for\n\t\t\t\t\t\t\tisPvjsonEdgeOrBurr(\n\t\t\t\t\t\t\t\t" + JSON.stringify(pvjsonEntity, null, " ") + "\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t"));
480 }
481 }
482 else if (gpml_utilities_1.isPvjsonGroup(pvjsonEntity)) {
483 // We still have some GPML files with empty Groups and/or nested Groups
484 // floating around, but we don't process them, because that's a
485 // curation issue, not a gpml2pvjson issue.
486 var containedCount = pvjsonEntity.contains.length;
487 if (containedCount === 0 || pvjsonEntity.hasOwnProperty("groupRef")) {
488 if (containedCount === 0) {
489 return hl.fromError(new Error("\n\t\t\t\t\t\t\t\tEncountered empty Group:\n\t\t\t\t\t\t\t\t" + JSON.stringify(pvjsonEntity, null, " ") + "\n\t\t\t\t\t\t\t\t"));
490 }
491 if (pvjsonEntity.hasOwnProperty("groupRef")) {
492 return hl.fromError(new Error("\n\t\t\t\t\t\t\t\tEncountered nested Group:\n\t\t\t\t\t\t\t\t" + JSON.stringify(pvjsonEntity, null, " ") + "\n\t\t\t\t\t\t\t\t"));
493 }
494 finalSortedStream = hl([processor.output]);
495 }
496 else {
497 var graphIdOfGroup = pvjsonEntity.id;
498 try {
499 finalSortedStream = hl(pvjsonEntity.contains.map(function (containedId) { return processor.output.entitiesById[containedId]; }))
500 .filter(function (groupedEntity) { return groupedEntity.kaavioType !== "Group"; })
501 .collect()
502 .map(function (groupedEntities) {
503 var pvjsonGroup = group_1.postprocessPVJSON(groupedEntities, pvjsonEntity);
504 var graphIdToZIndex = processor.graphIdToZIndex;
505 pvjsonGroup.contains = fp_1.sortBy([
506 function (thisEntityId) {
507 return graphIdToZIndex[thisEntityId];
508 }
509 ], groupedEntities.map(function (x) { return x.id; }));
510 var id = pvjsonGroup.id, x = pvjsonGroup.x, y = pvjsonGroup.y;
511 var groupedEntitiesFinal = groupedEntities.map(function (groupedEntity) {
512 if (gpml_utilities_1.isPvjsonEdge(groupedEntity)) {
513 groupedEntity.points = fp_1.map(function (point) {
514 point.x -= x;
515 point.y -= y;
516 return point;
517 }, groupedEntity.points);
518 }
519 else if (gpml_utilities_1.isPvjsonSingleFreeNode(groupedEntity)) {
520 groupedEntity.height;
521 groupedEntity.x -= x;
522 groupedEntity.y -= y;
523 }
524 else {
525 return hl.fromError(new Error("\n\t\t\t\t\t\t\t\t\t\t\t\tEncountered unexpected entity\n\t\t\t\t\t\t\t\t\t\t\t\t" + JSON.stringify(groupedEntity, null, " ") + "\n\t\t\t\t\t\t\t\t\t\t\t\tin Group\n\t\t\t\t\t\t\t\t\t\t\t\t" + JSON.stringify(pvjsonGroup, null, " ") + "\n\t\t\t\t\t\t\t\t\t\t\t\t"));
526 }
527 // NOTE: this is needed for GPML2013a, because GPML2013a uses both
528 // GroupId/GroupRef and GraphId/GraphRef. GPML2017 uses a single
529 // identifier per entity. That identifier can be referenced by
530 // GroupRef and/or GraphRef. Pvjson follows GPML2017 in this, so
531 // we convert from GPML2013a format:
532 // GroupRef="GROUP_ID_VALUE"
533 // to pvjson format:
534 // {isPartOf: "GRAPH_ID_VALUE"}
535 groupedEntity.isPartOf = id;
536 return fp_1.omit(["groupRef"], groupedEntity);
537 });
538 groupedEntitiesFinal.forEach(function (pvjsonEntity) {
539 setPvjsonEntity(pvjsonEntity);
540 });
541 setPvjsonEntity(pvjsonGroup);
542 processor.output = iassign(processor.output, function (o) {
543 return o.pathway.contains;
544 }, function (contains) {
545 return insertEntityIdAndSortByZIndex(fp_1.difference(contains, groupedEntitiesFinal.map(function (x) { return x.id; })), id);
546 });
547 return pvjsonGroup;
548 })
549 .map(function (pvjsonEntity) {
550 return processor.output;
551 });
552 }
553 catch (err) {
554 return hl.fromError(err);
555 }
556 }
557 }
558 else {
559 setPvjsonEntity(pvjsonEntity);
560 processor.output = iassign(processor.output, function (o) {
561 return o.pathway.contains;
562 }, insertEntityIdAndSortByZIndex);
563 finalSortedStream = hl([processor.output]);
564 }
565 return finalSortedStream;
566 });
567 pvjsonEntityStream.observe().last().doto(function () {
568 processor.pvjsonEntityLatestStream.end();
569 });
570 var openControlledVocabularyStream = hl(cxmlSources["/Pathway/Biopax/bp:openControlledVocabulary"])
571 .map(processPropertiesAndType("openControlledVocabulary"))
572 .map(function (openControlledVocabulary) {
573 var vocabularyName = openControlledVocabulary.ontology;
574 var vocabularyIRI = VOCABULARY_NAME_TO_IRI[vocabularyName];
575 if (!vocabularyIRI) {
576 return hl.fromError(new Error("\n\t\t\t\t\t\tEncountered unexpected name \"" + vocabularyName + "\" for openControlledVocabulary,\n\t\t\t\t\t\twith dbId \"" + openControlledVocabulary.dbId + "\"\n\t\t\t\t\t\t"));
577 /* TODO should we use this?
578 vocabularyIRI = `http://www.ebi.ac.uk/miriam/main/search?query=${vocabularyName.replace(
579 /\ /,
580 "+"
581 )}#`;
582 //*/
583 }
584 openControlledVocabulary.id =
585 vocabularyIRI + openControlledVocabulary.dbId;
586 return openControlledVocabulary;
587 })
588 .collect()
589 .map(function (openControlledVocabularies) {
590 // TODO should these go through the processor instead?
591 processor.output = iassign(processor.output, function (o) {
592 var pathway = o.pathway, entitiesById = o.entitiesById;
593 openControlledVocabularies.forEach(function (openControlledVocabulary) {
594 var id = openControlledVocabulary.id;
595 entitiesById[id] = openControlledVocabulary;
596 if (openControlledVocabulary.ontology === "Pathway Ontology") {
597 pathway.type.push(id);
598 }
599 });
600 return o;
601 });
602 return processor.output;
603 });
604 var publicationXrefStream = hl(cxmlSources["/Pathway/Biopax/bp:PublicationXref"])
605 .map(processPropertiesAndType("PublicationXref"))
606 .collect()
607 .map(function (publicationXrefs) {
608 publicationXrefs
609 .sort(function (a, b) {
610 var yearA = parseInt(a.year);
611 var yearB = parseInt(b.year);
612 if (yearA > yearB) {
613 return 1;
614 }
615 else if (yearA < yearB) {
616 return -1;
617 }
618 else {
619 return 0;
620 }
621 })
622 .forEach(function (publicationXref, i) {
623 publicationXref.textContent = String(i + 1);
624 });
625 return publicationXrefs;
626 })
627 .map(function (publicationXrefs) {
628 // TODO should these go through the processor instead?
629 processor.output = iassign(processor.output, function (o) {
630 return o.entitiesById;
631 }, function (entitiesById) {
632 publicationXrefs.forEach(function (publicationXref) {
633 entitiesById[publicationXref.id] = publicationXref;
634 });
635 return entitiesById;
636 });
637 return processor.output;
638 });
639 /* TODO do we need to handle these?
640 <xsd:element ref="gpml:InfoBox" minOccurs="1" maxOccurs="1" />
641 <xsd:element ref="gpml:Legend" minOccurs="0" maxOccurs="1"/>
642 */
643 return hl([
644 pathwayMetadataStream,
645 pathwayCommentStream,
646 pvjsonEntityStream,
647 openControlledVocabularyStream,
648 publicationXrefStream
649 ])
650 .merge()
651 .errors(function (err) {
652 throw new VError(err, " when converting pathway " + pathwayIri + "\n\t\t\t\t");
653 });
654 // // TODO Double-check old code to make sure nothing is missed.
655 // // TODO does the stream ever end?
656 // // TODO does backpressure work?
657 // TODO compare the old pvjs/kaavio code below for grouping entities to
658 // ensure we don't have any regression errors.
659 /*
660 getGroupedZIndexedEntities(zIndexedEntities) {
661 const { entitiesById } = this.props;
662 return zIndexedEntities
663 .filter(entity => !entity.isPartOf)
664 .reduce(function(acc, entity) {
665 const kaavioType = entity.kaavioType;
666 if (kaavioType === "Group") {
667 // TODO: refactor this so that contains is actually a map of the contained elements. Not just an array of their IDs
668 entity.contains = entity.contains
669 .map(id => entitiesById[id])
670 .sort(function(a, b) {
671 const zIndexA = a.zIndex;
672 const zIndexB = b.zIndex;
673 if (zIndexA < zIndexB) {
674 return 1;
675 } else if (zIndexA > zIndexB) {
676 return -1;
677 } else {
678 return 0;
679 }
680 })
681 .map(entity => entity.id);
682 } else if (entity.hasOwnProperty("burrs")) {
683 entity.burrs = entity.burrs
684 .map(id => entitiesById[id])
685 .sort(function(a, b) {
686 const zIndexA = a.zIndex;
687 const zIndexB = b.zIndex;
688 if (zIndexA < zIndexB) {
689 return 1;
690 } else if (zIndexA > zIndexB) {
691 return -1;
692 } else {
693 return 0;
694 }
695 })
696 .map(entity => entity.id);
697 }
698 if (
699 ["Burr"].indexOf(kaavioType) === -1 &&
700 !entity.hasOwnProperty("isPartOf")
701 ) {
702 acc.push(entity);
703 }
704 return acc;
705 }, []);
706 }
707 //*/
708}
709exports.toPvjson = toPvjson;
710//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toPvjson.js","sourceRoot":"","sources":["../../src/2013a/toPvjson.ts"],"names":[],"mappings":"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"}
\No newline at end of file