From fa3821b50f9095ebd5ed1b4f297c59c227e1015d Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Sun, 18 Oct 2015 20:58:17 -0700 Subject: [PATCH 01/62] Update of CopyService with new copy algorithm (incomplete) --- .../entanglement/src/services/CopyService.js | 88 ++++++++++++++++++- 1 file changed, 86 insertions(+), 2 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 48ba3e7ce5..f9bf53a0b9 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -23,7 +23,8 @@ /*global define */ define( - function () { + ["../../../commonUI/browse/lib/uuid"], + function (uuid) { "use strict"; /** @@ -53,8 +54,61 @@ define( object.getCapability('type') ); }; + + /** + * Will build a graph of an object and all of its composed objects in memory + * @private + * @param domainObject + */ + function buildCopyGraph(domainObject, parent) { + var clonedModels = []; + + function clone(object) { + return JSON.parse(JSON.stringify(object)); + } + + function copy(object, parent) { + var modelClone = clone(object.getModel()); + modelClone.composition = []; + if (domainObject.hasCapability('composition')) { + return domainObject.useCapability('composition').then(function(composees){ + return composees.reduce(function(promise, composee){ + return promise.then(function(){ + return copy(composee, object).then(function(composeeClone){ + /* + TODO: Use the composition capability for this. Just not sure how to contextualize the as-yet non-existent modelClone object. + */ + return modelClone.composition.push(composeeClone.id); + }); + }); + }, $q.when(undefined)).then(function (){ + modelClone.id = uuid(); + clonedModels.push(modelClone); + return modelClone; + }); + }); + } else { + return Q.when(modelClone); + } + }; + return copy(domainObject, parent).then(function(){ + return clonedModels; + }); + } - CopyService.prototype.perform = function (domainObject, parent) { + function newPerform (domainObject, parent) { + return buildCopyGraph.then(function(clonedModels){ + return clonedModels.reduce(function(promise, clonedModel){ + /* + TODO: Persist the clone. We need to bypass the creation service on this because it wants to create the composition along the way, which we want to avoid. The composition has already been done directly in the model. + */ + }, this.q.when(undefined)); + }) + } + + CopyService.prototype.perform = oldPerform; + + function oldPerform (domainObject, parent) { var model = JSON.parse(JSON.stringify(domainObject.getModel())), $q = this.$q, self = this; @@ -74,6 +128,36 @@ define( model.composition = []; } + /* + * 1) Traverse to leaf of object tree + * 2) Copy object and persist + * 3) Go up to parent + * 4) Update parent in memory with new composition + * 4) If parent has more children + * 5) Visit next child + * 6) Go to 2) + * 7) else + * 8) Persist parent + */ + + /* + * copy(object, parent) { + * 1) objectClone = clone(object); // Clone object + * 2) objectClone.composition = []; // Reset the clone's composition + * 3) composees = object.composition; + * 3) composees.reduce(function (promise, composee) { // For each child in original composition + * 4) return promise.then(function () { + * 5) return copy(composee, object).then(function(clonedComposee){ + * 6) objectClone.composition.push(clonedComposee); + * 7) return objectClone; + * 8) ); // Copy the child + * 9) }; + * 10) }) + * 11) objectClone.id = newId(); + * 12) return persist(objectClone); + * } + */ + return this.creationService .createObject(model, parent) .then(function (newObject) { From 2a1388772af83c1851c495519f53fe9cf0cc2b6f Mon Sep 17 00:00:00 2001 From: Henry Date: Mon, 19 Oct 2015 17:32:43 -0700 Subject: [PATCH 02/62] Incremental commit of duplication --- bundles.json | 2 +- platform/entanglement/bundle.json | 3 +- .../entanglement/src/services/CopyService.js | 38 +++++++++++++------ 3 files changed, 29 insertions(+), 14 deletions(-) diff --git a/bundles.json b/bundles.json index c85b681bf5..3940336656 100644 --- a/bundles.json +++ b/bundles.json @@ -22,7 +22,7 @@ "platform/features/events", "platform/forms", "platform/identity", - "platform/persistence/local", + "platform/persistence/elastic", "platform/persistence/queue", "platform/policy", "platform/entanglement", diff --git a/platform/entanglement/bundle.json b/platform/entanglement/bundle.json index 61c3d90539..9594c29b4f 100644 --- a/platform/entanglement/bundle.json +++ b/platform/entanglement/bundle.json @@ -75,7 +75,8 @@ "name": "Copy Service", "description": "Provides a service for copying objects", "implementation": "services/CopyService.js", - "depends": ["$q", "creationService", "policyService"] + "depends": ["$q", "creationService", "policyService", + "persistenceService"] }, { "key": "locationService", diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index f9bf53a0b9..dd558dbec0 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -35,10 +35,11 @@ define( * @memberof platform/entanglement * @implements {platform/entanglement.AbstractComposeService} */ - function CopyService($q, creationService, policyService) { + function CopyService($q, creationService, policyService, persistenceService) { this.$q = $q; this.creationService = creationService; this.policyService = policyService; + this.persistenceService = persistenceService; } CopyService.prototype.validate = function (object, parentCandidate) { @@ -61,15 +62,18 @@ define( * @param domainObject */ function buildCopyGraph(domainObject, parent) { - var clonedModels = []; + var clones = [], + $q = this.$q; function clone(object) { return JSON.parse(JSON.stringify(object)); } function copy(object, parent) { + var self = this; var modelClone = clone(object.getModel()); modelClone.composition = []; + if (domainObject.hasCapability('composition')) { return domainObject.useCapability('composition').then(function(composees){ return composees.reduce(function(promise, composee){ @@ -83,27 +87,37 @@ define( }); }, $q.when(undefined)).then(function (){ modelClone.id = uuid(); - clonedModels.push(modelClone); + clones.push({persistence: parent.getCapability('persistence'), model: modelClone}); return modelClone; }); }); } else { - return Q.when(modelClone); + return $q.when(modelClone); } }; return copy(domainObject, parent).then(function(){ - return clonedModels; + return clones; }); } function newPerform (domainObject, parent) { - return buildCopyGraph.then(function(clonedModels){ - return clonedModels.reduce(function(promise, clonedModel){ - /* - TODO: Persist the clone. We need to bypass the creation service on this because it wants to create the composition along the way, which we want to avoid. The composition has already been done directly in the model. - */ - }, this.q.when(undefined)); - }) + var $q = this.$q; + if (this.validate(domainObject, parent)) { + return buildCopyGraph(domainObject, parent).then(function(clones){ + return clones.reduce(function(promise, clone){ + /* + TODO: Persist the clone. We need to bypass the creation service on this because it wants to create the composition along the way, which we want to avoid. The composition has already been done directly in the model. + */ + promise.then(function(){ + return this.persistenceService.createObject(clone.persistence.getSpace(), clone.model.id, clone.model); + }); + }, $q.when(undefined)); + }) + } else { + throw new Error( + "Tried to copy objects without validating first." + ); + } } CopyService.prototype.perform = oldPerform; From 89e763b5158856144a3accaecc3d1ed2c03c2f40 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Tue, 20 Oct 2015 09:25:31 -0700 Subject: [PATCH 03/62] Incremental commit of Duplication --- bundles.json | 2 +- .../entanglement/src/services/CopyService.js | 22 ++++++++++--------- 2 files changed, 13 insertions(+), 11 deletions(-) diff --git a/bundles.json b/bundles.json index 3940336656..c85b681bf5 100644 --- a/bundles.json +++ b/bundles.json @@ -22,7 +22,7 @@ "platform/features/events", "platform/forms", "platform/identity", - "platform/persistence/elastic", + "platform/persistence/local", "platform/persistence/queue", "platform/policy", "platform/entanglement", diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index dd558dbec0..6798443b48 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -61,27 +61,28 @@ define( * @private * @param domainObject */ - function buildCopyGraph(domainObject, parent) { + CopyService.prototype.buildCopyGraph = function(domainObject, parent) { var clones = [], - $q = this.$q; + $q = this.$q, + self = this; function clone(object) { return JSON.parse(JSON.stringify(object)); } function copy(object, parent) { - var self = this; var modelClone = clone(object.getModel()); modelClone.composition = []; - if (domainObject.hasCapability('composition')) { - return domainObject.useCapability('composition').then(function(composees){ + if (object.hasCapability('composition')) { + return object.useCapability('composition').then(function(composees){ return composees.reduce(function(promise, composee){ return promise.then(function(){ return copy(composee, object).then(function(composeeClone){ /* TODO: Use the composition capability for this. Just not sure how to contextualize the as-yet non-existent modelClone object. */ + composeeClone.location = modelClone.id; return modelClone.composition.push(composeeClone.id); }); }); @@ -101,15 +102,16 @@ define( } function newPerform (domainObject, parent) { - var $q = this.$q; + var $q = this.$q, + self = this; if (this.validate(domainObject, parent)) { - return buildCopyGraph(domainObject, parent).then(function(clones){ + return this.buildCopyGraph(domainObject, parent).then(function(clones){ return clones.reduce(function(promise, clone){ /* TODO: Persist the clone. We need to bypass the creation service on this because it wants to create the composition along the way, which we want to avoid. The composition has already been done directly in the model. */ - promise.then(function(){ - return this.persistenceService.createObject(clone.persistence.getSpace(), clone.model.id, clone.model); + return promise.then(function(){ + return self.persistenceService.createObject(clone.persistence.getSpace(), clone.model.id, clone.model); }); }, $q.when(undefined)); }) @@ -120,7 +122,7 @@ define( } } - CopyService.prototype.perform = oldPerform; + CopyService.prototype.perform = newPerform; function oldPerform (domainObject, parent) { var model = JSON.parse(JSON.stringify(domainObject.getModel())), From 6d08c81b3b83b6e3563b4e4579fa5fa422a798ab Mon Sep 17 00:00:00 2001 From: Henry Date: Tue, 20 Oct 2015 12:18:30 -0700 Subject: [PATCH 04/62] First iteration of duplication complete --- bundles.json | 2 +- .../entanglement/src/services/CopyService.js | 45 ++++++++++++------- 2 files changed, 31 insertions(+), 16 deletions(-) diff --git a/bundles.json b/bundles.json index c85b681bf5..3940336656 100644 --- a/bundles.json +++ b/bundles.json @@ -22,7 +22,7 @@ "platform/features/events", "platform/forms", "platform/identity", - "platform/persistence/local", + "platform/persistence/elastic", "platform/persistence/queue", "platform/policy", "platform/entanglement", diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 6798443b48..843ec6cd2a 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -62,6 +62,13 @@ define( * @param domainObject */ CopyService.prototype.buildCopyGraph = function(domainObject, parent) { + /* TODO: Use contextualized objects here. + Parent should be fully contextualized, and either the + original parent or a contextualized clone. The subsequent + composition changes can then be performed regardless of + whether it is the top level composition of the original + parent being updated, or of one of the cloned children. */ + var clones = [], $q = this.$q, self = this; @@ -70,15 +77,16 @@ define( return JSON.parse(JSON.stringify(object)); } - function copy(object, parent) { - var modelClone = clone(object.getModel()); + function copy(originalObject, originalParent) { + var modelClone = clone(originalObject.getModel()); modelClone.composition = []; + modelClone.id = uuid(); - if (object.hasCapability('composition')) { - return object.useCapability('composition').then(function(composees){ + if (originalObject.hasCapability('composition')) { + return originalObject.useCapability('composition').then(function(composees){ return composees.reduce(function(promise, composee){ return promise.then(function(){ - return copy(composee, object).then(function(composeeClone){ + return copy(composee, originalObject).then(function(composeeClone){ /* TODO: Use the composition capability for this. Just not sure how to contextualize the as-yet non-existent modelClone object. */ @@ -87,12 +95,14 @@ define( }); }); }, $q.when(undefined)).then(function (){ - modelClone.id = uuid(); - clones.push({persistence: parent.getCapability('persistence'), model: modelClone}); + /* Todo: Move this outside of promise and avoid + duplication below */ + clones.push({persistence: originalParent.getCapability('persistence'), model: modelClone}); return modelClone; }); }); } else { + clones.push({persistence: originalParent.getCapability('persistence'), model: modelClone}); return $q.when(modelClone); } }; @@ -106,15 +116,20 @@ define( self = this; if (this.validate(domainObject, parent)) { return this.buildCopyGraph(domainObject, parent).then(function(clones){ - return clones.reduce(function(promise, clone){ - /* - TODO: Persist the clone. We need to bypass the creation service on this because it wants to create the composition along the way, which we want to avoid. The composition has already been done directly in the model. - */ - return promise.then(function(){ + return $q.all(clones.map(function(clone){ return self.persistenceService.createObject(clone.persistence.getSpace(), clone.model.id, clone.model); - }); - }, $q.when(undefined)); - }) + })).then(function(){ return clones}); + }).then(function(clones) { + var parentClone = clones[clones.length-1]; + parentClone.model.location = parent.getId() + return $q.when( + parent.hasCapability('composition') && + parent.getCapability('composition').add(parentClone.model.id) + .then( + function(){ + parent.getCapability("persistence").persist() + })); + }); } else { throw new Error( "Tried to copy objects without validating first." From ee314ab387bb8067cc3d874479a676651ca9da37 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 28 Oct 2015 17:05:05 -0700 Subject: [PATCH 05/62] Added notifications --- platform/entanglement/bundle.json | 2 +- .../src/actions/AbstractComposeAction.js | 6 +- .../entanglement/src/actions/CopyAction.js | 34 +++++++++- .../entanglement/src/services/CopyService.js | 62 ++++++------------- .../dialogTest/src/DialogLaunchController.js | 1 - 5 files changed, 55 insertions(+), 50 deletions(-) diff --git a/platform/entanglement/bundle.json b/platform/entanglement/bundle.json index 9594c29b4f..f8eed70030 100644 --- a/platform/entanglement/bundle.json +++ b/platform/entanglement/bundle.json @@ -20,7 +20,7 @@ "glyph": "+", "category": "contextual", "implementation": "actions/CopyAction.js", - "depends": ["locationService", "copyService"] + "depends": ["locationService", "copyService", "dialogService", "notificationService"] }, { "key": "link", diff --git a/platform/entanglement/src/actions/AbstractComposeAction.js b/platform/entanglement/src/actions/AbstractComposeAction.js index f68391adc9..1ceb469591 100644 --- a/platform/entanglement/src/actions/AbstractComposeAction.js +++ b/platform/entanglement/src/actions/AbstractComposeAction.js @@ -71,7 +71,7 @@ define( * @param {string} [suffix] a string to display in the dialog title; * default is "to a new location" */ - function AbstractComposeAction(locationService, composeService, context, verb, suffix) { + function AbstractComposeAction(locationService, composeService, context, verb, suffix, progressCallback) { if (context.selectedObject) { this.newParent = context.domainObject; this.object = context.selectedObject; @@ -87,6 +87,7 @@ define( this.composeService = composeService; this.verb = verb || "Compose"; this.suffix = suffix || "to a new location"; + this.progressCallback = progressCallback; } AbstractComposeAction.prototype.perform = function () { @@ -97,6 +98,7 @@ define( composeService = this.composeService, currentParent = this.currentParent, newParent = this.newParent, + progressCallback = this.progressCallback, object = this.object; if (newParent) { @@ -118,7 +120,7 @@ define( validateLocation, currentParent ).then(function (newParent) { - return composeService.perform(object, newParent); + return composeService.perform(object, newParent, progressCallback); }); }; diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index 3411fdba85..e10c619de0 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -34,13 +34,43 @@ define( * @constructor * @memberof platform/entanglement */ - function CopyAction(locationService, copyService, context) { + function CopyAction(locationService, copyService, dialogService, notificationService, context) { + var notification, + notificationModel = { + title: "Copying objects", + unknownProgress: false, + severity: "info", + }; + + function progress(phase, totalObjects, processed){ + if (phase.toLowerCase() === 'preparing'){ + console.log('preparing'); + dialogService.showBlockingMessage({ + title: "Preparing to copy objects", + unknownProgress: true, + severity: "info", + }); + } else if (phase.toLowerCase() === "copying") { + console.log('copying'); + dialogService.dismiss(); + if (!notification) { + notification = notificationService.notify(notificationModel); + } + notificationModel.progress = (processed / totalObjects) * 100; + notificationModel.title = ["Copying ", processed, "of ", totalObjects, "objects"].join(" "); + if (processed >= totalObjects){ + notification.dismiss(); + } + } + } + return new AbstractComposeAction( locationService, copyService, context, "Duplicate", - "to a location" + "to a location", + progress ); } diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 843ec6cd2a..1f4bc2ddac 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -111,24 +111,28 @@ define( }); } - function newPerform (domainObject, parent) { + function newPerform (domainObject, parent, progress) { var $q = this.$q, self = this; if (this.validate(domainObject, parent)) { - return this.buildCopyGraph(domainObject, parent).then(function(clones){ - return $q.all(clones.map(function(clone){ + progress("preparing"); + return this.buildCopyGraph(domainObject, parent) + .then(function(clones){ + return $q.all(clones.map(function(clone, index){ + progress("copying", clones.length, index); return self.persistenceService.createObject(clone.persistence.getSpace(), clone.model.id, clone.model); - })).then(function(){ return clones}); - }).then(function(clones) { - var parentClone = clones[clones.length-1]; - parentClone.model.location = parent.getId() - return $q.when( - parent.hasCapability('composition') && - parent.getCapability('composition').add(parentClone.model.id) - .then( - function(){ - parent.getCapability("persistence").persist() - })); + })).then(function(){ return clones}); + }) + .then(function(clones) { + var parentClone = clones[clones.length-1]; + parentClone.model.location = parent.getId() + return $q.when( + parent.hasCapability('composition') && + parent.getCapability('composition').add(parentClone.model.id) + .then(function(){ + progress("copying", clones.length, clones.length); + parent.getCapability("persistence").persist() + })); }); } else { throw new Error( @@ -159,36 +163,6 @@ define( model.composition = []; } - /* - * 1) Traverse to leaf of object tree - * 2) Copy object and persist - * 3) Go up to parent - * 4) Update parent in memory with new composition - * 4) If parent has more children - * 5) Visit next child - * 6) Go to 2) - * 7) else - * 8) Persist parent - */ - - /* - * copy(object, parent) { - * 1) objectClone = clone(object); // Clone object - * 2) objectClone.composition = []; // Reset the clone's composition - * 3) composees = object.composition; - * 3) composees.reduce(function (promise, composee) { // For each child in original composition - * 4) return promise.then(function () { - * 5) return copy(composee, object).then(function(clonedComposee){ - * 6) objectClone.composition.push(clonedComposee); - * 7) return objectClone; - * 8) ); // Copy the child - * 9) }; - * 10) }) - * 11) objectClone.id = newId(); - * 12) return persist(objectClone); - * } - */ - return this.creationService .createObject(model, parent) .then(function (newObject) { diff --git a/testing/dialogTest/src/DialogLaunchController.js b/testing/dialogTest/src/DialogLaunchController.js index bc8cdcb419..cfd3f22e74 100644 --- a/testing/dialogTest/src/DialogLaunchController.js +++ b/testing/dialogTest/src/DialogLaunchController.js @@ -34,7 +34,6 @@ define( hint: "Do not navigate away from this page or close this browser tab while this operation is in progress.", actionText: "Calculating...", unknownProgress: !knownProgress, - unknownDuration: false, severity: MessageSeverity.INFO, actions: [ { From 9c90eb52a4574c48bf5a583c3ef1c1dd636df643 Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Thu, 29 Oct 2015 11:30:01 -0700 Subject: [PATCH 06/62] [Production] Added collapse left and right pane symbols open #188 --- .../icomoon.io-WTD-symbols-project.json | 240 +++++++++++------- .../general/res/fonts/symbols/wtdsymbols.eot | Bin 11836 -> 11968 bytes .../general/res/fonts/symbols/wtdsymbols.svg | 2 + .../general/res/fonts/symbols/wtdsymbols.ttf | Bin 11660 -> 11792 bytes .../general/res/fonts/symbols/wtdsymbols.woff | Bin 11736 -> 11868 bytes 5 files changed, 156 insertions(+), 86 deletions(-) diff --git a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json index 72c9a01fa2..ef3c1beecf 100644 --- a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json +++ b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json @@ -1,19 +1,35 @@ { "metadata": { "name": "WTD Symbols", - "lastOpened": 1445369623428, - "created": 1445367449289 + "lastOpened": 1446143042082, + "created": 1446143040164 }, "iconSets": [ { "selection": [ + { + "order": 110, + "id": 91, + "prevSize": 32, + "code": 58899, + "name": "icon-collapse-pane-left", + "tempChar": "" + }, + { + "order": 111, + "id": 90, + "prevSize": 32, + "code": 58900, + "name": "icon-collapse-pane-right", + "tempChar": "" + }, { "order": 109, "id": 89, "prevSize": 32, "code": 58898, "name": "icon-save", - "tempChar": "" + "tempChar": "" }, { "order": 108, @@ -21,7 +37,7 @@ "prevSize": 32, "code": 58897, "name": "icon-dataset", - "tempChar": "" + "tempChar": "" }, { "order": 90, @@ -29,7 +45,7 @@ "prevSize": 32, "code": 58896, "name": "icon-bell", - "tempChar": "" + "tempChar": "" }, { "order": 91, @@ -37,7 +53,7 @@ "prevSize": 32, "code": 58889, "name": "icon-hourglass", - "tempChar": "" + "tempChar": "" }, { "order": 92, @@ -50,7 +66,7 @@ 58890 ], "name": "icon-info-v15", - "tempChar": "" + "tempChar": "" }, { "order": 93, @@ -58,7 +74,7 @@ "prevSize": 32, "code": 58887, "name": "icon-x-in-circle", - "tempChar": "" + "tempChar": "" }, { "order": 94, @@ -66,7 +82,7 @@ "prevSize": 32, "code": 58881, "name": "icon-datatable", - "tempChar": "" + "tempChar": "" }, { "order": 95, @@ -74,7 +90,7 @@ "prevSize": 32, "code": 58882, "name": "icon-tabular-scrolling", - "tempChar": "" + "tempChar": "" }, { "order": 96, @@ -82,7 +98,7 @@ "prevSize": 32, "code": 58884, "name": "icon-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 97, @@ -90,7 +106,7 @@ "prevSize": 32, "code": 58885, "name": "icon-calendar", - "tempChar": "" + "tempChar": "" }, { "order": 98, @@ -98,7 +114,7 @@ "prevSize": 32, "code": 58886, "name": "icon-paint-bucket", - "tempChar": "" + "tempChar": "" }, { "order": 99, @@ -106,7 +122,7 @@ "prevSize": 32, "code": 123, "name": "icon-pointer-left", - "tempChar": "" + "tempChar": "" }, { "order": 100, @@ -114,7 +130,7 @@ "prevSize": 32, "code": 125, "name": "icon-pointer-right", - "tempChar": "" + "tempChar": "" }, { "order": 101, @@ -122,7 +138,7 @@ "prevSize": 32, "code": 80, "name": "icon-person", - "tempChar": "" + "tempChar": "" }, { "order": 102, @@ -130,7 +146,7 @@ "prevSize": 32, "code": 232, "name": "icon-chain-links", - "tempChar": "" + "tempChar": "" }, { "order": 103, @@ -138,7 +154,7 @@ "prevSize": 32, "code": 115, "name": "icon-database-in-brackets", - "tempChar": "" + "tempChar": "" }, { "order": 104, @@ -146,7 +162,7 @@ "prevSize": 32, "code": 114, "name": "icon-refresh", - "tempChar": "" + "tempChar": "" }, { "order": 105, @@ -154,7 +170,7 @@ "prevSize": 32, "code": 108, "name": "icon-lock", - "tempChar": "" + "tempChar": "" }, { "order": 106, @@ -162,7 +178,7 @@ "prevSize": 32, "code": 51, "name": "icon-box-with-dashed-lines", - "tempChar": "" + "tempChar": "" }, { "order": 10, @@ -170,7 +186,7 @@ "prevSize": 32, "code": 58880, "name": "icon-box-with-arrow-cursor", - "tempChar": "" + "tempChar": "" }, { "order": 11, @@ -178,7 +194,7 @@ "prevSize": 32, "code": 65, "name": "icon-activity-mode", - "tempChar": "" + "tempChar": "" }, { "order": 12, @@ -186,7 +202,7 @@ "prevSize": 32, "code": 97, "name": "icon-activity", - "tempChar": "" + "tempChar": "" }, { "order": 87, @@ -194,7 +210,7 @@ "prevSize": 32, "code": 33, "name": "icon-alert-rect", - "tempChar": "" + "tempChar": "" }, { "order": 14, @@ -202,7 +218,7 @@ "prevSize": 32, "code": 58883, "name": "icon-alert-triangle", - "tempChar": "" + "tempChar": "" }, { "order": 15, @@ -210,7 +226,7 @@ "prevSize": 32, "code": 238, "name": "icon-arrow-double-down", - "tempChar": "" + "tempChar": "" }, { "order": 16, @@ -218,7 +234,7 @@ "prevSize": 32, "code": 235, "name": "icon-arrow-double-up", - "tempChar": "" + "tempChar": "" }, { "order": 2, @@ -226,7 +242,7 @@ "prevSize": 32, "code": 118, "name": "icon-arrow-down", - "tempChar": "" + "tempChar": "" }, { "order": 19, @@ -234,7 +250,7 @@ "prevSize": 32, "code": 60, "name": "icon-arrow-left", - "tempChar": "" + "tempChar": "" }, { "order": 20, @@ -242,7 +258,7 @@ "prevSize": 32, "code": 62, "name": "icon-arrow-right", - "tempChar": "" + "tempChar": "" }, { "order": 21, @@ -250,7 +266,7 @@ "prevSize": 32, "code": 236, "name": "icon-arrow-tall-down", - "tempChar": "" + "tempChar": "" }, { "order": 22, @@ -258,7 +274,7 @@ "prevSize": 32, "code": 237, "name": "icon-arrow-tall-up", - "tempChar": "" + "tempChar": "" }, { "order": 23, @@ -266,7 +282,7 @@ "prevSize": 32, "code": 94, "name": "icon-arrow-up", - "tempChar": "" + "tempChar": "" }, { "order": 24, @@ -274,7 +290,7 @@ "prevSize": 32, "code": 73, "name": "icon-arrows-out", - "tempChar": "" + "tempChar": "" }, { "order": 25, @@ -282,7 +298,7 @@ "prevSize": 32, "code": 58893, "name": "icon-arrows-right-left", - "tempChar": "" + "tempChar": "" }, { "order": 33, @@ -290,7 +306,7 @@ "prevSize": 32, "code": 53, "name": "icon-arrows-up-down", - "tempChar": "" + "tempChar": "" }, { "order": 26, @@ -298,7 +314,7 @@ "prevSize": 32, "code": 42, "name": "icon-asterisk", - "tempChar": "" + "tempChar": "" }, { "order": 27, @@ -306,7 +322,7 @@ "prevSize": 32, "code": 72, "name": "icon-autoflow-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 28, @@ -314,7 +330,7 @@ "prevSize": 32, "code": 224, "name": "icon-box", - "tempChar": "" + "tempChar": "" }, { "order": 29, @@ -322,7 +338,7 @@ "prevSize": 32, "code": 50, "name": "icon-check", - "tempChar": "" + "tempChar": "" }, { "order": 30, @@ -330,7 +346,7 @@ "prevSize": 32, "code": 67, "name": "icon-clock", - "tempChar": "" + "tempChar": "" }, { "order": 31, @@ -338,7 +354,7 @@ "prevSize": 32, "code": 46, "name": "icon-connectivity", - "tempChar": "" + "tempChar": "" }, { "order": 32, @@ -346,7 +362,7 @@ "prevSize": 32, "code": 100, "name": "icon-database-query", - "tempChar": "" + "tempChar": "" }, { "order": 17, @@ -354,7 +370,7 @@ "prevSize": 32, "code": 68, "name": "icon-database", - "tempChar": "" + "tempChar": "" }, { "order": 35, @@ -362,7 +378,7 @@ "prevSize": 32, "code": 81, "name": "icon-dictionary", - "tempChar": "" + "tempChar": "" }, { "order": 36, @@ -370,7 +386,7 @@ "prevSize": 32, "code": 242, "name": "icon-duplicate", - "tempChar": "" + "tempChar": "" }, { "order": 37, @@ -378,7 +394,7 @@ "prevSize": 32, "code": 102, "name": "icon-folder-new", - "tempChar": "" + "tempChar": "" }, { "order": 38, @@ -386,7 +402,7 @@ "prevSize": 32, "code": 70, "name": "icon-folder", - "tempChar": "" + "tempChar": "" }, { "order": 39, @@ -394,7 +410,7 @@ "prevSize": 32, "code": 95, "name": "icon-fullscreen-collapse", - "tempChar": "" + "tempChar": "" }, { "order": 40, @@ -402,7 +418,7 @@ "prevSize": 32, "code": 122, "name": "icon-fullscreen-expand", - "tempChar": "" + "tempChar": "" }, { "order": 41, @@ -410,7 +426,7 @@ "prevSize": 32, "code": 71, "name": "icon-gear", - "tempChar": "" + "tempChar": "" }, { "order": 49, @@ -418,7 +434,7 @@ "prevSize": 32, "code": 227, "name": "icon-image", - "tempChar": "" + "tempChar": "" }, { "order": 42, @@ -426,7 +442,7 @@ "prevSize": 32, "code": 225, "name": "icon-layers", - "tempChar": "" + "tempChar": "" }, { "order": 43, @@ -434,7 +450,7 @@ "prevSize": 32, "code": 76, "name": "icon-layout", - "tempChar": "" + "tempChar": "" }, { "order": 44, @@ -442,7 +458,7 @@ "prevSize": 32, "code": 226, "name": "icon-line-horz", - "tempChar": "" + "tempChar": "" }, { "order": 75, @@ -450,7 +466,7 @@ "prevSize": 32, "code": 244, "name": "icon-link", - "tempChar": "" + "tempChar": "" }, { "order": 46, @@ -458,7 +474,7 @@ "prevSize": 32, "code": 88, "name": "icon-magnify-in", - "tempChar": "" + "tempChar": "" }, { "order": 47, @@ -466,7 +482,7 @@ "prevSize": 32, "code": 89, "name": "icon-magnify-out", - "tempChar": "" + "tempChar": "" }, { "order": 48, @@ -474,7 +490,7 @@ "prevSize": 32, "code": 77, "name": "icon-magnify", - "tempChar": "" + "tempChar": "" }, { "order": 34, @@ -482,7 +498,7 @@ "prevSize": 32, "code": 109, "name": "icon-menu", - "tempChar": "" + "tempChar": "" }, { "order": 50, @@ -490,7 +506,7 @@ "prevSize": 32, "code": 243, "name": "icon-move", - "tempChar": "" + "tempChar": "" }, { "order": 51, @@ -498,7 +514,7 @@ "prevSize": 32, "code": 121, "name": "icon-new-window", - "tempChar": "" + "tempChar": "" }, { "order": 52, @@ -506,7 +522,7 @@ "prevSize": 32, "code": 111, "name": "icon-object", - "tempChar": "" + "tempChar": "" }, { "order": 73, @@ -514,7 +530,7 @@ "prevSize": 32, "code": 63, "name": "icon-object-unknown", - "tempChar": "" + "tempChar": "" }, { "order": 53, @@ -522,7 +538,7 @@ "prevSize": 32, "code": 86, "name": "icon-packet", - "tempChar": "" + "tempChar": "" }, { "order": 54, @@ -530,7 +546,7 @@ "prevSize": 32, "code": 234, "name": "icon-page", - "tempChar": "" + "tempChar": "" }, { "order": 55, @@ -538,7 +554,7 @@ "prevSize": 32, "code": 241, "name": "icon-pause", - "tempChar": "" + "tempChar": "" }, { "order": 56, @@ -546,7 +562,7 @@ "prevSize": 32, "code": 112, "name": "icon-pencil", - "tempChar": "" + "tempChar": "" }, { "order": 65, @@ -554,7 +570,7 @@ "prevSize": 32, "code": 79, "name": "icon-people", - "tempChar": "" + "tempChar": "" }, { "order": 57, @@ -562,7 +578,7 @@ "prevSize": 32, "code": 239, "name": "icon-play", - "tempChar": "" + "tempChar": "" }, { "order": 58, @@ -570,7 +586,7 @@ "prevSize": 32, "code": 233, "name": "icon-plot-resource", - "tempChar": "" + "tempChar": "" }, { "order": 59, @@ -578,7 +594,7 @@ "prevSize": 32, "code": 43, "name": "icon-plus", - "tempChar": "" + "tempChar": "" }, { "order": 60, @@ -586,7 +602,7 @@ "prevSize": 32, "code": 45, "name": "icon-minus", - "tempChar": "" + "tempChar": "" }, { "order": 61, @@ -594,7 +610,7 @@ "prevSize": 32, "code": 54, "name": "icon-sine", - "tempChar": "" + "tempChar": "" }, { "order": 62, @@ -602,7 +618,7 @@ "prevSize": 32, "code": 228, "name": "icon-T", - "tempChar": "" + "tempChar": "" }, { "order": 63, @@ -610,7 +626,7 @@ "prevSize": 32, "code": 116, "name": "icon-telemetry-panel", - "tempChar": "" + "tempChar": "" }, { "order": 64, @@ -618,7 +634,7 @@ "prevSize": 32, "code": 84, "name": "icon-telemetry", - "tempChar": "" + "tempChar": "" }, { "order": 18, @@ -626,7 +642,7 @@ "prevSize": 32, "code": 246, "name": "icon-thumbs-strip", - "tempChar": "" + "tempChar": "" }, { "order": 67, @@ -634,7 +650,7 @@ "prevSize": 32, "code": 83, "name": "icon-timeline", - "tempChar": "" + "tempChar": "" }, { "order": 68, @@ -642,7 +658,7 @@ "prevSize": 32, "code": 245, "name": "icon-timer", - "tempChar": "" + "tempChar": "" }, { "order": 69, @@ -650,7 +666,7 @@ "prevSize": 32, "code": 90, "name": "icon-trash", - "tempChar": "" + "tempChar": "" }, { "order": 70, @@ -658,7 +674,7 @@ "prevSize": 32, "code": 229, "name": "icon-two-parts-both", - "tempChar": "" + "tempChar": "" }, { "order": 71, @@ -666,7 +682,7 @@ "prevSize": 32, "code": 231, "name": "icon-two-parts-one-only", - "tempChar": "" + "tempChar": "" }, { "order": 72, @@ -674,7 +690,7 @@ "prevSize": 32, "code": 120, "name": "icon-x-heavy", - "tempChar": "" + "tempChar": "" }, { "order": 66, @@ -682,7 +698,7 @@ "prevSize": 32, "code": 58946, "name": "icon-x", - "tempChar": "" + "tempChar": "" } ], "id": 2, @@ -697,6 +713,58 @@ "height": 1024, "prevSize": 32, "icons": [ + { + "id": 91, + "paths": [ + "M256 0h-256v1024h256c105.6 0 192-86.4 192-192v-640c0-105.6-86.4-192-192-192z", + "M512 320l512 320v-640z" + ], + "attrs": [ + { + "fill": "rgb(0, 0, 0)" + }, + { + "fill": "rgb(0, 0, 0)" + } + ], + "isMulticolor": false, + "grid": 0, + "tags": [ + "icon-collapse-pane-left" + ], + "colorPermutations": { + "125525525516161751": [ + 0, + 0 + ] + } + }, + { + "id": 90, + "paths": [ + "M768 0h256v1024h-256c-105.6 0-192-86.4-192-192v-640c0-105.6 86.4-192 192-192z", + "M512 320l-512 320v-640z" + ], + "attrs": [ + { + "fill": "rgb(0, 0, 0)" + }, + { + "fill": "rgb(0, 0, 0)" + } + ], + "isMulticolor": false, + "grid": 0, + "tags": [ + "icon-collapse-pane-right" + ], + "colorPermutations": { + "125525525516161751": [ + 0, + 0 + ] + } + }, { "id": 89, "paths": [ diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot index 491c4b12ca8dcdd9d8ba76bfa45591db87e65314..7a2163d74a62a3ce83d29f4f6aa07a885b6b4af8 100755 GIT binary patch delta 417 zcmZXP%}WAN6vfYbPHIKeFp@z+X=3=1i?V6s!iCFVpjAj^Lz%PiGmUJe|AELXYvD2? z5E5KP47h4h&<8EUeF$wLh;X_tT6y8}IOp8od+*-v7`s*@49tWZR$1suo>n8)s5;($ z0Oq2Or`1vclmmR9PJ23YcGP@7o+YgT%P}pb9@-vrdBA^3xvY_4GlY54J#)J0wFKy#hjW=%`Lq4_sED7a8<~c%CJy`l}}w` z56q#QyC;UtMvsA^M|UEd8B4i%>%oZ*6YB-8{bFEXlmTLw^u*!<1_lNJ1_q`CAkC4U zQ<=8eYGEFbpTWSOb|ND+F@=5GrCtUGO#`63Sq4ym{Q!$3kPnn+P|3(GsR-g=5d`vk zfaWFSRCuAZ60z@YU8D8DH;v7&$>jiH=@L3;s^uaK9Rn<^oH + + \ No newline at end of file diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf index 20417d579a7a9729a8f70b746c31f594a9113f88..3688063566de4eb2b801899d54439d5d96e93213 100755 GIT binary patch delta 400 zcmeB)o)9xZv0mibF9rri86b8^Pb@BAU|oB(j4hIm1zs^6^Q})84L{S4jHM5 zDeUL+@);O3R{-VBGJpc?2Uw(m{0Bh3N=9x;MHB~%AOnLI3(&lboc!d(ZLintV_?wE z0m^U7O{^$j$Y3aEV9-$k@)hzDb5kYcue^-|3b+6@tSZPaE@5B>N-^kun7HFCqsZho z#(q|Dpb+C^MJ9*I22AXm6PZlZ>X{fA{vTjrU_QXW#lQ>HsVJyuWM(R8qNdErD9Fh0 zpMjCVzp&7sk%0-Q<_|-mKU0H$;lBg_4lp$Ug)sCgsR8wx83XkKZ35~B>HW{}4^uBA zgYf^$%x@>p(U>E%UP<_HJipCX25z8df#6bv$afe$IYiT(F=}&Gv0mWXF9rri86b8^Pb@BAU|oB(j4hIm1&!;7Ulu@84L_+Co)nK zQ`om%>SbWiGyuw*WdH@(53ooA`9OIFm5khyiXaXaK_I^eXkJ22esbdC>X|tV3|eo1 z@|$uKD+(CW7|IzKv=;#R3VDgSsS@&6-o^n14gfW*D#$M`VPFPIG3e$@+;NssXmT54 zKdUHEh;gzalfz^KCicyVOeSiRmx|9(W&|o@VqiGfDqbGXZ}XLbn+2qi;gXL#8;qWO eM$?=zVl#_YJmchS?M<91Knakxh|O9$&lmxyfj^G` diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff index 879197340048aa1cb7be6f8142ee67d248d8d271..fb025033cb2b8d5dc41b4b6a81c4786e814bc036 100755 GIT binary patch delta 444 zcmcZ+eJ4h&+~3WOfsp|S^kNve!L$Ga)8s-Xv57jW^&;1Pr6(2_FfcH!0ZMT|u|RrG zWg1Xy3j>3?0|+m;S0t8^nwY}Cp!o%;#tekn&*kN300kKsv~+-c6%b}Wz#^TITT%fO z3t(Vi%mCpi4i>?j{A8dy?Hxch+dz2R>oxmw6DtaU8g+n{Gbn&@219vXVs0u>Yywc@ zDiD^x@;0s@zqkbGdYg%Vt}=>DzQowiD$c;nzzFn$&Ey6q?#*kNOw{U`7#RK^U}0cB zz`(`83)HD7sAyznDrlmn%*iOo$nYN+1pbAE{)`MvKsA3D3jLWH{0sjb_;-M*0Vsr_ zS4j=1*UT8G7ibeuH%RY)hJToP85xBCUuJ$g`Gv+Dne|G-hvWHezA|vL0R6+ja4ACM wJB*&ZK+~KtYV!@vc*e>4+PlO}goA_^03|^&6U9&pax)Ns;zf8fzs^ZU07@oqs{jB1 delta 319 zcmcZ;b0b=;+~3WOfsp|SbZ;#>jkd;N>3~M z4F(3r1P~75U=hs8PX?;fwg9Tx1j37}XXfN4Rut#}1>XP#6u>x*p*$}!H!$t}+TuzQowiD$2mjzzFn$&Ey6q?#*kNOw=ZS6rZCE@+A`k z!@*YZ@_2rmuMFHQKmi7ZOFr&wFnY3tmN{d@<^ZjD#>v~YHwgoM1P+`ChEfJzkRou< L2ydRObCMANY~@Sa From 92a3fa3e4c18ac2e55386e0018c75720243054a9 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 29 Oct 2015 16:40:51 -0700 Subject: [PATCH 07/62] Added error handling, and refactored CopyAction slightly --- .../notification/src/NotificationService.js | 6 +- .../src/actions/AbstractComposeAction.js | 10 +- .../entanglement/src/actions/CopyAction.js | 48 +++-- .../entanglement/src/services/CopyService.js | 190 +++++++++--------- 4 files changed, 137 insertions(+), 117 deletions(-) diff --git a/platform/commonUI/notification/src/NotificationService.js b/platform/commonUI/notification/src/NotificationService.js index 0e2be08626..d6fac910a7 100644 --- a/platform/commonUI/notification/src/NotificationService.js +++ b/platform/commonUI/notification/src/NotificationService.js @@ -52,7 +52,7 @@ define( * are used to inform users of events in a non-intrusive way. As * much as possible, notifications share a model with blocking * dialogs so that the same information can be provided in a dialog - * and then minimized to a banner notification if needed. + * and then minimized to a banner notification if needed, or vice-versa. * * @typedef {object} NotificationModel * @property {string} title The title of the message @@ -75,6 +75,7 @@ define( * @property {NotificationOption[]} options any additional * actions the user can take. Will be represented as additional buttons * that may or may not be available from a banner. + * @see DialogModel */ /** @@ -220,7 +221,8 @@ define( * @returns {Notification} the provided notification decorated with * functions to dismiss or minimize */ - NotificationService.prototype.info = function (notificationModel) { + NotificationService.prototype.info = function (model) { + var notificationModel = typeof model === "string" ? {title: model} : model notificationModel.autoDismiss = notificationModel.autoDismiss || true; notificationModel.severity = "info"; return this.notify(notificationModel); diff --git a/platform/entanglement/src/actions/AbstractComposeAction.js b/platform/entanglement/src/actions/AbstractComposeAction.js index 1ceb469591..5538eec3be 100644 --- a/platform/entanglement/src/actions/AbstractComposeAction.js +++ b/platform/entanglement/src/actions/AbstractComposeAction.js @@ -70,8 +70,12 @@ define( * @param {string} verb the verb to display for the action (e.g. "Move") * @param {string} [suffix] a string to display in the dialog title; * default is "to a new location" + * @param {function} progressCallback a callback function that will + * be invoked to update invoker on progress. This is optional and + * may not be implemented by all composing actions. The signature of + * the callback function will depend on the service being invoked. */ - function AbstractComposeAction(locationService, composeService, context, verb, suffix, progressCallback) { + function AbstractComposeAction(locationService, composeService, context, verb, suffix) { if (context.selectedObject) { this.newParent = context.domainObject; this.object = context.selectedObject; @@ -87,10 +91,9 @@ define( this.composeService = composeService; this.verb = verb || "Compose"; this.suffix = suffix || "to a new location"; - this.progressCallback = progressCallback; } - AbstractComposeAction.prototype.perform = function () { + AbstractComposeAction.prototype.perform = function (progressCallback) { var dialogTitle, label, validateLocation, @@ -98,7 +101,6 @@ define( composeService = this.composeService, currentParent = this.currentParent, newParent = this.newParent, - progressCallback = this.progressCallback, object = this.object; if (newParent) { diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index 2bbfbe1cee..ad8f41a323 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -35,43 +35,57 @@ define( * @memberof platform/entanglement */ function CopyAction(locationService, copyService, dialogService, notificationService, context) { - var notification, + this.dialogService = dialogService; + this.notificationService = notificationService; + AbstractComposeAction.call(this, locationService, copyService, context, "Duplicate", "to a location"); + } + + CopyAction.prototype = Object.create(AbstractComposeAction.prototype); + + CopyAction.prototype.perform = function() { + var self = this, + notification, notificationModel = { title: "Copying objects", unknownProgress: false, severity: "info", }; - + function progress(phase, totalObjects, processed){ if (phase.toLowerCase() === 'preparing'){ - dialogService.showBlockingMessage({ + self.dialogService.showBlockingMessage({ title: "Preparing to copy objects", unknownProgress: true, severity: "info", }); } else if (phase.toLowerCase() === "copying") { - dialogService.dismiss(); + self.dialogService.dismiss(); if (!notification) { - notification = notificationService.notify(notificationModel); + notification = self.notificationService.notify(notificationModel); } notificationModel.progress = (processed / totalObjects) * 100; - notificationModel.title = ["Copying ", processed, "of ", totalObjects, "objects"].join(" "); - if (processed >= totalObjects){ + notificationModel.title = ["Copied ", processed, "of ", totalObjects, "objects"].join(" "); + if (processed === totalObjects){ notification.dismiss(); + self.notificationService.info(["Successfully copied ", totalObjects, " items."].join("")); } } } - - return new AbstractComposeAction( - locationService, - copyService, - context, - "Duplicate", - "to a location", - progress - ); - } + AbstractComposeAction.prototype.perform.call(this, progress) + .then(function(){ + self.notificationService.info("Copying complete."); + }, + function (error){ + //log error + //Show more general error message + self.notificationService.notify({ + title: "Error copying objects.", + severity: "error", + hint: error.message + }); + }); + }; return CopyAction; } ); diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 36daad9e33..dbf25fbf97 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -55,85 +55,130 @@ define( object.getCapability('type') ); }; - - /** - * Will build a graph of an object and all of its composed objects in memory - * @private - * @param domainObject - */ - CopyService.prototype.buildCopyGraph = function(domainObject, parent) { - /* TODO: Use contextualized objects here. - Parent should be fully contextualized, and either the - original parent or a contextualized clone. The subsequent - composition changes can then be performed regardless of - whether it is the top level composition of the original - parent being updated, or of one of the cloned children. */ + /** + * Will build a graph of an object and all of its child objects in + * memory + * @param domainObject The original object to be copied + * @param parent The parent of the original object to be copied + * @returns {Promise} resolved with an array of clones of the models + * of the object tree being copied. Copying is done in a bottom-up + * fashion, so that the last member in the array is a clone of the model + * object being copied. The clones are all full composed with + * references to their own children. + */ + CopyService.prototype.buildCopyPlan = function(domainObject, parent) { var clones = [], $q = this.$q, self = this; - function clone(object) { + function makeClone(object) { return JSON.parse(JSON.stringify(object)); } - + + /** + * A recursive function that will perform a bottom-up copy of + * the object tree with originalObject at the root. Recurses to + * the farthest leaf, then works its way back up again, + * cloning objects, and composing them with their child clones + * as it goes + * @param originalObject + * @param originalParent + * @returns {*} + */ function copy(originalObject, originalParent) { - var modelClone = clone(originalObject.getModel()); + //Make a clone of the model of the object to be copied + var modelClone = makeClone(originalObject.getModel()); modelClone.composition = []; modelClone.id = uuid(); - - if (originalObject.hasCapability('composition')) { - return originalObject.useCapability('composition').then(function(composees){ - return composees.reduce(function(promise, composee){ + return $q.when(originalObject.useCapability('composition')).then(function(composees){ + return (composees || []).reduce(function(promise, composee){ + //If the object is composed of other + // objects, chain a promise.. return promise.then(function(){ + // ...to recursively copy it (and its children) return copy(composee, originalObject).then(function(composeeClone){ - /* - TODO: Use the composition capability for this. Just not sure how to contextualize the as-yet non-existent modelClone object. - */ + //Once copied, associate each cloned + // composee with its parent clone composeeClone.location = modelClone.id; return modelClone.composition.push(composeeClone.id); }); + });}, $q.when(undefined) + ).then(function (){ + //Add the clone to the list of clones that will + //be returned by this function + clones.push({ + model: modelClone, + persistenceSpace: originalParent.getCapability('persistence') }); - }, $q.when(undefined)).then(function (){ - /* Todo: Move this outside of promise and avoid - duplication below */ - clones.push({persistence: originalParent.getCapability('persistence'), model: modelClone}); return modelClone; }); - }); - } else { - clones.push({persistence: originalParent.getCapability('persistence'), model: modelClone}); - return $q.when(modelClone); - } + }); + }; return copy(domainObject, parent).then(function(){ return clones; }); } - function newPerform (domainObject, parent, progress) { + /** + * Will persist a list of {@link objectClones}. + * @private + * @param progress + * @returns {Function} a function that will perform the persistence + * with a progress callback curried into it. + */ + CopyService.prototype.persistObjects = function(progress) { + var persisted = 0, + self = this; + return function(objectClones) { + return self.$q.all(objectClones.map(function(clone, index){ + return self.persistenceService.createObject(clone.persistenceSpace, clone.model.id, clone.model) + .then(function(){ + progress("copying", objectClones.length, ++persisted); + }); + })).then(function(){ return objectClones}); + } + } + + /** + * Will add a list of clones to the specified parent's composition + * @private + * @param parent + * @param progress + * @returns {Function} + */ + CopyService.prototype.addClonesToParent = function(parent, progress) { + var self = this; + return function(clones) { + var parentClone = clones[clones.length-1]; + parentClone.model.location = parent.getId() + return self.$q.when( + parent.hasCapability('composition') && + parent.getCapability('composition').add(parentClone.model.id) + .then(function(){ + parent.getCapability("persistence").persist() + })); + } + } + + /** + * Creates a duplicate of the object tree starting at domainObject to + * the new parent specified. + * @param domainObject + * @param parent + * @param progress + * @returns a promise that will be completed when the duplication is + * successful, otherwise an error is thrown. + */ + CopyService.prototype.perform = function (domainObject, parent, progress) { var $q = this.$q, - processed = 0, self = this; if (this.validate(domainObject, parent)) { progress("preparing"); - return this.buildCopyGraph(domainObject, parent) - .then(function(clones){ - return $q.all(clones.map(function(clone, index){ - return self.persistenceService.createObject(clone.persistence.getSpace(), clone.model.id, clone.model).then(function(){progress("copying", clones.length, processed++);}); - })).then(function(){ return clones}); - }) - .then(function(clones) { - var parentClone = clones[clones.length-1]; - parentClone.model.location = parent.getId() - return $q.when( - parent.hasCapability('composition') && - parent.getCapability('composition').add(parentClone.model.id) - .then(function(){ - progress("copying", clones.length, clones.length); - parent.getCapability("persistence").persist() - })); - }); + return this.buildCopyPlan(domainObject, parent) + .then(self.persistObjects(progress)) + .then(self.addClonesToParent(parent, progress)); } else { throw new Error( "Tried to copy objects without validating first." @@ -141,49 +186,6 @@ define( } } - CopyService.prototype.perform = newPerform; - - function oldPerform (domainObject, parent) { - var model = JSON.parse(JSON.stringify(domainObject.getModel())), - $q = this.$q, - self = this; - - // Wrapper for the recursive step - function duplicateObject(domainObject, parent) { - return self.perform(domainObject, parent); - } - - if (!this.validate(domainObject, parent)) { - throw new Error( - "Tried to copy objects without validating first." - ); - } - - if (domainObject.hasCapability('composition')) { - model.composition = []; - } - - return this.creationService - .createObject(model, parent) - .then(function (newObject) { - if (!domainObject.hasCapability('composition')) { - return; - } - - return domainObject - .useCapability('composition') - .then(function (composees) { - // Duplicate composition serially to prevent - // write conflicts. - return composees.reduce(function (promise, composee) { - return promise.then(function () { - return duplicateObject(composee, newObject); - }); - }, $q.when(undefined)); - }); - }); - }; - return CopyService; } ); From 05722d9b1100f55b918cbcd5688d1294102558d9 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 29 Oct 2015 17:15:20 -0700 Subject: [PATCH 08/62] Added error handling --- platform/entanglement/bundle.json | 3 ++- platform/entanglement/src/actions/CopyAction.js | 9 +++++---- platform/entanglement/src/services/CopyService.js | 4 +++- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/platform/entanglement/bundle.json b/platform/entanglement/bundle.json index f8eed70030..192a132602 100644 --- a/platform/entanglement/bundle.json +++ b/platform/entanglement/bundle.json @@ -20,7 +20,8 @@ "glyph": "+", "category": "contextual", "implementation": "actions/CopyAction.js", - "depends": ["locationService", "copyService", "dialogService", "notificationService"] + "depends": ["$log", "locationService", "copyService", + "dialogService", "notificationService"] }, { "key": "link", diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index ad8f41a323..1fb8a29229 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -34,9 +34,10 @@ define( * @constructor * @memberof platform/entanglement */ - function CopyAction(locationService, copyService, dialogService, notificationService, context) { + function CopyAction($log, locationService, copyService, dialogService, notificationService, context) { this.dialogService = dialogService; this.notificationService = notificationService; + this.$log = $log; AbstractComposeAction.call(this, locationService, copyService, context, "Duplicate", "to a location"); } @@ -75,9 +76,9 @@ define( AbstractComposeAction.prototype.perform.call(this, progress) .then(function(){ self.notificationService.info("Copying complete."); - }, - function (error){ - //log error + }) + .catch(function (error){ + self.$log.error("Error copying objects. ", error); //Show more general error message self.notificationService.notify({ title: "Error copying objects.", diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index dbf25fbf97..ee22f592c1 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -122,7 +122,9 @@ define( } /** - * Will persist a list of {@link objectClones}. + * Will persist a list of {@link objectClones}. It will persist all + * simultaneously, irrespective of order in the list. This may + * result in automatic request batching by the browser. * @private * @param progress * @returns {Function} a function that will perform the persistence From f44819a7fe1603debbc9e0d62aa6c3ad17ffdafb Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 29 Oct 2015 17:40:17 -0700 Subject: [PATCH 09/62] Improvements to copy notifications --- platform/entanglement/src/actions/CopyAction.js | 5 +---- platform/entanglement/src/services/CopyService.js | 5 ++--- .../entanglement/test/actions/AbstractComposeActionSpec.js | 2 +- 3 files changed, 4 insertions(+), 8 deletions(-) diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index 1fb8a29229..a8dbf95d4c 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -66,15 +66,12 @@ define( } notificationModel.progress = (processed / totalObjects) * 100; notificationModel.title = ["Copied ", processed, "of ", totalObjects, "objects"].join(" "); - if (processed === totalObjects){ - notification.dismiss(); - self.notificationService.info(["Successfully copied ", totalObjects, " items."].join("")); - } } } AbstractComposeAction.prototype.perform.call(this, progress) .then(function(){ + notification.dismiss(); self.notificationService.info("Copying complete."); }) .catch(function (error){ diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index ee22f592c1..aaa3227f8c 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -114,7 +114,6 @@ define( return modelClone; }); }); - }; return copy(domainObject, parent).then(function(){ return clones; @@ -137,7 +136,7 @@ define( return self.$q.all(objectClones.map(function(clone, index){ return self.persistenceService.createObject(clone.persistenceSpace, clone.model.id, clone.model) .then(function(){ - progress("copying", objectClones.length, ++persisted); + progress && progress("copying", objectClones.length, ++persisted); }); })).then(function(){ return objectClones}); } @@ -177,7 +176,7 @@ define( var $q = this.$q, self = this; if (this.validate(domainObject, parent)) { - progress("preparing"); + progress && progress("preparing"); return this.buildCopyPlan(domainObject, parent) .then(self.persistObjects(progress)) .then(self.addClonesToParent(parent, progress)); diff --git a/platform/entanglement/test/actions/AbstractComposeActionSpec.js b/platform/entanglement/test/actions/AbstractComposeActionSpec.js index 5be0604ec3..b65e0569ff 100644 --- a/platform/entanglement/test/actions/AbstractComposeActionSpec.js +++ b/platform/entanglement/test/actions/AbstractComposeActionSpec.js @@ -140,7 +140,7 @@ define( .args[0](newParent); expect(composeService.perform) - .toHaveBeenCalledWith(selectedObject, newParent); + .toHaveBeenCalledWith(selectedObject, newParent, undefined); }); }); }); From 4eaeea1e1436d9ff2e5923b6974faebe6cc7db88 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Thu, 29 Oct 2015 21:39:50 -0700 Subject: [PATCH 10/62] Fixed bugs in copy --- .../entanglement/src/services/CopyService.js | 27 ++++++++++--------- 1 file changed, 15 insertions(+), 12 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index aaa3227f8c..d97ec4677b 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -89,7 +89,8 @@ define( function copy(originalObject, originalParent) { //Make a clone of the model of the object to be copied var modelClone = makeClone(originalObject.getModel()); - modelClone.composition = []; + delete modelClone.composition; + delete modelClone.location; modelClone.id = uuid(); return $q.when(originalObject.useCapability('composition')).then(function(composees){ return (composees || []).reduce(function(promise, composee){ @@ -101,6 +102,7 @@ define( //Once copied, associate each cloned // composee with its parent clone composeeClone.location = modelClone.id; + modelClone.composition = modelClone.composition || []; return modelClone.composition.push(composeeClone.id); }); });}, $q.when(undefined) @@ -153,13 +155,15 @@ define( var self = this; return function(clones) { var parentClone = clones[clones.length-1]; - parentClone.model.location = parent.getId() - return self.$q.when( - parent.hasCapability('composition') && - parent.getCapability('composition').add(parentClone.model.id) - .then(function(){ - parent.getCapability("persistence").persist() - })); + if (!parent.hasCapability('composition')){ + self.$q.reject(); + } + parentClone.model.location = parent.getId(); + + return self.persistenceService + .updateObject(parentClone.persistenceSpace, parentClone.model.id, parentClone.model) + .then(function(){return parent.getCapability('composition').add(parentClone.model.id)}) + .then(function(){return parent.getCapability("persistence").persist()}); } } @@ -173,13 +177,12 @@ define( * successful, otherwise an error is thrown. */ CopyService.prototype.perform = function (domainObject, parent, progress) { - var $q = this.$q, - self = this; + var $q = this.$q; if (this.validate(domainObject, parent)) { progress && progress("preparing"); return this.buildCopyPlan(domainObject, parent) - .then(self.persistObjects(progress)) - .then(self.addClonesToParent(parent, progress)); + .then(this.persistObjects(progress)) + .then(this.addClonesToParent(parent, progress)); } else { throw new Error( "Tried to copy objects without validating first." From e4a14b7603a9fe6266e9b04f18cd27e95bbf8b6f Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 30 Oct 2015 14:56:52 -0700 Subject: [PATCH 11/62] [Time Conductor] Consistently throttle broadcast Consistently throttle broadcast of bounds to minimize redundant broadcasts, nasa/openmctweb#229 --- platform/features/conductor/src/ConductorRepresenter.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/platform/features/conductor/src/ConductorRepresenter.js b/platform/features/conductor/src/ConductorRepresenter.js index 2d1bec36d8..8f893c4fb8 100644 --- a/platform/features/conductor/src/ConductorRepresenter.js +++ b/platform/features/conductor/src/ConductorRepresenter.js @@ -103,7 +103,7 @@ define( var newDomain = conductor.domain(value); conductorScope.parameters.format = newDomain && newDomain.format; - repScope.$broadcast('telemetry:display:bounds', bounds()); + broadcastBounds(); } // telemetry domain metadata -> option for a select control @@ -141,7 +141,7 @@ define( conductorScope .$watch('ngModel.domain', updateDomain); - repScope.$on('telemetry:view', updateConductorInner); + repScope.$on('telemetry:view', broadcastBounds); }; ConductorRepresenter.prototype.conductorScope = function (s) { From f7f6b8d61281013b5563730fc82d8411c29fb36a Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 30 Oct 2015 14:59:32 -0700 Subject: [PATCH 12/62] [Time Conductor] Don't broadcast on telemetry:view Instead, use delay from throttling initial bounds broadcast to avoid broadcasting bounds prematurely. --- platform/features/conductor/src/ConductorRepresenter.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/platform/features/conductor/src/ConductorRepresenter.js b/platform/features/conductor/src/ConductorRepresenter.js index 8f893c4fb8..4b8e848a48 100644 --- a/platform/features/conductor/src/ConductorRepresenter.js +++ b/platform/features/conductor/src/ConductorRepresenter.js @@ -140,8 +140,6 @@ define( .$watch('ngModel.conductor.inner.end', updateConductorInner); conductorScope .$watch('ngModel.domain', updateDomain); - - repScope.$on('telemetry:view', broadcastBounds); }; ConductorRepresenter.prototype.conductorScope = function (s) { From 91a4138334924d92b977645622dda2809ea6ab42 Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Mon, 2 Nov 2015 10:14:28 -0800 Subject: [PATCH 13/62] Added crosshair symbol for inspect prod-uisymbols open #90 --- .../icomoon.io-WTD-symbols-project.json | 205 ++++++++++-------- .../general/res/fonts/symbols/wtdsymbols.eot | Bin 11968 -> 12192 bytes .../general/res/fonts/symbols/wtdsymbols.svg | 1 + .../general/res/fonts/symbols/wtdsymbols.ttf | Bin 11792 -> 12016 bytes .../general/res/fonts/symbols/wtdsymbols.woff | Bin 11868 -> 12092 bytes 5 files changed, 118 insertions(+), 88 deletions(-) diff --git a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json index ef3c1beecf..a90e5159c0 100644 --- a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json +++ b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json @@ -1,19 +1,27 @@ { "metadata": { "name": "WTD Symbols", - "lastOpened": 1446143042082, - "created": 1446143040164 + "lastOpened": 1446487783771, + "created": 1446487781767 }, "iconSets": [ { "selection": [ + { + "order": 112, + "id": 92, + "prevSize": 32, + "code": 58901, + "name": "icon-crosshair", + "tempChar": "" + }, { "order": 110, "id": 91, "prevSize": 32, "code": 58899, "name": "icon-collapse-pane-left", - "tempChar": "" + "tempChar": "" }, { "order": 111, @@ -21,7 +29,7 @@ "prevSize": 32, "code": 58900, "name": "icon-collapse-pane-right", - "tempChar": "" + "tempChar": "" }, { "order": 109, @@ -29,7 +37,7 @@ "prevSize": 32, "code": 58898, "name": "icon-save", - "tempChar": "" + "tempChar": "" }, { "order": 108, @@ -37,7 +45,7 @@ "prevSize": 32, "code": 58897, "name": "icon-dataset", - "tempChar": "" + "tempChar": "" }, { "order": 90, @@ -45,7 +53,7 @@ "prevSize": 32, "code": 58896, "name": "icon-bell", - "tempChar": "" + "tempChar": "" }, { "order": 91, @@ -53,7 +61,7 @@ "prevSize": 32, "code": 58889, "name": "icon-hourglass", - "tempChar": "" + "tempChar": "" }, { "order": 92, @@ -66,7 +74,7 @@ 58890 ], "name": "icon-info-v15", - "tempChar": "" + "tempChar": "" }, { "order": 93, @@ -74,7 +82,7 @@ "prevSize": 32, "code": 58887, "name": "icon-x-in-circle", - "tempChar": "" + "tempChar": "" }, { "order": 94, @@ -82,7 +90,7 @@ "prevSize": 32, "code": 58881, "name": "icon-datatable", - "tempChar": "" + "tempChar": "" }, { "order": 95, @@ -90,7 +98,7 @@ "prevSize": 32, "code": 58882, "name": "icon-tabular-scrolling", - "tempChar": "" + "tempChar": "" }, { "order": 96, @@ -98,7 +106,7 @@ "prevSize": 32, "code": 58884, "name": "icon-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 97, @@ -106,7 +114,7 @@ "prevSize": 32, "code": 58885, "name": "icon-calendar", - "tempChar": "" + "tempChar": "" }, { "order": 98, @@ -114,7 +122,7 @@ "prevSize": 32, "code": 58886, "name": "icon-paint-bucket", - "tempChar": "" + "tempChar": "" }, { "order": 99, @@ -122,7 +130,7 @@ "prevSize": 32, "code": 123, "name": "icon-pointer-left", - "tempChar": "" + "tempChar": "" }, { "order": 100, @@ -130,7 +138,7 @@ "prevSize": 32, "code": 125, "name": "icon-pointer-right", - "tempChar": "" + "tempChar": "" }, { "order": 101, @@ -138,7 +146,7 @@ "prevSize": 32, "code": 80, "name": "icon-person", - "tempChar": "" + "tempChar": "" }, { "order": 102, @@ -146,7 +154,7 @@ "prevSize": 32, "code": 232, "name": "icon-chain-links", - "tempChar": "" + "tempChar": "" }, { "order": 103, @@ -154,7 +162,7 @@ "prevSize": 32, "code": 115, "name": "icon-database-in-brackets", - "tempChar": "" + "tempChar": "" }, { "order": 104, @@ -162,7 +170,7 @@ "prevSize": 32, "code": 114, "name": "icon-refresh", - "tempChar": "" + "tempChar": "" }, { "order": 105, @@ -170,7 +178,7 @@ "prevSize": 32, "code": 108, "name": "icon-lock", - "tempChar": "" + "tempChar": "" }, { "order": 106, @@ -178,7 +186,7 @@ "prevSize": 32, "code": 51, "name": "icon-box-with-dashed-lines", - "tempChar": "" + "tempChar": "" }, { "order": 10, @@ -186,7 +194,7 @@ "prevSize": 32, "code": 58880, "name": "icon-box-with-arrow-cursor", - "tempChar": "" + "tempChar": "" }, { "order": 11, @@ -194,7 +202,7 @@ "prevSize": 32, "code": 65, "name": "icon-activity-mode", - "tempChar": "" + "tempChar": "" }, { "order": 12, @@ -202,7 +210,7 @@ "prevSize": 32, "code": 97, "name": "icon-activity", - "tempChar": "" + "tempChar": "" }, { "order": 87, @@ -210,7 +218,7 @@ "prevSize": 32, "code": 33, "name": "icon-alert-rect", - "tempChar": "" + "tempChar": "" }, { "order": 14, @@ -218,7 +226,7 @@ "prevSize": 32, "code": 58883, "name": "icon-alert-triangle", - "tempChar": "" + "tempChar": "" }, { "order": 15, @@ -226,7 +234,7 @@ "prevSize": 32, "code": 238, "name": "icon-arrow-double-down", - "tempChar": "" + "tempChar": "" }, { "order": 16, @@ -234,7 +242,7 @@ "prevSize": 32, "code": 235, "name": "icon-arrow-double-up", - "tempChar": "" + "tempChar": "" }, { "order": 2, @@ -242,7 +250,7 @@ "prevSize": 32, "code": 118, "name": "icon-arrow-down", - "tempChar": "" + "tempChar": "" }, { "order": 19, @@ -250,7 +258,7 @@ "prevSize": 32, "code": 60, "name": "icon-arrow-left", - "tempChar": "" + "tempChar": "" }, { "order": 20, @@ -258,7 +266,7 @@ "prevSize": 32, "code": 62, "name": "icon-arrow-right", - "tempChar": "" + "tempChar": "" }, { "order": 21, @@ -266,7 +274,7 @@ "prevSize": 32, "code": 236, "name": "icon-arrow-tall-down", - "tempChar": "" + "tempChar": "" }, { "order": 22, @@ -274,7 +282,7 @@ "prevSize": 32, "code": 237, "name": "icon-arrow-tall-up", - "tempChar": "" + "tempChar": "" }, { "order": 23, @@ -282,7 +290,7 @@ "prevSize": 32, "code": 94, "name": "icon-arrow-up", - "tempChar": "" + "tempChar": "" }, { "order": 24, @@ -290,7 +298,7 @@ "prevSize": 32, "code": 73, "name": "icon-arrows-out", - "tempChar": "" + "tempChar": "" }, { "order": 25, @@ -298,7 +306,7 @@ "prevSize": 32, "code": 58893, "name": "icon-arrows-right-left", - "tempChar": "" + "tempChar": "" }, { "order": 33, @@ -306,7 +314,7 @@ "prevSize": 32, "code": 53, "name": "icon-arrows-up-down", - "tempChar": "" + "tempChar": "" }, { "order": 26, @@ -314,7 +322,7 @@ "prevSize": 32, "code": 42, "name": "icon-asterisk", - "tempChar": "" + "tempChar": "" }, { "order": 27, @@ -322,7 +330,7 @@ "prevSize": 32, "code": 72, "name": "icon-autoflow-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 28, @@ -330,7 +338,7 @@ "prevSize": 32, "code": 224, "name": "icon-box", - "tempChar": "" + "tempChar": "" }, { "order": 29, @@ -338,7 +346,7 @@ "prevSize": 32, "code": 50, "name": "icon-check", - "tempChar": "" + "tempChar": "" }, { "order": 30, @@ -346,7 +354,7 @@ "prevSize": 32, "code": 67, "name": "icon-clock", - "tempChar": "" + "tempChar": "" }, { "order": 31, @@ -354,7 +362,7 @@ "prevSize": 32, "code": 46, "name": "icon-connectivity", - "tempChar": "" + "tempChar": "" }, { "order": 32, @@ -362,7 +370,7 @@ "prevSize": 32, "code": 100, "name": "icon-database-query", - "tempChar": "" + "tempChar": "" }, { "order": 17, @@ -370,7 +378,7 @@ "prevSize": 32, "code": 68, "name": "icon-database", - "tempChar": "" + "tempChar": "" }, { "order": 35, @@ -378,7 +386,7 @@ "prevSize": 32, "code": 81, "name": "icon-dictionary", - "tempChar": "" + "tempChar": "" }, { "order": 36, @@ -386,7 +394,7 @@ "prevSize": 32, "code": 242, "name": "icon-duplicate", - "tempChar": "" + "tempChar": "" }, { "order": 37, @@ -394,7 +402,7 @@ "prevSize": 32, "code": 102, "name": "icon-folder-new", - "tempChar": "" + "tempChar": "" }, { "order": 38, @@ -402,7 +410,7 @@ "prevSize": 32, "code": 70, "name": "icon-folder", - "tempChar": "" + "tempChar": "" }, { "order": 39, @@ -410,7 +418,7 @@ "prevSize": 32, "code": 95, "name": "icon-fullscreen-collapse", - "tempChar": "" + "tempChar": "" }, { "order": 40, @@ -418,7 +426,7 @@ "prevSize": 32, "code": 122, "name": "icon-fullscreen-expand", - "tempChar": "" + "tempChar": "" }, { "order": 41, @@ -426,7 +434,7 @@ "prevSize": 32, "code": 71, "name": "icon-gear", - "tempChar": "" + "tempChar": "" }, { "order": 49, @@ -434,7 +442,7 @@ "prevSize": 32, "code": 227, "name": "icon-image", - "tempChar": "" + "tempChar": "" }, { "order": 42, @@ -442,7 +450,7 @@ "prevSize": 32, "code": 225, "name": "icon-layers", - "tempChar": "" + "tempChar": "" }, { "order": 43, @@ -450,7 +458,7 @@ "prevSize": 32, "code": 76, "name": "icon-layout", - "tempChar": "" + "tempChar": "" }, { "order": 44, @@ -458,7 +466,7 @@ "prevSize": 32, "code": 226, "name": "icon-line-horz", - "tempChar": "" + "tempChar": "" }, { "order": 75, @@ -466,7 +474,7 @@ "prevSize": 32, "code": 244, "name": "icon-link", - "tempChar": "" + "tempChar": "" }, { "order": 46, @@ -474,7 +482,7 @@ "prevSize": 32, "code": 88, "name": "icon-magnify-in", - "tempChar": "" + "tempChar": "" }, { "order": 47, @@ -482,7 +490,7 @@ "prevSize": 32, "code": 89, "name": "icon-magnify-out", - "tempChar": "" + "tempChar": "" }, { "order": 48, @@ -490,7 +498,7 @@ "prevSize": 32, "code": 77, "name": "icon-magnify", - "tempChar": "" + "tempChar": "" }, { "order": 34, @@ -498,7 +506,7 @@ "prevSize": 32, "code": 109, "name": "icon-menu", - "tempChar": "" + "tempChar": "" }, { "order": 50, @@ -506,7 +514,7 @@ "prevSize": 32, "code": 243, "name": "icon-move", - "tempChar": "" + "tempChar": "" }, { "order": 51, @@ -514,7 +522,7 @@ "prevSize": 32, "code": 121, "name": "icon-new-window", - "tempChar": "" + "tempChar": "" }, { "order": 52, @@ -522,7 +530,7 @@ "prevSize": 32, "code": 111, "name": "icon-object", - "tempChar": "" + "tempChar": "" }, { "order": 73, @@ -530,7 +538,7 @@ "prevSize": 32, "code": 63, "name": "icon-object-unknown", - "tempChar": "" + "tempChar": "" }, { "order": 53, @@ -538,7 +546,7 @@ "prevSize": 32, "code": 86, "name": "icon-packet", - "tempChar": "" + "tempChar": "" }, { "order": 54, @@ -546,7 +554,7 @@ "prevSize": 32, "code": 234, "name": "icon-page", - "tempChar": "" + "tempChar": "" }, { "order": 55, @@ -554,7 +562,7 @@ "prevSize": 32, "code": 241, "name": "icon-pause", - "tempChar": "" + "tempChar": "" }, { "order": 56, @@ -562,7 +570,7 @@ "prevSize": 32, "code": 112, "name": "icon-pencil", - "tempChar": "" + "tempChar": "" }, { "order": 65, @@ -570,7 +578,7 @@ "prevSize": 32, "code": 79, "name": "icon-people", - "tempChar": "" + "tempChar": "" }, { "order": 57, @@ -578,7 +586,7 @@ "prevSize": 32, "code": 239, "name": "icon-play", - "tempChar": "" + "tempChar": "" }, { "order": 58, @@ -586,7 +594,7 @@ "prevSize": 32, "code": 233, "name": "icon-plot-resource", - "tempChar": "" + "tempChar": "" }, { "order": 59, @@ -594,7 +602,7 @@ "prevSize": 32, "code": 43, "name": "icon-plus", - "tempChar": "" + "tempChar": "" }, { "order": 60, @@ -602,7 +610,7 @@ "prevSize": 32, "code": 45, "name": "icon-minus", - "tempChar": "" + "tempChar": "" }, { "order": 61, @@ -610,7 +618,7 @@ "prevSize": 32, "code": 54, "name": "icon-sine", - "tempChar": "" + "tempChar": "" }, { "order": 62, @@ -618,7 +626,7 @@ "prevSize": 32, "code": 228, "name": "icon-T", - "tempChar": "" + "tempChar": "" }, { "order": 63, @@ -626,7 +634,7 @@ "prevSize": 32, "code": 116, "name": "icon-telemetry-panel", - "tempChar": "" + "tempChar": "" }, { "order": 64, @@ -634,7 +642,7 @@ "prevSize": 32, "code": 84, "name": "icon-telemetry", - "tempChar": "" + "tempChar": "" }, { "order": 18, @@ -642,7 +650,7 @@ "prevSize": 32, "code": 246, "name": "icon-thumbs-strip", - "tempChar": "" + "tempChar": "" }, { "order": 67, @@ -650,7 +658,7 @@ "prevSize": 32, "code": 83, "name": "icon-timeline", - "tempChar": "" + "tempChar": "" }, { "order": 68, @@ -658,7 +666,7 @@ "prevSize": 32, "code": 245, "name": "icon-timer", - "tempChar": "" + "tempChar": "" }, { "order": 69, @@ -666,7 +674,7 @@ "prevSize": 32, "code": 90, "name": "icon-trash", - "tempChar": "" + "tempChar": "" }, { "order": 70, @@ -674,7 +682,7 @@ "prevSize": 32, "code": 229, "name": "icon-two-parts-both", - "tempChar": "" + "tempChar": "" }, { "order": 71, @@ -682,7 +690,7 @@ "prevSize": 32, "code": 231, "name": "icon-two-parts-one-only", - "tempChar": "" + "tempChar": "" }, { "order": 72, @@ -690,7 +698,7 @@ "prevSize": 32, "code": 120, "name": "icon-x-heavy", - "tempChar": "" + "tempChar": "" }, { "order": 66, @@ -698,7 +706,7 @@ "prevSize": 32, "code": 58946, "name": "icon-x", - "tempChar": "" + "tempChar": "" } ], "id": 2, @@ -713,6 +721,27 @@ "height": 1024, "prevSize": 32, "icons": [ + { + "id": 92, + "paths": [ + "M512 0c-282.8 0-512 229.2-512 512s229.2 512 512 512 512-229.2 512-512-229.2-512-512-512zM576 825.6v-121.6c0-35.4-28.6-64-64-64s-64 28.6-64 64v121.6c-61-12.4-117.2-42.2-162.2-87.4-45-45-75-101.2-87.4-162.2h121.6c35.4 0 64-28.6 64-64s-28.6-64-64-64h-121.6c12.4-61 42.2-117.2 87.4-162.2 45-45 101.2-75 162.2-87.4v121.6c0 35.4 28.6 64 64 64s64-28.6 64-64v-121.6c61 12.4 117.2 42.2 162.2 87.4 45 45 75 101.2 87.4 162.2h-121.6c-35.4 0-64 28.6-64 64s28.6 64 64 64h121.6c-12.4 61-42.2 117.2-87.4 162.2-45 45.2-101.2 75-162.2 87.4z" + ], + "attrs": [ + { + "fill": "rgb(0, 0, 0)" + } + ], + "isMulticolor": false, + "grid": 0, + "tags": [ + "icon-crosshair" + ], + "colorPermutations": { + "125525525516161751": [ + 0 + ] + } + }, { "id": 91, "paths": [ diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot index 7a2163d74a62a3ce83d29f4f6aa07a885b6b4af8..df69093ccd096b13014d13185ba77f1ffd212cc7 100755 GIT binary patch delta 513 zcmX>QyC9x*fj$Gnhl#A_EU}A@y_)FIT+hM4z_1616OwZi3oeUY`^CV(C50V! zKyd*E2Bric&5@o{nfC8qZxoQ9!N8y)laZR3!hYjRFav{D3sBxH11P|LfCZ>m3uK;3 zMs7((90!XakpBQ^UQSMaa^iOG17{c*bbNsFJ8}~%3K%l=7|IzKbXkA`3VDgSsq$Ce z#sT>%Kn<%3@{3Ctn1M13dKWIRrP|DlytbN zq*Ya=tGINOB9(&lum}T1nGYcA1)1^Z7+f1pT?n%#2TCkZW&{QT(1)*%EsBljxB1Gz s4GJ{|hD)*GFJbiL8ZC3i=*?TS(ita<>+Iq@Ai~E0(iXk>md-Oq05tV|-2eap delta 288 zcmZ1we;}6ifF1*bz(iJamcznI>nA!i*RwM)Fzf;1gyh`Bg3BV;elajG$^fxTdSY<_ zP+Wk4fhhqLyw`Hfk8(FD4>v+n42np zCB+tOi{BCjq<55PD$!1Lbtl~g9#>p3%940?tV&5#t zyhd&EOs&N->y?BL$Mf5KW#9(d3IvxTM83o5$r0M-j8U5>Xs0ty{;ji(a{*9-5s0HU J@6vt72mtb(Ofdie diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg index 59762c9d86..ff7ada3a67 100755 --- a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg +++ b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg @@ -92,5 +92,6 @@ + \ No newline at end of file diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf index 3688063566de4eb2b801899d54439d5d96e93213..970147a9339c7427f7461c2b240341c93c0557d1 100755 GIT binary patch delta 514 zcmbOb^C7mLfsuiMft#U$ftkU;KUm*L=n6XrP-G7fCnV=47F-s)_KSgmQ3i-z(i4jd zfZ_rS3`_|?nj<}@GVR~J-Y6hHgMmRqCL=X5h5g2tU5dGRR#IQB|wJ)f$j&8JOeZHyNL&mGKx%YW9(-Y2TCzcR%CLRY{106Igx3N z+T@p-i)Gd;2_KH&YNV_E}L%K^m#={c2YK(Q?h3>q>Z{O?|GR7PrI3Il`I1)v%;5N5yeB{%~p$iSct z(x(E#><3t6GIC2QfMPm8^K(Erj)O%oCqEge&QE6sP|*$$-p+mCOm1QY&|=*HAYTED zGa1VB5_405VnA`mRUj;X*`_j>*(Sk4ahB)I?2LiA|PKk5L_n zjE&5I0@{prjOIWjDk26Huw|5E6bB-pGN6DpBOfC>5HT@i?d}c;=-!prZb0!psMd^@7a!a}0|%G+hWQCchP5pv(yLJQD-Mt7D5| z#%o(FM2WX`;PTs7&OZb2YA2>}!Gn6v$f>nc3gz)Cc HIwu(cM(%!e delta 354 zcmdlJcPB=y+~3WOfsp|S^kNve!L$Ga)8s-Xv57ju_3X*Hi3JP{j2S@e0>YO?uKh|+ zECz}(tpO_LfMS94oXRwy*cJu`bq5e$aIZ)#BQ-IFfkE>NP>mS~v!Bb$&j1QCFlgxj z`6?jHet<8*% z<#~y@sX(y_K+UT_SpLe}xPtuR5}y?BL$Mf5KW#DE33NSESiV*n@qbGmSGG~n1tfQUI fIC;9xHsJ+836QoZhEfJzkRovC32!deJ;?|FtR_%M From 946a6d4a041c5570c325b722e7e220ab47d00d79 Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Mon, 2 Nov 2015 11:04:38 -0800 Subject: [PATCH 14/62] Updated crosshair symbol for inspect open #90 --- .../icomoon.io-WTD-symbols-project.json | 8 ++++---- .../general/res/fonts/symbols/wtdsymbols.eot | Bin 12192 -> 12164 bytes .../general/res/fonts/symbols/wtdsymbols.svg | 2 +- .../general/res/fonts/symbols/wtdsymbols.ttf | Bin 12016 -> 11988 bytes .../general/res/fonts/symbols/wtdsymbols.woff | Bin 12092 -> 12064 bytes 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json index a90e5159c0..489d491fd2 100644 --- a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json +++ b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json @@ -1,14 +1,14 @@ { "metadata": { "name": "WTD Symbols", - "lastOpened": 1446487783771, - "created": 1446487781767 + "lastOpened": 1446490786311, + "created": 1446489891263 }, "iconSets": [ { "selection": [ { - "order": 112, + "order": 113, "id": 92, "prevSize": 32, "code": 58901, @@ -724,7 +724,7 @@ { "id": 92, "paths": [ - "M512 0c-282.8 0-512 229.2-512 512s229.2 512 512 512 512-229.2 512-512-229.2-512-512-512zM576 825.6v-121.6c0-35.4-28.6-64-64-64s-64 28.6-64 64v121.6c-61-12.4-117.2-42.2-162.2-87.4-45-45-75-101.2-87.4-162.2h121.6c35.4 0 64-28.6 64-64s-28.6-64-64-64h-121.6c12.4-61 42.2-117.2 87.4-162.2 45-45 101.2-75 162.2-87.4v121.6c0 35.4 28.6 64 64 64s64-28.6 64-64v-121.6c61 12.4 117.2 42.2 162.2 87.4 45 45 75 101.2 87.4 162.2h-121.6c-35.4 0-64 28.6-64 64s28.6 64 64 64h121.6c-12.4 61-42.2 117.2-87.4 162.2-45 45.2-101.2 75-162.2 87.4z" + "M514 2c-282.8 0-512 229.2-512 512s229.2 512 512 512 512-229.2 512-512-229.2-512-512-512zM860.2 450h-282.2v-282.2c69.6 12.8 133.8 46.2 185 97.4 51 51 84.4 115.2 97.2 184.8zM450 167.8v282.2h-282.2c12.8-69.6 46.2-133.8 97.4-185 51-51 115.2-84.4 184.8-97.2zM167.8 578h282.2v282.2c-69.6-12.8-133.8-46.2-185-97.4-51-51-84.4-115.2-97.2-184.8zM578 860.2v-282.2h282.2c-12.8 69.6-46.2 133.8-97.4 185-51 51-115.2 84.4-184.8 97.2z" ], "attrs": [ { diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot index df69093ccd096b13014d13185ba77f1ffd212cc7..43192b87f77505cea5f0ebfa6831f5451609fb02 100755 GIT binary patch delta 414 zcmZ1w-xAN-qR+r^Wg@FN%U!!j?uiZ?>fg=NKOkuyx^^k!<3&>|M z%K!?nA7+sP@)rR4DjB&Y6>%Ia!a)8J1_s8Qoc!d(ZGR8!V_?uR0Lt&kO{^$j$Ydx7 z@?QY?3VDgSsq$Ce#xXGHasbt@D#$M`VPFQzFz9Uo$ulrBZ_a1*)2L@;WK3NbgiXI+>v&7FTo59S}hC= z3}zWX0rmqdGC=+wAYUaTx1=JDgGCU?f55=Nn3I#AoVcC)z!?Sx9Uq|lj@-nG0)|Y6 zas~!n79d|CFEKY&{>s}pAYTQjepNw!aR~!6P=-P80!W^LnR#8 z2N*;ce1R&J_?SdR - + \ No newline at end of file diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf index 970147a9339c7427f7461c2b240341c93c0557d1..0bb5126e8ab0b74bbef524f347803d4109412a19 100755 GIT binary patch delta 398 zcmewmdnI;)L;bsXnp_MFOc@Le8Vnh!i7D*2xgIhwXaV^QW*I;M_QNbvK>h+CUnL{A zq#}-kMHt9G!oa|olarsExb5$OeGCjb20-~8xrr4844Dk&K>iCLUm-6sH&y=1+c*XW zT@Il7RR#IQB@E0!83w&AAbAF6=8gOPH0oIynEvl$VPf9LAi^NapvIujU;$LF#K$Bm zBFAKGWXEJ`qQ|7ns3<7MC=Nu7f{J#G=0F4#(PLBxBA^H#BRdc=F=g%U4hZPpodu&A zqy9ZJiC0rI;{2EP?-{3&np(Wczh{h65HZGCj8dHTU_s`6$l5^K|2Y69!E%gJ_zao+ zTyv=scck6jcz&C&4BRXr4>DYeO*Vwl|Nnu!H+h|w49ow2EKHlvX;m^ZGEMf-*~z>~ Lgkdv_?i)q`08nnM delta 454 zcmcZ-`yqCML;b&dy-^GdOc@Le8ZsHFi7D(iz63KcXtgjfFqmZk1=tU;$N>3!fP9sV z+>(ko4i-Tm{{aI7V@^(fa^iOG17{c*bbNsFJ8}~%3K%jO${84RS%7?nyu{p8`73YZ zfP598`c(z_#U%{PKp6(T3m|z0X6B9i{WR*C7#RK^U}0cBz#zil3sk7Y$0RBu$7F0| z$7E`v$D}N5YNDpB#3swA$EXfO#ztm90c}P*Mspw%6%hjp*fPp7iUSc)8BoBQk&lrb zh?p3%c6SE^bnniB(GIH8(yDqvN=iChRnn@e(p6kKN|8!IdRT;kqRa=7^@7a!a}2Hx zr!It9lNX9F@MHvf73jlP#}>uL^V@u7;0A>a1H+}*@Ru<9|39$*j{x}`Ahlos)W>|_ j{{aRD7KZ=-K;-64T9u5943l+qb}}Cj;oJN|=M5tOK(22M diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff index 1a4784a8b5bf0c7394e304f6ef9daac70457cecc..0b1935282d656f909ad4d8c68577fc097dd986b2 100755 GIT binary patch delta 444 zcmdlJw;)ce+~3WOfsp|S^c5JmLA2f#2Byh{Okxvt-0Oi{4Tg8~G`TWT6H^!%w6*{R z%s`m^HrK-ppde7}4Un$_!t94xq%v|#Di|2F1sE6@b3izbgGD$eKN+Y_rv|8I2MBNb zdthH~VnqQ1gRTjXuK>oG4CQ%=xv4<05TL$QAS{1{>up>?esKxVZ44X##A?*DGBEw$ z$HK(Ck3ob%mO%|DYyniL#K$BmBFAKGWXEJ`qQ|7ns3<7MC=Nu7f{J#G=0F4#(PLBx zBA^H#BRdc=F=g%U4hZPpodu&Aqy9ZJiC0rI;{2EP?-{3&np(Wczh{h65HZGCj8dHT zU_s`6$l5^K|2Y69!E%gJ_zao+UVNS=D6E+n7`P+t?#A=md}ZKf0SYiMT#8LLgwg;1 lfqXgnmzE66|9>n@o29fX85x--Ptn=Qyh(&%bAav}MgVlIbE^OV delta 464 zcmZ1wwe% zls5xm_8VV*gFy?@890!YFPJS{_oz4uPnjIj# zo%_I<+{B6k1_s>#AYTEDGa1VB5_405VnA`mRUj;Xh3joxL4I)w&}}js|HNucmeu5{ z7h&)PN-FU&iHgWE85`L#nVRS^DGQsLs3|M4$ujCOssoX+kr_}xo6(NZ9Ee0k#DD^} zjB Date: Tue, 3 Nov 2015 15:24:38 -0800 Subject: [PATCH 15/62] [Time Conductor] Cancel requests Don't callback for any telemetry requests from a TelemetryHandle if the handle has been destroyed. --- platform/telemetry/src/TelemetryHandle.js | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/platform/telemetry/src/TelemetryHandle.js b/platform/telemetry/src/TelemetryHandle.js index ff77d7b9e0..11fd05bb90 100644 --- a/platform/telemetry/src/TelemetryHandle.js +++ b/platform/telemetry/src/TelemetryHandle.js @@ -39,6 +39,7 @@ define( */ function TelemetryHandle($q, subscription) { var seriesMap = {}, + active = true, self = Object.create(subscription); // Request a telemetry series for this specific object @@ -50,7 +51,7 @@ define( // Store it for subsequent lookup seriesMap[id] = series; // Notify callback of new series data, if there is one - if (callback) { + if (callback && active) { callback(telemetryObject, series); } // Pass it along for promise-chaining @@ -61,6 +62,10 @@ define( return telemetry.requestData(request).then(receiveSeries); } + self.unsubscribe = function () { + active = false; + return subscription.unsubscribe(); + }; /** * Get the most recently obtained telemetry data series associated From df484c18008becf57601eaf2eae7d3a37d52b15b Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Tue, 3 Nov 2015 15:27:08 -0800 Subject: [PATCH 16/62] [Time Conductor] Update TelemetryHandler spec --- platform/telemetry/test/TelemetryHandleSpec.js | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/platform/telemetry/test/TelemetryHandleSpec.js b/platform/telemetry/test/TelemetryHandleSpec.js index 2e34b8dcd3..8e543d21dd 100644 --- a/platform/telemetry/test/TelemetryHandleSpec.js +++ b/platform/telemetry/test/TelemetryHandleSpec.js @@ -85,10 +85,18 @@ define( it("exposes subscription API", function () { // Should still expose methods from the provided subscription - expect(handle.unsubscribe) - .toBe(mockSubscription.unsubscribe); - expect(handle.getTelemetryObjects) - .toBe(mockSubscription.getTelemetryObjects); + // (though these may have been wrapped) + expect(mockSubscription.getTelemetryObjects) + .not.toHaveBeenCalled(); + handle.getTelemetryObjects(); + expect(mockSubscription.getTelemetryObjects) + .toHaveBeenCalled(); + + expect(mockSubscription.unsubscribe) + .not.toHaveBeenCalled(); + handle.unsubscribe(); + expect(mockSubscription.unsubscribe) + .toHaveBeenCalled(); }); it("provides an interface for historical requests", function () { From ac529be55c88c9afb0fecf861ee69df39daed511 Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Tue, 3 Nov 2015 17:01:22 -0800 Subject: [PATCH 17/62] [Time Conductor] Don't emit view event Don't emit an event when plot is instantiated; this is no longer needed, as time conductor broadcasts its bounds whenever views change. --- platform/features/plot/src/PlotController.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/platform/features/plot/src/PlotController.js b/platform/features/plot/src/PlotController.js index d6acdb6a5c..cf6bfcf581 100644 --- a/platform/features/plot/src/PlotController.js +++ b/platform/features/plot/src/PlotController.js @@ -245,9 +245,6 @@ define( // Unsubscribe when the plot is destroyed $scope.$on("$destroy", releaseSubscription); - - // Notify any external observers that a new telemetry view is here - $scope.$emit("telemetry:view"); } /** From 226f0932dafa6e4ae72b52a8b1bc8866ef1acd0e Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Wed, 4 Nov 2015 11:46:49 -0800 Subject: [PATCH 18/62] [Themes] Add test cases Add test cases to verify that stylesheets are excluded/included according to theme, when a theme has been specified. nasa/openmctweb#241 --- .../general/test/StyleSheetLoaderSpec.js | 37 ++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/platform/commonUI/general/test/StyleSheetLoaderSpec.js b/platform/commonUI/general/test/StyleSheetLoaderSpec.js index b2c1a7da93..8a679004d8 100644 --- a/platform/commonUI/general/test/StyleSheetLoaderSpec.js +++ b/platform/commonUI/general/test/StyleSheetLoaderSpec.js @@ -32,10 +32,11 @@ define( mockPlainDocument, mockHead, mockElement, + testBundle, loader; beforeEach(function () { - var testBundle = { + testBundle = { path: "a/b", resources: "c" }; @@ -72,6 +73,40 @@ define( expect(mockElement.setAttribute) .toHaveBeenCalledWith('href', "a/b/c/d.css"); }); + + describe("for themed stylesheets", function () { + var testTheme = "test-theme"; + + beforeEach(function () { + testStyleSheets = [{ + stylesheetUrl: "themed.css", + bundle: testBundle, + theme: testTheme + }, { + stylesheetUrl: "bad-theme.css", + bundle: testBundle, + theme: 'bad-theme' + }]; + + loader = new StyleSheetLoader( + testStyleSheets, + mockDocument, + testTheme + ); + }) + + it("includes matching themes", function () { + expect(mockElement.setAttribute) + .toHaveBeenCalledWith('href', "a/b/c/themed.css"); + }); + + it("excludes mismatching themes", function () { + expect(mockElement.setAttribute) + .not.toHaveBeenCalledWith('href', "a/b/c/bad-theme.css"); + }); + }); + + }); } ); From bda1bf9f9adbe5cd81655df83e8c50503847ad49 Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Wed, 4 Nov 2015 11:49:27 -0800 Subject: [PATCH 19/62] [Themes] Match themes from stylesheet loader --- platform/commonUI/general/src/StyleSheetLoader.js | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/platform/commonUI/general/src/StyleSheetLoader.js b/platform/commonUI/general/src/StyleSheetLoader.js index 19c0ffc291..9b64303df1 100644 --- a/platform/commonUI/general/src/StyleSheetLoader.js +++ b/platform/commonUI/general/src/StyleSheetLoader.js @@ -38,8 +38,9 @@ define( * @constructor * @param {object[]} stylesheets stylesheet extension definitions * @param $document Angular's jqLite-wrapped document element + * @param {string} activeTheme the theme in use */ - function StyleSheetLoader(stylesheets, $document) { + function StyleSheetLoader(stylesheets, $document, activeTheme) { var head = $document.find('head'), document = $document[0]; @@ -62,8 +63,15 @@ define( head.append(link); } + // Stylesheets which specify themes should only be applied + // when that theme has been declared. + function matchesTheme(stylesheet) { + return stylesheet.theme === undefined || + stylesheet.theme === activeTheme; + } + // Add all stylesheets from extensions - stylesheets.forEach(addStyleSheet); + stylesheets.filter(matchesTheme).forEach(addStyleSheet); } return StyleSheetLoader; From e32eb11e6033845b2ab5f4657eda03ac72e27ebd Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Wed, 4 Nov 2015 11:53:10 -0800 Subject: [PATCH 20/62] [Themes] Update bundle declarations Update bundle declarations to provide a THEME constant for use in filtering out theme-specific CSS additions. --- platform/commonUI/general/bundle.json | 7 ++++- platform/commonUI/themes/espresso/bundle.json | 28 +++++++++++-------- platform/commonUI/themes/snow/bundle.json | 28 +++++++++++-------- 3 files changed, 40 insertions(+), 23 deletions(-) diff --git a/platform/commonUI/general/bundle.json b/platform/commonUI/general/bundle.json index edaa8ec103..5976b912cc 100644 --- a/platform/commonUI/general/bundle.json +++ b/platform/commonUI/general/bundle.json @@ -18,7 +18,7 @@ "runs": [ { "implementation": "StyleSheetLoader.js", - "depends": [ "stylesheets[]", "$document" ] + "depends": [ "stylesheets[]", "$document", "THEME" ] } ], "stylesheets": [ @@ -194,6 +194,11 @@ { "key": "MCT_SCROLL_Y_ATTRIBUTE", "value": "mctScrollY" + }, + { + "key": "THEME", + "value": "unspecified", + "priority": "fallback" } ], "containers": [ diff --git a/platform/commonUI/themes/espresso/bundle.json b/platform/commonUI/themes/espresso/bundle.json index 37cab3e412..94c7259027 100644 --- a/platform/commonUI/themes/espresso/bundle.json +++ b/platform/commonUI/themes/espresso/bundle.json @@ -1,12 +1,18 @@ { - "name": "Espresso", - "description": "Espresso theme: dark and rich", - "extensions": { - "stylesheets": [ - { - "stylesheetUrl": "css/theme-espresso.css", - "priority": 1000 - } - ] - } -} \ No newline at end of file + "name": "Espresso", + "description": "Espresso theme: dark and rich", + "extensions": { + "stylesheets": [ + { + "stylesheetUrl": "css/theme-espresso.css", + "priority": 1000 + } + ], + "constants": [ + { + "key": "THEME", + "value": "espresso" + } + ] + } +} diff --git a/platform/commonUI/themes/snow/bundle.json b/platform/commonUI/themes/snow/bundle.json index 6db1ba21c1..6780df8e33 100644 --- a/platform/commonUI/themes/snow/bundle.json +++ b/platform/commonUI/themes/snow/bundle.json @@ -1,12 +1,18 @@ { - "name": "Sonw", - "description": "Snow theme: light and cool", - "extensions": { - "stylesheets": [ - { - "stylesheetUrl": "css/theme-snow.css", - "priority": 1000 - } - ] - } -} \ No newline at end of file + "name": "Snow", + "description": "Snow theme: light and cool", + "extensions": { + "stylesheets": [ + { + "stylesheetUrl": "css/theme-snow.css", + "priority": 1000 + } + ], + "constants": [ + { + "key": "THEME", + "value": "snow" + } + ] + } +} From 522ce02302421967f1dfaf8fd4e2d077cc6abcb0 Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Wed, 4 Nov 2015 11:54:19 -0800 Subject: [PATCH 21/62] [Themes] Add missing semicolon ...to satisfy JSLint. --- platform/commonUI/general/test/StyleSheetLoaderSpec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform/commonUI/general/test/StyleSheetLoaderSpec.js b/platform/commonUI/general/test/StyleSheetLoaderSpec.js index 8a679004d8..c1db25fb0a 100644 --- a/platform/commonUI/general/test/StyleSheetLoaderSpec.js +++ b/platform/commonUI/general/test/StyleSheetLoaderSpec.js @@ -93,7 +93,7 @@ define( mockDocument, testTheme ); - }) + }); it("includes matching themes", function () { expect(mockElement.setAttribute) From e5aa2b4f876f757eea021a620e63f9501895dc27 Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Wed, 4 Nov 2015 12:01:09 -0800 Subject: [PATCH 22/62] [Themes] Update developer guide Add documentation of the theme property of stylesheets extensions to the developer guide. --- docs/src/guide/index.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/docs/src/guide/index.md b/docs/src/guide/index.md index 7b35dd66cc..1469a05c71 100644 --- a/docs/src/guide/index.md +++ b/docs/src/guide/index.md @@ -1106,6 +1106,8 @@ property: * `stylesheetUrl`: Path and filename, including extension, for the stylesheet to include. This path is relative to the bundle's resources folder (by default, `res`) +* `theme`: Optional; if present, this stylesheet will only be included if this +value matches the `THEME` constant. To control the order of CSS files, use priority (see the section on Extension Definitions above.) @@ -2323,7 +2325,12 @@ default paths to reach external services are all correct. ### Configuration Constants + The following configuration constants are recognized by Open MCT Web bundles: +* Common UI elements - `platform/commonUI/general` + * `THEME`: A string identifying the current theme symbolically. Individual + stylesheets (the `stylesheets` extension category) may specify an optional + `theme` property which will be matched against this before inclusion. * CouchDB adapter - `platform/persistence/couch` * `COUCHDB_PATH`: URL or path to the CouchDB database to be used for domain object persistence. Should not include a trailing slash. From 5697a39ec3809bef0450348dd9a37c85514a74e4 Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Wed, 4 Nov 2015 13:54:29 -0800 Subject: [PATCH 23/62] [Production] Changed target icon e615 to eye open #188 Jay request; e615 is no-gleam and replaces the crosshair glpyh; gleam version is e616 --- .../icomoon.io-WTD-symbols-project.json | 229 ++++++++++-------- .../general/res/fonts/symbols/wtdsymbols.eot | Bin 12164 -> 12408 bytes .../general/res/fonts/symbols/wtdsymbols.svg | 3 +- .../general/res/fonts/symbols/wtdsymbols.ttf | Bin 11988 -> 12232 bytes .../general/res/fonts/symbols/wtdsymbols.woff | Bin 12064 -> 12308 bytes 5 files changed, 136 insertions(+), 96 deletions(-) diff --git a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json index 489d491fd2..fee491e4b3 100644 --- a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json +++ b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json @@ -1,19 +1,27 @@ { "metadata": { "name": "WTD Symbols", - "lastOpened": 1446490786311, - "created": 1446489891263 + "lastOpened": 1446670352108, + "created": 1446670349721 }, "iconSets": [ { "selection": [ { - "order": 113, + "order": 116, + "id": 93, + "prevSize": 32, + "code": 58902, + "name": "icon-eye-open-no-gleam", + "tempChar": "" + }, + { + "order": 115, "id": 92, "prevSize": 32, "code": 58901, - "name": "icon-crosshair", - "tempChar": "" + "name": "icon-eye-open", + "tempChar": "" }, { "order": 110, @@ -21,7 +29,7 @@ "prevSize": 32, "code": 58899, "name": "icon-collapse-pane-left", - "tempChar": "" + "tempChar": "" }, { "order": 111, @@ -29,7 +37,7 @@ "prevSize": 32, "code": 58900, "name": "icon-collapse-pane-right", - "tempChar": "" + "tempChar": "" }, { "order": 109, @@ -37,7 +45,7 @@ "prevSize": 32, "code": 58898, "name": "icon-save", - "tempChar": "" + "tempChar": "" }, { "order": 108, @@ -45,7 +53,7 @@ "prevSize": 32, "code": 58897, "name": "icon-dataset", - "tempChar": "" + "tempChar": "" }, { "order": 90, @@ -53,7 +61,7 @@ "prevSize": 32, "code": 58896, "name": "icon-bell", - "tempChar": "" + "tempChar": "" }, { "order": 91, @@ -61,7 +69,7 @@ "prevSize": 32, "code": 58889, "name": "icon-hourglass", - "tempChar": "" + "tempChar": "" }, { "order": 92, @@ -74,7 +82,7 @@ 58890 ], "name": "icon-info-v15", - "tempChar": "" + "tempChar": "" }, { "order": 93, @@ -82,7 +90,7 @@ "prevSize": 32, "code": 58887, "name": "icon-x-in-circle", - "tempChar": "" + "tempChar": "" }, { "order": 94, @@ -90,7 +98,7 @@ "prevSize": 32, "code": 58881, "name": "icon-datatable", - "tempChar": "" + "tempChar": "" }, { "order": 95, @@ -98,7 +106,7 @@ "prevSize": 32, "code": 58882, "name": "icon-tabular-scrolling", - "tempChar": "" + "tempChar": "" }, { "order": 96, @@ -106,7 +114,7 @@ "prevSize": 32, "code": 58884, "name": "icon-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 97, @@ -114,7 +122,7 @@ "prevSize": 32, "code": 58885, "name": "icon-calendar", - "tempChar": "" + "tempChar": "" }, { "order": 98, @@ -122,7 +130,7 @@ "prevSize": 32, "code": 58886, "name": "icon-paint-bucket", - "tempChar": "" + "tempChar": "" }, { "order": 99, @@ -130,7 +138,7 @@ "prevSize": 32, "code": 123, "name": "icon-pointer-left", - "tempChar": "" + "tempChar": "" }, { "order": 100, @@ -138,7 +146,7 @@ "prevSize": 32, "code": 125, "name": "icon-pointer-right", - "tempChar": "" + "tempChar": "" }, { "order": 101, @@ -146,7 +154,7 @@ "prevSize": 32, "code": 80, "name": "icon-person", - "tempChar": "" + "tempChar": "" }, { "order": 102, @@ -154,7 +162,7 @@ "prevSize": 32, "code": 232, "name": "icon-chain-links", - "tempChar": "" + "tempChar": "" }, { "order": 103, @@ -162,7 +170,7 @@ "prevSize": 32, "code": 115, "name": "icon-database-in-brackets", - "tempChar": "" + "tempChar": "" }, { "order": 104, @@ -170,7 +178,7 @@ "prevSize": 32, "code": 114, "name": "icon-refresh", - "tempChar": "" + "tempChar": "" }, { "order": 105, @@ -178,7 +186,7 @@ "prevSize": 32, "code": 108, "name": "icon-lock", - "tempChar": "" + "tempChar": "" }, { "order": 106, @@ -186,7 +194,7 @@ "prevSize": 32, "code": 51, "name": "icon-box-with-dashed-lines", - "tempChar": "" + "tempChar": "" }, { "order": 10, @@ -194,7 +202,7 @@ "prevSize": 32, "code": 58880, "name": "icon-box-with-arrow-cursor", - "tempChar": "" + "tempChar": "" }, { "order": 11, @@ -202,7 +210,7 @@ "prevSize": 32, "code": 65, "name": "icon-activity-mode", - "tempChar": "" + "tempChar": "" }, { "order": 12, @@ -210,7 +218,7 @@ "prevSize": 32, "code": 97, "name": "icon-activity", - "tempChar": "" + "tempChar": "" }, { "order": 87, @@ -218,7 +226,7 @@ "prevSize": 32, "code": 33, "name": "icon-alert-rect", - "tempChar": "" + "tempChar": "" }, { "order": 14, @@ -226,7 +234,7 @@ "prevSize": 32, "code": 58883, "name": "icon-alert-triangle", - "tempChar": "" + "tempChar": "" }, { "order": 15, @@ -234,7 +242,7 @@ "prevSize": 32, "code": 238, "name": "icon-arrow-double-down", - "tempChar": "" + "tempChar": "" }, { "order": 16, @@ -242,7 +250,7 @@ "prevSize": 32, "code": 235, "name": "icon-arrow-double-up", - "tempChar": "" + "tempChar": "" }, { "order": 2, @@ -250,7 +258,7 @@ "prevSize": 32, "code": 118, "name": "icon-arrow-down", - "tempChar": "" + "tempChar": "" }, { "order": 19, @@ -258,7 +266,7 @@ "prevSize": 32, "code": 60, "name": "icon-arrow-left", - "tempChar": "" + "tempChar": "" }, { "order": 20, @@ -266,7 +274,7 @@ "prevSize": 32, "code": 62, "name": "icon-arrow-right", - "tempChar": "" + "tempChar": "" }, { "order": 21, @@ -274,7 +282,7 @@ "prevSize": 32, "code": 236, "name": "icon-arrow-tall-down", - "tempChar": "" + "tempChar": "" }, { "order": 22, @@ -282,7 +290,7 @@ "prevSize": 32, "code": 237, "name": "icon-arrow-tall-up", - "tempChar": "" + "tempChar": "" }, { "order": 23, @@ -290,7 +298,7 @@ "prevSize": 32, "code": 94, "name": "icon-arrow-up", - "tempChar": "" + "tempChar": "" }, { "order": 24, @@ -298,7 +306,7 @@ "prevSize": 32, "code": 73, "name": "icon-arrows-out", - "tempChar": "" + "tempChar": "" }, { "order": 25, @@ -306,7 +314,7 @@ "prevSize": 32, "code": 58893, "name": "icon-arrows-right-left", - "tempChar": "" + "tempChar": "" }, { "order": 33, @@ -314,7 +322,7 @@ "prevSize": 32, "code": 53, "name": "icon-arrows-up-down", - "tempChar": "" + "tempChar": "" }, { "order": 26, @@ -322,7 +330,7 @@ "prevSize": 32, "code": 42, "name": "icon-asterisk", - "tempChar": "" + "tempChar": "" }, { "order": 27, @@ -330,7 +338,7 @@ "prevSize": 32, "code": 72, "name": "icon-autoflow-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 28, @@ -338,7 +346,7 @@ "prevSize": 32, "code": 224, "name": "icon-box", - "tempChar": "" + "tempChar": "" }, { "order": 29, @@ -346,7 +354,7 @@ "prevSize": 32, "code": 50, "name": "icon-check", - "tempChar": "" + "tempChar": "" }, { "order": 30, @@ -354,7 +362,7 @@ "prevSize": 32, "code": 67, "name": "icon-clock", - "tempChar": "" + "tempChar": "" }, { "order": 31, @@ -362,7 +370,7 @@ "prevSize": 32, "code": 46, "name": "icon-connectivity", - "tempChar": "" + "tempChar": "" }, { "order": 32, @@ -370,7 +378,7 @@ "prevSize": 32, "code": 100, "name": "icon-database-query", - "tempChar": "" + "tempChar": "" }, { "order": 17, @@ -378,7 +386,7 @@ "prevSize": 32, "code": 68, "name": "icon-database", - "tempChar": "" + "tempChar": "" }, { "order": 35, @@ -386,7 +394,7 @@ "prevSize": 32, "code": 81, "name": "icon-dictionary", - "tempChar": "" + "tempChar": "" }, { "order": 36, @@ -394,7 +402,7 @@ "prevSize": 32, "code": 242, "name": "icon-duplicate", - "tempChar": "" + "tempChar": "" }, { "order": 37, @@ -402,7 +410,7 @@ "prevSize": 32, "code": 102, "name": "icon-folder-new", - "tempChar": "" + "tempChar": "" }, { "order": 38, @@ -410,7 +418,7 @@ "prevSize": 32, "code": 70, "name": "icon-folder", - "tempChar": "" + "tempChar": "" }, { "order": 39, @@ -418,7 +426,7 @@ "prevSize": 32, "code": 95, "name": "icon-fullscreen-collapse", - "tempChar": "" + "tempChar": "" }, { "order": 40, @@ -426,7 +434,7 @@ "prevSize": 32, "code": 122, "name": "icon-fullscreen-expand", - "tempChar": "" + "tempChar": "" }, { "order": 41, @@ -434,7 +442,7 @@ "prevSize": 32, "code": 71, "name": "icon-gear", - "tempChar": "" + "tempChar": "" }, { "order": 49, @@ -442,7 +450,7 @@ "prevSize": 32, "code": 227, "name": "icon-image", - "tempChar": "" + "tempChar": "" }, { "order": 42, @@ -450,7 +458,7 @@ "prevSize": 32, "code": 225, "name": "icon-layers", - "tempChar": "" + "tempChar": "" }, { "order": 43, @@ -458,7 +466,7 @@ "prevSize": 32, "code": 76, "name": "icon-layout", - "tempChar": "" + "tempChar": "" }, { "order": 44, @@ -466,7 +474,7 @@ "prevSize": 32, "code": 226, "name": "icon-line-horz", - "tempChar": "" + "tempChar": "" }, { "order": 75, @@ -474,7 +482,7 @@ "prevSize": 32, "code": 244, "name": "icon-link", - "tempChar": "" + "tempChar": "" }, { "order": 46, @@ -482,7 +490,7 @@ "prevSize": 32, "code": 88, "name": "icon-magnify-in", - "tempChar": "" + "tempChar": "" }, { "order": 47, @@ -490,7 +498,7 @@ "prevSize": 32, "code": 89, "name": "icon-magnify-out", - "tempChar": "" + "tempChar": "" }, { "order": 48, @@ -498,7 +506,7 @@ "prevSize": 32, "code": 77, "name": "icon-magnify", - "tempChar": "" + "tempChar": "" }, { "order": 34, @@ -506,7 +514,7 @@ "prevSize": 32, "code": 109, "name": "icon-menu", - "tempChar": "" + "tempChar": "" }, { "order": 50, @@ -514,7 +522,7 @@ "prevSize": 32, "code": 243, "name": "icon-move", - "tempChar": "" + "tempChar": "" }, { "order": 51, @@ -522,7 +530,7 @@ "prevSize": 32, "code": 121, "name": "icon-new-window", - "tempChar": "" + "tempChar": "" }, { "order": 52, @@ -530,7 +538,7 @@ "prevSize": 32, "code": 111, "name": "icon-object", - "tempChar": "" + "tempChar": "" }, { "order": 73, @@ -538,7 +546,7 @@ "prevSize": 32, "code": 63, "name": "icon-object-unknown", - "tempChar": "" + "tempChar": "" }, { "order": 53, @@ -546,7 +554,7 @@ "prevSize": 32, "code": 86, "name": "icon-packet", - "tempChar": "" + "tempChar": "" }, { "order": 54, @@ -554,7 +562,7 @@ "prevSize": 32, "code": 234, "name": "icon-page", - "tempChar": "" + "tempChar": "" }, { "order": 55, @@ -562,7 +570,7 @@ "prevSize": 32, "code": 241, "name": "icon-pause", - "tempChar": "" + "tempChar": "" }, { "order": 56, @@ -570,7 +578,7 @@ "prevSize": 32, "code": 112, "name": "icon-pencil", - "tempChar": "" + "tempChar": "" }, { "order": 65, @@ -578,7 +586,7 @@ "prevSize": 32, "code": 79, "name": "icon-people", - "tempChar": "" + "tempChar": "" }, { "order": 57, @@ -586,7 +594,7 @@ "prevSize": 32, "code": 239, "name": "icon-play", - "tempChar": "" + "tempChar": "" }, { "order": 58, @@ -594,7 +602,7 @@ "prevSize": 32, "code": 233, "name": "icon-plot-resource", - "tempChar": "" + "tempChar": "" }, { "order": 59, @@ -602,7 +610,7 @@ "prevSize": 32, "code": 43, "name": "icon-plus", - "tempChar": "" + "tempChar": "" }, { "order": 60, @@ -610,7 +618,7 @@ "prevSize": 32, "code": 45, "name": "icon-minus", - "tempChar": "" + "tempChar": "" }, { "order": 61, @@ -618,7 +626,7 @@ "prevSize": 32, "code": 54, "name": "icon-sine", - "tempChar": "" + "tempChar": "" }, { "order": 62, @@ -626,7 +634,7 @@ "prevSize": 32, "code": 228, "name": "icon-T", - "tempChar": "" + "tempChar": "" }, { "order": 63, @@ -634,7 +642,7 @@ "prevSize": 32, "code": 116, "name": "icon-telemetry-panel", - "tempChar": "" + "tempChar": "" }, { "order": 64, @@ -642,7 +650,7 @@ "prevSize": 32, "code": 84, "name": "icon-telemetry", - "tempChar": "" + "tempChar": "" }, { "order": 18, @@ -650,7 +658,7 @@ "prevSize": 32, "code": 246, "name": "icon-thumbs-strip", - "tempChar": "" + "tempChar": "" }, { "order": 67, @@ -658,7 +666,7 @@ "prevSize": 32, "code": 83, "name": "icon-timeline", - "tempChar": "" + "tempChar": "" }, { "order": 68, @@ -666,7 +674,7 @@ "prevSize": 32, "code": 245, "name": "icon-timer", - "tempChar": "" + "tempChar": "" }, { "order": 69, @@ -674,7 +682,7 @@ "prevSize": 32, "code": 90, "name": "icon-trash", - "tempChar": "" + "tempChar": "" }, { "order": 70, @@ -682,7 +690,7 @@ "prevSize": 32, "code": 229, "name": "icon-two-parts-both", - "tempChar": "" + "tempChar": "" }, { "order": 71, @@ -690,7 +698,7 @@ "prevSize": 32, "code": 231, "name": "icon-two-parts-one-only", - "tempChar": "" + "tempChar": "" }, { "order": 72, @@ -698,7 +706,7 @@ "prevSize": 32, "code": 120, "name": "icon-x-heavy", - "tempChar": "" + "tempChar": "" }, { "order": 66, @@ -706,7 +714,7 @@ "prevSize": 32, "code": 58946, "name": "icon-x", - "tempChar": "" + "tempChar": "" } ], "id": 2, @@ -722,13 +730,43 @@ "prevSize": 32, "icons": [ { - "id": 92, + "id": 93, "paths": [ - "M514 2c-282.8 0-512 229.2-512 512s229.2 512 512 512 512-229.2 512-512-229.2-512-512-512zM860.2 450h-282.2v-282.2c69.6 12.8 133.8 46.2 185 97.4 51 51 84.4 115.2 97.2 184.8zM450 167.8v282.2h-282.2c12.8-69.6 46.2-133.8 97.4-185 51-51 115.2-84.4 184.8-97.2zM167.8 578h282.2v282.2c-69.6-12.8-133.8-46.2-185-97.4-51-51-84.4-115.2-97.2-184.8zM578 860.2v-282.2h282.2c-12.8 69.6-46.2 133.8-97.4 185-51 51-115.2 84.4-184.8 97.2z" + "M512 64c-261 0-480.6 195.4-512 448 31.4 252.6 251 448 512 448s480.6-195.4 512-448c-31.4-252.6-251-448-512-448zM768.2 734.6c-71.4 62.8-162.8 97.4-257.6 97.4s-186.2-34.6-257.6-97.4c-66.6-58.6-110.6-137.2-125-222.6 0 0 0-0.2 0-0.2 76.8-154 220.8-257.6 384-257.6s307.2 103.8 384 257.6c0 0 0 0.2 0 0.2-14.4 85.4-61.2 164-127.8 222.6z", + "M512 288c-123.8 0-224 100.2-224 224s100.2 224 224 224 224-100.2 224-224-100.2-224-224-224zM576 544c-53 0-96-43-96-96s43-96 96-96 96 43 96 96c0 53-43 96-96 96z" ], "attrs": [ { - "fill": "rgb(0, 0, 0)" + "fill": "rgb(6, 161, 75)" + }, + { + "fill": "rgb(6, 161, 75)" + } + ], + "isMulticolor": false, + "grid": 0, + "tags": [ + "icon-eye-open-no-gleam" + ], + "colorPermutations": { + "125525525516161751": [ + 1, + 1 + ] + } + }, + { + "id": 92, + "paths": [ + "M512 64c-261 0-480.6 195.4-512 448 31.4 252.6 251 448 512 448s480.6-195.4 512-448c-31.4-252.6-251-448-512-448zM768.2 734.6c-71.4 62.8-162.8 97.4-257.6 97.4s-186.2-34.6-257.6-97.4c-66.6-58.6-110.6-137.2-125-222.6 0 0 0-0.2 0-0.2 76.8-154 220.8-257.6 384-257.6s307.2 103.8 384 257.6c0 0 0 0.2 0 0.2-14.4 85.4-61.2 164-127.8 222.6z", + "M512 288c-123.8 0-224 100.2-224 224s100.2 224 224 224 224-100.2 224-224-100.2-224-224-224z" + ], + "attrs": [ + { + "fill": "rgb(6, 161, 75)" + }, + { + "fill": "rgb(6, 161, 75)" } ], "isMulticolor": false, @@ -738,7 +776,8 @@ ], "colorPermutations": { "125525525516161751": [ - 0 + 1, + 1 ] } }, diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot index 43192b87f77505cea5f0ebfa6831f5451609fb02..6e1b7e80f758535957274e67400b99fbcb3354bc 100755 GIT binary patch delta 755 zcmZpP|B=8}VZgv}LVqHg8H@k!VC9Jp6YC|e{bFEXlmTLw^u*!<1_lNJ1_q`CAkC4U zQ<>(a8n_n7&tPECc$1Nun8JQXlMr%mSYkJviKO;K?+4hxvL29L1{RP{kvtJhv^VOp_(NDp z&D6xq*hoxNgpDjuA-m5(!@@!Xgt2>0m$2{tGe8W`uwa;6t+g~nIe52!JipCX25zvo z87?L0o(1_IMF0Qy{{S!?jsUqF3``(VAYf!*U_S8w04Rk1{{xXA5fl)!xkNjiaq@g^ aj>-3Rw()Ke(GV#EDgY^q**s7886yBI^s#IJ delta 502 zcmaKo%_~G<6vm(P&ShpyKBgHTO}^>+8W&>>3yoR$18fm9Hy?9phAD)Vjh%(2yR(pu zjg&GHsY$U>EJ!v|Y$h9aO3EE)Mq;I&_dWfd=RK#+`yN^i=B~B@w@N(MCq4KFZSg>S zrR44dpmIL_VRbGBpa>8lu9k3QdGd9$DUVqL8lg?7-lvUlni~_9|ZrF*<&dtNb z5tIX6qbn-bePTVQj6Kq?ML>TP=7im}E3f20q?3{`CE-K`WVE4&2hpU`eo~}W8cZUb2f|x diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg index 455f2db341..7636991183 100755 --- a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg +++ b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg @@ -92,6 +92,7 @@ - + + \ No newline at end of file diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf index 0bb5126e8ab0b74bbef524f347803d4109412a19..a514b65eb1c647bda35368d1e53bfdbc72733026 100755 GIT binary patch delta 738 zcmcZ-dm?^*MKz`!8Dz`&FMq&d=aD$~4F1J?ri84L^>Z!%I7 zQ`qkH7pFw4Gba-h74{%y-Ivc>~hS;Ms`f*dd$jK2TKc0ge{CUGE(kC7duP*g;Y38d20M2|_Ci6Lo2XCx0#Waow?1dEZuwAJ0c z)y&9&TQ)Gc$kw(fIZ&3{+2}umUXZPFy|QhP9*6;=nHyXy7stmhu5^Xbe-rhMjP!Mi z9jxMAR8?K#tsIJV822OV0qJF60eKY36Tw7#qaKStgq74xP0Wmq#6(5d$nq4j`y4bZ zEHpqEyXSNX`|dvj!~hKohRLTjmxd?@@Ai-9xB1Gz4fZy}r3BrxApe8t|Ns6U0EWX6 zAeV!I2_y;xj0_CS2mT)bh0yRe*MKz`!8Dz`&FMq&d=aD%0N0)8qp3GZ+{&7&1~5 zQ`m2FJ!D|e0`eKmGJpc?hgqb6`~^V1N=9x;MH~l+VsSj diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff index 0b1935282d656f909ad4d8c68577fc097dd986b2..eb524a6291219a5ece92a25582e28571ff75e5de 100755 GIT binary patch delta 769 zcmZ1wHzh%=+~3WOfsp|S3`7{XLA3q}2Byh{OkxvtRO=mS~v)@}FodFaCiroP6RX~{i0E=u!Zb=1D z><6&`aRvFsB|ukynfT`_quAt2jQy;V49pCSKrh%#ZeZfxyq0N=T0Jw+1O^rc z<^~24215onpk5_DCU!YyVvO-H+;t zV4}TIkHsItN@}JiX2wQhq9SZ$c?#Km4jL8~8X%0_b2@~5_n!e`fQH57cjEIkK}nK{ zfk8QVw|_jp%~u9)u;&>rCFq_7g#w8F|L^|+7KX|9v}D9UaSKVsAW0~Q*({))&Nw+= bn`3gd&NkjHA{ruPKq-*PF`KP)pD_Xei$buU delta 526 zcmaKpJ4k|26vxlGexW9ml3GYFdwe~#FEV=!VNI<$w3MWY`AD>k1PcP&9YVgQ25F93 zGNK41XlsmWiG~)Z9#c!$XXk1{QLWq_3cw&S80S(y)xSgt5__d{ z510Bzuteg?EdZMy0ApNUjnEWZ4^Ww$d(?^B;Vm)T??oHsf8(dm+A5+>{v|K0V@{-rYe9D+CZfANviK^ zU?yWb8+EwYm{VfiXf?EBGZ`AJE}S4EB4HmHkp@(gF&4ebxZRnnXwBoIQgr%6(VS?&MW0hCqNU3404>_-3RD&Tmhp0BhJuwCTK>C4{%Fn(@F_6>-Gb}c*EsbFI)MPd u-BMtr=F1B2Qogmdn#+p7s)Ma$RX0z*WD6rQIWlyqJvGu75clLIsfa&~PlAO2 From ff1e1251f68b254dd1b19ece63f94a0252fbd86f Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Wed, 4 Nov 2015 13:54:29 -0800 Subject: [PATCH 24/62] [Frontend] Integrating new Inspect icon from prod-uisymbols open #244 open #188 --- .../icomoon.io-WTD-symbols-project.json | 229 ++++++++++-------- .../general/res/fonts/symbols/wtdsymbols.eot | Bin 12164 -> 12408 bytes .../general/res/fonts/symbols/wtdsymbols.svg | 3 +- .../general/res/fonts/symbols/wtdsymbols.ttf | Bin 11988 -> 12232 bytes .../general/res/fonts/symbols/wtdsymbols.woff | Bin 12064 -> 12308 bytes 5 files changed, 136 insertions(+), 96 deletions(-) diff --git a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json index 489d491fd2..fee491e4b3 100644 --- a/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json +++ b/platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json @@ -1,19 +1,27 @@ { "metadata": { "name": "WTD Symbols", - "lastOpened": 1446490786311, - "created": 1446489891263 + "lastOpened": 1446670352108, + "created": 1446670349721 }, "iconSets": [ { "selection": [ { - "order": 113, + "order": 116, + "id": 93, + "prevSize": 32, + "code": 58902, + "name": "icon-eye-open-no-gleam", + "tempChar": "" + }, + { + "order": 115, "id": 92, "prevSize": 32, "code": 58901, - "name": "icon-crosshair", - "tempChar": "" + "name": "icon-eye-open", + "tempChar": "" }, { "order": 110, @@ -21,7 +29,7 @@ "prevSize": 32, "code": 58899, "name": "icon-collapse-pane-left", - "tempChar": "" + "tempChar": "" }, { "order": 111, @@ -29,7 +37,7 @@ "prevSize": 32, "code": 58900, "name": "icon-collapse-pane-right", - "tempChar": "" + "tempChar": "" }, { "order": 109, @@ -37,7 +45,7 @@ "prevSize": 32, "code": 58898, "name": "icon-save", - "tempChar": "" + "tempChar": "" }, { "order": 108, @@ -45,7 +53,7 @@ "prevSize": 32, "code": 58897, "name": "icon-dataset", - "tempChar": "" + "tempChar": "" }, { "order": 90, @@ -53,7 +61,7 @@ "prevSize": 32, "code": 58896, "name": "icon-bell", - "tempChar": "" + "tempChar": "" }, { "order": 91, @@ -61,7 +69,7 @@ "prevSize": 32, "code": 58889, "name": "icon-hourglass", - "tempChar": "" + "tempChar": "" }, { "order": 92, @@ -74,7 +82,7 @@ 58890 ], "name": "icon-info-v15", - "tempChar": "" + "tempChar": "" }, { "order": 93, @@ -82,7 +90,7 @@ "prevSize": 32, "code": 58887, "name": "icon-x-in-circle", - "tempChar": "" + "tempChar": "" }, { "order": 94, @@ -90,7 +98,7 @@ "prevSize": 32, "code": 58881, "name": "icon-datatable", - "tempChar": "" + "tempChar": "" }, { "order": 95, @@ -98,7 +106,7 @@ "prevSize": 32, "code": 58882, "name": "icon-tabular-scrolling", - "tempChar": "" + "tempChar": "" }, { "order": 96, @@ -106,7 +114,7 @@ "prevSize": 32, "code": 58884, "name": "icon-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 97, @@ -114,7 +122,7 @@ "prevSize": 32, "code": 58885, "name": "icon-calendar", - "tempChar": "" + "tempChar": "" }, { "order": 98, @@ -122,7 +130,7 @@ "prevSize": 32, "code": 58886, "name": "icon-paint-bucket", - "tempChar": "" + "tempChar": "" }, { "order": 99, @@ -130,7 +138,7 @@ "prevSize": 32, "code": 123, "name": "icon-pointer-left", - "tempChar": "" + "tempChar": "" }, { "order": 100, @@ -138,7 +146,7 @@ "prevSize": 32, "code": 125, "name": "icon-pointer-right", - "tempChar": "" + "tempChar": "" }, { "order": 101, @@ -146,7 +154,7 @@ "prevSize": 32, "code": 80, "name": "icon-person", - "tempChar": "" + "tempChar": "" }, { "order": 102, @@ -154,7 +162,7 @@ "prevSize": 32, "code": 232, "name": "icon-chain-links", - "tempChar": "" + "tempChar": "" }, { "order": 103, @@ -162,7 +170,7 @@ "prevSize": 32, "code": 115, "name": "icon-database-in-brackets", - "tempChar": "" + "tempChar": "" }, { "order": 104, @@ -170,7 +178,7 @@ "prevSize": 32, "code": 114, "name": "icon-refresh", - "tempChar": "" + "tempChar": "" }, { "order": 105, @@ -178,7 +186,7 @@ "prevSize": 32, "code": 108, "name": "icon-lock", - "tempChar": "" + "tempChar": "" }, { "order": 106, @@ -186,7 +194,7 @@ "prevSize": 32, "code": 51, "name": "icon-box-with-dashed-lines", - "tempChar": "" + "tempChar": "" }, { "order": 10, @@ -194,7 +202,7 @@ "prevSize": 32, "code": 58880, "name": "icon-box-with-arrow-cursor", - "tempChar": "" + "tempChar": "" }, { "order": 11, @@ -202,7 +210,7 @@ "prevSize": 32, "code": 65, "name": "icon-activity-mode", - "tempChar": "" + "tempChar": "" }, { "order": 12, @@ -210,7 +218,7 @@ "prevSize": 32, "code": 97, "name": "icon-activity", - "tempChar": "" + "tempChar": "" }, { "order": 87, @@ -218,7 +226,7 @@ "prevSize": 32, "code": 33, "name": "icon-alert-rect", - "tempChar": "" + "tempChar": "" }, { "order": 14, @@ -226,7 +234,7 @@ "prevSize": 32, "code": 58883, "name": "icon-alert-triangle", - "tempChar": "" + "tempChar": "" }, { "order": 15, @@ -234,7 +242,7 @@ "prevSize": 32, "code": 238, "name": "icon-arrow-double-down", - "tempChar": "" + "tempChar": "" }, { "order": 16, @@ -242,7 +250,7 @@ "prevSize": 32, "code": 235, "name": "icon-arrow-double-up", - "tempChar": "" + "tempChar": "" }, { "order": 2, @@ -250,7 +258,7 @@ "prevSize": 32, "code": 118, "name": "icon-arrow-down", - "tempChar": "" + "tempChar": "" }, { "order": 19, @@ -258,7 +266,7 @@ "prevSize": 32, "code": 60, "name": "icon-arrow-left", - "tempChar": "" + "tempChar": "" }, { "order": 20, @@ -266,7 +274,7 @@ "prevSize": 32, "code": 62, "name": "icon-arrow-right", - "tempChar": "" + "tempChar": "" }, { "order": 21, @@ -274,7 +282,7 @@ "prevSize": 32, "code": 236, "name": "icon-arrow-tall-down", - "tempChar": "" + "tempChar": "" }, { "order": 22, @@ -282,7 +290,7 @@ "prevSize": 32, "code": 237, "name": "icon-arrow-tall-up", - "tempChar": "" + "tempChar": "" }, { "order": 23, @@ -290,7 +298,7 @@ "prevSize": 32, "code": 94, "name": "icon-arrow-up", - "tempChar": "" + "tempChar": "" }, { "order": 24, @@ -298,7 +306,7 @@ "prevSize": 32, "code": 73, "name": "icon-arrows-out", - "tempChar": "" + "tempChar": "" }, { "order": 25, @@ -306,7 +314,7 @@ "prevSize": 32, "code": 58893, "name": "icon-arrows-right-left", - "tempChar": "" + "tempChar": "" }, { "order": 33, @@ -314,7 +322,7 @@ "prevSize": 32, "code": 53, "name": "icon-arrows-up-down", - "tempChar": "" + "tempChar": "" }, { "order": 26, @@ -322,7 +330,7 @@ "prevSize": 32, "code": 42, "name": "icon-asterisk", - "tempChar": "" + "tempChar": "" }, { "order": 27, @@ -330,7 +338,7 @@ "prevSize": 32, "code": 72, "name": "icon-autoflow-tabular", - "tempChar": "" + "tempChar": "" }, { "order": 28, @@ -338,7 +346,7 @@ "prevSize": 32, "code": 224, "name": "icon-box", - "tempChar": "" + "tempChar": "" }, { "order": 29, @@ -346,7 +354,7 @@ "prevSize": 32, "code": 50, "name": "icon-check", - "tempChar": "" + "tempChar": "" }, { "order": 30, @@ -354,7 +362,7 @@ "prevSize": 32, "code": 67, "name": "icon-clock", - "tempChar": "" + "tempChar": "" }, { "order": 31, @@ -362,7 +370,7 @@ "prevSize": 32, "code": 46, "name": "icon-connectivity", - "tempChar": "" + "tempChar": "" }, { "order": 32, @@ -370,7 +378,7 @@ "prevSize": 32, "code": 100, "name": "icon-database-query", - "tempChar": "" + "tempChar": "" }, { "order": 17, @@ -378,7 +386,7 @@ "prevSize": 32, "code": 68, "name": "icon-database", - "tempChar": "" + "tempChar": "" }, { "order": 35, @@ -386,7 +394,7 @@ "prevSize": 32, "code": 81, "name": "icon-dictionary", - "tempChar": "" + "tempChar": "" }, { "order": 36, @@ -394,7 +402,7 @@ "prevSize": 32, "code": 242, "name": "icon-duplicate", - "tempChar": "" + "tempChar": "" }, { "order": 37, @@ -402,7 +410,7 @@ "prevSize": 32, "code": 102, "name": "icon-folder-new", - "tempChar": "" + "tempChar": "" }, { "order": 38, @@ -410,7 +418,7 @@ "prevSize": 32, "code": 70, "name": "icon-folder", - "tempChar": "" + "tempChar": "" }, { "order": 39, @@ -418,7 +426,7 @@ "prevSize": 32, "code": 95, "name": "icon-fullscreen-collapse", - "tempChar": "" + "tempChar": "" }, { "order": 40, @@ -426,7 +434,7 @@ "prevSize": 32, "code": 122, "name": "icon-fullscreen-expand", - "tempChar": "" + "tempChar": "" }, { "order": 41, @@ -434,7 +442,7 @@ "prevSize": 32, "code": 71, "name": "icon-gear", - "tempChar": "" + "tempChar": "" }, { "order": 49, @@ -442,7 +450,7 @@ "prevSize": 32, "code": 227, "name": "icon-image", - "tempChar": "" + "tempChar": "" }, { "order": 42, @@ -450,7 +458,7 @@ "prevSize": 32, "code": 225, "name": "icon-layers", - "tempChar": "" + "tempChar": "" }, { "order": 43, @@ -458,7 +466,7 @@ "prevSize": 32, "code": 76, "name": "icon-layout", - "tempChar": "" + "tempChar": "" }, { "order": 44, @@ -466,7 +474,7 @@ "prevSize": 32, "code": 226, "name": "icon-line-horz", - "tempChar": "" + "tempChar": "" }, { "order": 75, @@ -474,7 +482,7 @@ "prevSize": 32, "code": 244, "name": "icon-link", - "tempChar": "" + "tempChar": "" }, { "order": 46, @@ -482,7 +490,7 @@ "prevSize": 32, "code": 88, "name": "icon-magnify-in", - "tempChar": "" + "tempChar": "" }, { "order": 47, @@ -490,7 +498,7 @@ "prevSize": 32, "code": 89, "name": "icon-magnify-out", - "tempChar": "" + "tempChar": "" }, { "order": 48, @@ -498,7 +506,7 @@ "prevSize": 32, "code": 77, "name": "icon-magnify", - "tempChar": "" + "tempChar": "" }, { "order": 34, @@ -506,7 +514,7 @@ "prevSize": 32, "code": 109, "name": "icon-menu", - "tempChar": "" + "tempChar": "" }, { "order": 50, @@ -514,7 +522,7 @@ "prevSize": 32, "code": 243, "name": "icon-move", - "tempChar": "" + "tempChar": "" }, { "order": 51, @@ -522,7 +530,7 @@ "prevSize": 32, "code": 121, "name": "icon-new-window", - "tempChar": "" + "tempChar": "" }, { "order": 52, @@ -530,7 +538,7 @@ "prevSize": 32, "code": 111, "name": "icon-object", - "tempChar": "" + "tempChar": "" }, { "order": 73, @@ -538,7 +546,7 @@ "prevSize": 32, "code": 63, "name": "icon-object-unknown", - "tempChar": "" + "tempChar": "" }, { "order": 53, @@ -546,7 +554,7 @@ "prevSize": 32, "code": 86, "name": "icon-packet", - "tempChar": "" + "tempChar": "" }, { "order": 54, @@ -554,7 +562,7 @@ "prevSize": 32, "code": 234, "name": "icon-page", - "tempChar": "" + "tempChar": "" }, { "order": 55, @@ -562,7 +570,7 @@ "prevSize": 32, "code": 241, "name": "icon-pause", - "tempChar": "" + "tempChar": "" }, { "order": 56, @@ -570,7 +578,7 @@ "prevSize": 32, "code": 112, "name": "icon-pencil", - "tempChar": "" + "tempChar": "" }, { "order": 65, @@ -578,7 +586,7 @@ "prevSize": 32, "code": 79, "name": "icon-people", - "tempChar": "" + "tempChar": "" }, { "order": 57, @@ -586,7 +594,7 @@ "prevSize": 32, "code": 239, "name": "icon-play", - "tempChar": "" + "tempChar": "" }, { "order": 58, @@ -594,7 +602,7 @@ "prevSize": 32, "code": 233, "name": "icon-plot-resource", - "tempChar": "" + "tempChar": "" }, { "order": 59, @@ -602,7 +610,7 @@ "prevSize": 32, "code": 43, "name": "icon-plus", - "tempChar": "" + "tempChar": "" }, { "order": 60, @@ -610,7 +618,7 @@ "prevSize": 32, "code": 45, "name": "icon-minus", - "tempChar": "" + "tempChar": "" }, { "order": 61, @@ -618,7 +626,7 @@ "prevSize": 32, "code": 54, "name": "icon-sine", - "tempChar": "" + "tempChar": "" }, { "order": 62, @@ -626,7 +634,7 @@ "prevSize": 32, "code": 228, "name": "icon-T", - "tempChar": "" + "tempChar": "" }, { "order": 63, @@ -634,7 +642,7 @@ "prevSize": 32, "code": 116, "name": "icon-telemetry-panel", - "tempChar": "" + "tempChar": "" }, { "order": 64, @@ -642,7 +650,7 @@ "prevSize": 32, "code": 84, "name": "icon-telemetry", - "tempChar": "" + "tempChar": "" }, { "order": 18, @@ -650,7 +658,7 @@ "prevSize": 32, "code": 246, "name": "icon-thumbs-strip", - "tempChar": "" + "tempChar": "" }, { "order": 67, @@ -658,7 +666,7 @@ "prevSize": 32, "code": 83, "name": "icon-timeline", - "tempChar": "" + "tempChar": "" }, { "order": 68, @@ -666,7 +674,7 @@ "prevSize": 32, "code": 245, "name": "icon-timer", - "tempChar": "" + "tempChar": "" }, { "order": 69, @@ -674,7 +682,7 @@ "prevSize": 32, "code": 90, "name": "icon-trash", - "tempChar": "" + "tempChar": "" }, { "order": 70, @@ -682,7 +690,7 @@ "prevSize": 32, "code": 229, "name": "icon-two-parts-both", - "tempChar": "" + "tempChar": "" }, { "order": 71, @@ -690,7 +698,7 @@ "prevSize": 32, "code": 231, "name": "icon-two-parts-one-only", - "tempChar": "" + "tempChar": "" }, { "order": 72, @@ -698,7 +706,7 @@ "prevSize": 32, "code": 120, "name": "icon-x-heavy", - "tempChar": "" + "tempChar": "" }, { "order": 66, @@ -706,7 +714,7 @@ "prevSize": 32, "code": 58946, "name": "icon-x", - "tempChar": "" + "tempChar": "" } ], "id": 2, @@ -722,13 +730,43 @@ "prevSize": 32, "icons": [ { - "id": 92, + "id": 93, "paths": [ - "M514 2c-282.8 0-512 229.2-512 512s229.2 512 512 512 512-229.2 512-512-229.2-512-512-512zM860.2 450h-282.2v-282.2c69.6 12.8 133.8 46.2 185 97.4 51 51 84.4 115.2 97.2 184.8zM450 167.8v282.2h-282.2c12.8-69.6 46.2-133.8 97.4-185 51-51 115.2-84.4 184.8-97.2zM167.8 578h282.2v282.2c-69.6-12.8-133.8-46.2-185-97.4-51-51-84.4-115.2-97.2-184.8zM578 860.2v-282.2h282.2c-12.8 69.6-46.2 133.8-97.4 185-51 51-115.2 84.4-184.8 97.2z" + "M512 64c-261 0-480.6 195.4-512 448 31.4 252.6 251 448 512 448s480.6-195.4 512-448c-31.4-252.6-251-448-512-448zM768.2 734.6c-71.4 62.8-162.8 97.4-257.6 97.4s-186.2-34.6-257.6-97.4c-66.6-58.6-110.6-137.2-125-222.6 0 0 0-0.2 0-0.2 76.8-154 220.8-257.6 384-257.6s307.2 103.8 384 257.6c0 0 0 0.2 0 0.2-14.4 85.4-61.2 164-127.8 222.6z", + "M512 288c-123.8 0-224 100.2-224 224s100.2 224 224 224 224-100.2 224-224-100.2-224-224-224zM576 544c-53 0-96-43-96-96s43-96 96-96 96 43 96 96c0 53-43 96-96 96z" ], "attrs": [ { - "fill": "rgb(0, 0, 0)" + "fill": "rgb(6, 161, 75)" + }, + { + "fill": "rgb(6, 161, 75)" + } + ], + "isMulticolor": false, + "grid": 0, + "tags": [ + "icon-eye-open-no-gleam" + ], + "colorPermutations": { + "125525525516161751": [ + 1, + 1 + ] + } + }, + { + "id": 92, + "paths": [ + "M512 64c-261 0-480.6 195.4-512 448 31.4 252.6 251 448 512 448s480.6-195.4 512-448c-31.4-252.6-251-448-512-448zM768.2 734.6c-71.4 62.8-162.8 97.4-257.6 97.4s-186.2-34.6-257.6-97.4c-66.6-58.6-110.6-137.2-125-222.6 0 0 0-0.2 0-0.2 76.8-154 220.8-257.6 384-257.6s307.2 103.8 384 257.6c0 0 0 0.2 0 0.2-14.4 85.4-61.2 164-127.8 222.6z", + "M512 288c-123.8 0-224 100.2-224 224s100.2 224 224 224 224-100.2 224-224-100.2-224-224-224z" + ], + "attrs": [ + { + "fill": "rgb(6, 161, 75)" + }, + { + "fill": "rgb(6, 161, 75)" } ], "isMulticolor": false, @@ -738,7 +776,8 @@ ], "colorPermutations": { "125525525516161751": [ - 0 + 1, + 1 ] } }, diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.eot index 43192b87f77505cea5f0ebfa6831f5451609fb02..6e1b7e80f758535957274e67400b99fbcb3354bc 100755 GIT binary patch delta 755 zcmZpP|B=8}VZgv}LVqHg8H@k!VC9Jp6YC|e{bFEXlmTLw^u*!<1_lNJ1_q`CAkC4U zQ<>(a8n_n7&tPECc$1Nun8JQXlMr%mSYkJviKO;K?+4hxvL29L1{RP{kvtJhv^VOp_(NDp z&D6xq*hoxNgpDjuA-m5(!@@!Xgt2>0m$2{tGe8W`uwa;6t+g~nIe52!JipCX25zvo z87?L0o(1_IMF0Qy{{S!?jsUqF3``(VAYf!*U_S8w04Rk1{{xXA5fl)!xkNjiaq@g^ aj>-3Rw()Ke(GV#EDgY^q**s7886yBI^s#IJ delta 502 zcmaKo%_~G<6vm(P&ShpyKBgHTO}^>+8W&>>3yoR$18fm9Hy?9phAD)Vjh%(2yR(pu zjg&GHsY$U>EJ!v|Y$h9aO3EE)Mq;I&_dWfd=RK#+`yN^i=B~B@w@N(MCq4KFZSg>S zrR44dpmIL_VRbGBpa>8lu9k3QdGd9$DUVqL8lg?7-lvUlni~_9|ZrF*<&dtNb z5tIX6qbn-bePTVQj6Kq?ML>TP=7im}E3f20q?3{`CE-K`WVE4&2hpU`eo~}W8cZUb2f|x diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg index 455f2db341..7636991183 100755 --- a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg +++ b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.svg @@ -92,6 +92,7 @@ - + + \ No newline at end of file diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.ttf index 0bb5126e8ab0b74bbef524f347803d4109412a19..a514b65eb1c647bda35368d1e53bfdbc72733026 100755 GIT binary patch delta 738 zcmcZ-dm?^*MKz`!8Dz`&FMq&d=aD$~4F1J?ri84L^>Z!%I7 zQ`qkH7pFw4Gba-h74{%y-Ivc>~hS;Ms`f*dd$jK2TKc0ge{CUGE(kC7duP*g;Y38d20M2|_Ci6Lo2XCx0#Waow?1dEZuwAJ0c z)y&9&TQ)Gc$kw(fIZ&3{+2}umUXZPFy|QhP9*6;=nHyXy7stmhu5^Xbe-rhMjP!Mi z9jxMAR8?K#tsIJV822OV0qJF60eKY36Tw7#qaKStgq74xP0Wmq#6(5d$nq4j`y4bZ zEHpqEyXSNX`|dvj!~hKohRLTjmxd?@@Ai-9xB1Gz4fZy}r3BrxApe8t|Ns6U0EWX6 zAeV!I2_y;xj0_CS2mT)bh0yRe*MKz`!8Dz`&FMq&d=aD%0N0)8qp3GZ+{&7&1~5 zQ`m2FJ!D|e0`eKmGJpc?hgqb6`~^V1N=9x;MH~l+VsSj diff --git a/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff b/platform/commonUI/general/res/fonts/symbols/wtdsymbols.woff index 0b1935282d656f909ad4d8c68577fc097dd986b2..eb524a6291219a5ece92a25582e28571ff75e5de 100755 GIT binary patch delta 769 zcmZ1wHzh%=+~3WOfsp|S3`7{XLA3q}2Byh{OkxvtRO=mS~v)@}FodFaCiroP6RX~{i0E=u!Zb=1D z><6&`aRvFsB|ukynfT`_quAt2jQy;V49pCSKrh%#ZeZfxyq0N=T0Jw+1O^rc z<^~24215onpk5_DCU!YyVvO-H+;t zV4}TIkHsItN@}JiX2wQhq9SZ$c?#Km4jL8~8X%0_b2@~5_n!e`fQH57cjEIkK}nK{ zfk8QVw|_jp%~u9)u;&>rCFq_7g#w8F|L^|+7KX|9v}D9UaSKVsAW0~Q*({))&Nw+= bn`3gd&NkjHA{ruPKq-*PF`KP)pD_Xei$buU delta 526 zcmaKpJ4k|26vxlGexW9ml3GYFdwe~#FEV=!VNI<$w3MWY`AD>k1PcP&9YVgQ25F93 zGNK41XlsmWiG~)Z9#c!$XXk1{QLWq_3cw&S80S(y)xSgt5__d{ z510Bzuteg?EdZMy0ApNUjnEWZ4^Ww$d(?^B;Vm)T??oHsf8(dm+A5+>{v|K0V@{-rYe9D+CZfANviK^ zU?yWb8+EwYm{VfiXf?EBGZ`AJE}S4EB4HmHkp@(gF&4ebxZRnnXwBoIQgr%6(VS?&MW0hCqNU3404>_-3RD&Tmhp0BhJuwCTK>C4{%Fn(@F_6>-Gb}c*EsbFI)MPd u-BMtr=F1B2Qogmdn#+p7s)Ma$RX0z*WD6rQIWlyqJvGu75clLIsfa&~PlAO2 From e09cf91def84008798845cd8be0cea7f47419776 Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Wed, 4 Nov 2015 15:03:56 -0800 Subject: [PATCH 25/62] [Frontend] Inspector-related fixes open #244 Fixing scroll issue in Inspector via flex layout; Added new _archetypes.scss file for .l-flex* and .col styles; moved .col and associated mixin out of _layout.scss and into _archetypes; --- .../general/res/sass/_archetypes.scss | 116 +++++ .../commonUI/general/res/sass/_inspector.scss | 5 + platform/commonUI/general/res/sass/_main.scss | 1 + .../res/sass/user-environ/_layout.scss | 97 ---- .../res/templates/object-inspector.html | 6 +- .../espresso/res/css/theme-espresso.css | 485 +++++++++--------- .../themes/snow/res/css/theme-snow.css | 485 +++++++++--------- 7 files changed, 633 insertions(+), 562 deletions(-) create mode 100644 platform/commonUI/general/res/sass/_archetypes.scss diff --git a/platform/commonUI/general/res/sass/_archetypes.scss b/platform/commonUI/general/res/sass/_archetypes.scss new file mode 100644 index 0000000000..54389b0eac --- /dev/null +++ b/platform/commonUI/general/res/sass/_archetypes.scss @@ -0,0 +1,116 @@ +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ + +/********************************************* COLUMN LAYOUTS STYLES */ +@mixin cols($totalCols, $span) { + $cw: 100% / $totalCols; + min-width: (500px / $totalCols) * $span; + @if ($totalCols != $span) { + width: ($cw * $span) - $ueColMargin; + } @else { + width: $cw; + } +} + +.cols { + @include clearfix; + .col { + @include box-sizing(border-box); + @include clearfix; + // background: rgba(#ffcc00, 0.2); + float: left; + margin-left: $ueColMargin; + padding-left: $interiorMargin; + position: relative; + &:first-child { + margin-left: 0; + padding-left: 0; + } + } + &.cols-2 { + $nc: 2; + .col-1 { + @include cols($nc, 1); + } + } + &.cols-2-ff { + // 2 columns, first column is fixed, second is fluid + .col-100px { + width: 100px; + } + } + + &.cols-6 { + $nc: 6; + .col-1 { + @include cols($nc, 1); + } + } + &.cols-16 { + $nc: 16; + .col-1 { + @include cols($nc, 1); + } + .col-2 { + @include cols($nc, 2); + } + .col-7 { + @include cols($nc, 7); + } + } + &.cols-32 { + $nc: 32; + .col-2 { + @include cols($nc, 2); + } + .col-15 { + @include cols($nc, 15); + } + } + .l-row { + @include clearfix; + padding: $interiorMargin 0; + } +} +/********************************************* FLEX STYLES */ +.l-flex-row, +.l-flex-col { + @include display-flex; + @include flex-wrap(nowrap); + .flex-elem { + &:not(.grows) { + @include flex(0 1 auto); + } + &.grows { + @include flex(1 1 auto); + } + } +} + +.l-flex-row { + @include flex-direction(row); + +} + +.l-flex-col { + @include flex-direction(column); +} \ No newline at end of file diff --git a/platform/commonUI/general/res/sass/_inspector.scss b/platform/commonUI/general/res/sass/_inspector.scss index 9f67ff3b73..62917017a4 100644 --- a/platform/commonUI/general/res/sass/_inspector.scss +++ b/platform/commonUI/general/res/sass/_inspector.scss @@ -43,6 +43,11 @@ vertical-align: bottom; } } + + ul { + @include box-sizing(border-box); + padding-right: $interiorMargin; + } ul li, em { diff --git a/platform/commonUI/general/res/sass/_main.scss b/platform/commonUI/general/res/sass/_main.scss index 0dab445e84..f7f2489dc7 100644 --- a/platform/commonUI/general/res/sass/_main.scss +++ b/platform/commonUI/general/res/sass/_main.scss @@ -21,6 +21,7 @@ *****************************************************************************/ @import "effects"; @import "global"; +@import "archetypes"; @import "about"; @import "text"; @import "icons"; diff --git a/platform/commonUI/general/res/sass/user-environ/_layout.scss b/platform/commonUI/general/res/sass/user-environ/_layout.scss index 4800cdeb6d..f421487cf0 100644 --- a/platform/commonUI/general/res/sass/user-environ/_layout.scss +++ b/platform/commonUI/general/res/sass/user-environ/_layout.scss @@ -19,23 +19,6 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -@mixin cols($totalCols, $span) { - $cw: 100% / $totalCols; - min-width: (500px / $totalCols) * $span; - @if ($totalCols != $span) { - width: ($cw * $span) - $ueColMargin; - } @else { - width: $cw; - } -} - -/*.holder-all { - $myM: 0; // $interiorMarginSm; - top: $myM; - right: $myM; - bottom: $myM; - left: $myM; -}*/ .browse-area, .edit-area, @@ -158,67 +141,6 @@ } } -.cols { - @include clearfix; - .col { - @include box-sizing(border-box); - @include clearfix; - // background: rgba(#ffcc00, 0.2); - float: left; - margin-left: $ueColMargin; - padding-left: $interiorMargin; - position: relative; - &:first-child { - margin-left: 0; - padding-left: 0; - } - } - &.cols-2 { - $nc: 2; - .col-1 { - @include cols($nc, 1); - } - } - &.cols-2-ff { - // 2 columns, first column is fixed, second is fluid - .col-100px { - width: 100px; - } - } - - &.cols-6 { - $nc: 6; - .col-1 { - @include cols($nc, 1); - } - } - &.cols-16 { - $nc: 16; - .col-1 { - @include cols($nc, 1); - } - .col-2 { - @include cols($nc, 2); - } - .col-7 { - @include cols($nc, 7); - } - } - &.cols-32 { - $nc: 32; - .col-2 { - @include cols($nc, 2); - } - .col-15 { - @include cols($nc, 15); - } - } - .l-row { - @include clearfix; - padding: $interiorMargin 0; - } -} - .browse-mode { .split-layout { .split-pane-component.pane { @@ -464,25 +386,6 @@ .holder-create-and-search { opacity: 0; } - /*.holder-create-and-search { - @include trans-prop-nice((top, left), 250ms); - top: $ueTopBarH + $interiorMargin; - left: -1 * $bodyMargin !important; - .create-btn { - @include border-left-radius(0); - @include trans-prop-nice((width), 250ms); - width: $uePaneMiniTabW !important; - text-align: center !important; - padding: 0; - .title-label, - &:after { - display: none; - } - &:before { - font-size: 9px; - } - } - }*/ } .pane-tree-showing { diff --git a/platform/commonUI/general/res/templates/object-inspector.html b/platform/commonUI/general/res/templates/object-inspector.html index 83ed591ff7..cf111a3695 100644 --- a/platform/commonUI/general/res/templates/object-inspector.html +++ b/platform/commonUI/general/res/templates/object-inspector.html @@ -20,9 +20,9 @@ at runtime from the About dialog for additional information. --> -
-
Inspection
-
    +
    +
    Inspection
    +
    • Properties
      .type-icon { color: #cccccc; font-size: 120%; float: left; margin-right: 5px; } - /* line 222, ../../../../general/res/sass/controls/_controls.scss */ + /* line 215, ../../../../general/res/sass/controls/_controls.scss */ .object-header .l-elem-wrapper { -webkit-justify-content: flex-start; justify-content: flex-start; } - /* line 225, ../../../../general/res/sass/controls/_controls.scss */ + /* line 218, ../../../../general/res/sass/controls/_controls.scss */ .object-header .l-elem-wrapper mct-representation { min-width: 0.7em; } - /* line 233, ../../../../general/res/sass/controls/_controls.scss */ + /* line 226, ../../../../general/res/sass/controls/_controls.scss */ .object-header .action { margin-right: 5px; } - /* line 237, ../../../../general/res/sass/controls/_controls.scss */ + /* line 230, ../../../../general/res/sass/controls/_controls.scss */ .object-header .title-label { color: #999; overflow: hidden; @@ -2143,13 +2250,13 @@ label.checkbox.custom { flex: 0 1 auto; -webkit-flex: 0 1 auto; padding-right: 0.35em; } - /* line 269, ../../../../general/res/sass/controls/_controls.scss */ + /* line 240, ../../../../general/res/sass/controls/_controls.scss */ .object-header .context-available { font-size: 0.7em; flex: 0 0 1; -webkit-flex: 0 0 1; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 276, ../../../../general/res/sass/controls/_controls.scss */ + /* line 247, ../../../../general/res/sass/controls/_controls.scss */ .object-header .context-available { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -2168,7 +2275,7 @@ label.checkbox.custom { -webkit-transition-delay: 0; transition-delay: 0; opacity: 0; } - /* line 259, ../../../../general/res/sass/controls/_controls.scss */ + /* line 252, ../../../../general/res/sass/controls/_controls.scss */ .object-header:hover .context-available { opacity: 1; } } @@ -2182,12 +2289,12 @@ label.checkbox.custom { @keyframes progress { 100% { background-position: 20px center; } } -/* line 281, ../../../../general/res/sass/controls/_controls.scss */ +/* line 274, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar { display: inline-block; overflow: hidden; position: relative; } - /* line 287, ../../../../general/res/sass/controls/_controls.scss */ + /* line 280, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar .progress-amt-holder { overflow: hidden; position: absolute; @@ -2197,7 +2304,7 @@ label.checkbox.custom { left: 1px; width: auto; height: auto; } - /* line 290, ../../../../general/res/sass/controls/_controls.scss */ + /* line 283, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar .progress-amt, .l-progress-bar .progress-amt:before, .l-progress-bar .progress-amt:after { @@ -2211,14 +2318,14 @@ label.checkbox.custom { height: auto; display: block; content: ''; } - /* line 298, ../../../../general/res/sass/controls/_controls.scss */ + /* line 291, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar .progress-amt { right: auto; } - /* line 303, ../../../../general/res/sass/controls/_controls.scss */ + /* line 296, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar.indeterminate .progress-amt { width: 100% !important; } -/* line 309, ../../../../general/res/sass/controls/_controls.scss */ +/* line 302, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar { -moz-border-radius: 3px; -webkit-border-radius: 3px; @@ -2227,7 +2334,7 @@ label.checkbox.custom { -webkit-box-shadow: inset rgba(0, 0, 0, 0.3) 0 1px 4px; box-shadow: inset rgba(0, 0, 0, 0.3) 0 1px 4px; background: rgba(0, 0, 0, 0.1); } - /* line 314, ../../../../general/res/sass/controls/_controls.scss */ + /* line 307, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar .progress-amt { -moz-border-radius: 3px; -webkit-border-radius: 3px; @@ -2254,10 +2361,10 @@ label.checkbox.custom { -o-transition-delay: 0; -webkit-transition-delay: 0; transition-delay: 0; } - /* line 319, ../../../../general/res/sass/controls/_controls.scss */ + /* line 312, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar .progress-amt:before { background-color: #0099cc; } - /* line 322, ../../../../general/res/sass/controls/_controls.scss */ + /* line 315, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar .progress-amt:after { background-image: url(''); background-size: 100%; @@ -2265,7 +2372,7 @@ label.checkbox.custom { background-image: -moz-linear-gradient(rgba(0, 0, 0, 0) 5%, rgba(255, 255, 255, 0.25) 30%, rgba(0, 0, 0, 0) 100%); background-image: -webkit-linear-gradient(rgba(0, 0, 0, 0) 5%, rgba(255, 255, 255, 0.25) 30%, rgba(0, 0, 0, 0) 100%); background-image: linear-gradient(rgba(0, 0, 0, 0) 5%, rgba(255, 255, 255, 0.25) 30%, rgba(0, 0, 0, 0) 100%); } - /* line 331, ../../../../general/res/sass/controls/_controls.scss */ + /* line 324, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar:not(.indeterminate) .progress-amt:before { -moz-animation: progress 0.4s linear infinite; -webkit-animation: progress 0.4s linear infinite; @@ -2278,7 +2385,7 @@ label.checkbox.custom { background-position: 0 center; background-repeat: repeat-x; background-size: 20px 40%; } - /* line 339, ../../../../general/res/sass/controls/_controls.scss */ + /* line 332, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar.indeterminate .progress-amt:before { -moz-animation: progress 0.6s linear infinite; -webkit-animation: progress 0.6s linear infinite; @@ -2290,12 +2397,12 @@ label.checkbox.custom { background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%); background-repeat: repeat; background-size: 20px 20px; } - /* line 344, ../../../../general/res/sass/controls/_controls.scss */ + /* line 337, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar.indeterminate .progress-amt:after { display: none; } /******************************************************** SLIDERS */ -/* line 352, ../../../../general/res/sass/controls/_controls.scss */ +/* line 345, ../../../../general/res/sass/controls/_controls.scss */ .slider .slot { width: auto; position: absolute; @@ -2303,7 +2410,7 @@ label.checkbox.custom { right: 0; bottom: 0; left: 0; } -/* line 362, ../../../../general/res/sass/controls/_controls.scss */ +/* line 355, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob { -moz-transition-property: opacity, background-color, border-color, color; -o-transition-property: opacity, background-color, border-color, color; @@ -2329,10 +2436,10 @@ label.checkbox.custom { auto: 0; bottom: auto; left: auto; } - /* line 307, ../../../../general/res/sass/controls/_controls.scss */ + /* line 358, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob:hover { background-color: #0099cc; } -/* line 318, ../../../../general/res/sass/controls/_controls.scss */ +/* line 369, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob-l { -moz-border-radius-topleft: 10px; -webkit-border-top-left-radius: 10px; @@ -2341,7 +2448,7 @@ label.checkbox.custom { -webkit-border-bottom-left-radius: 10px; border-bottom-left-radius: 10px; cursor: w-resize; } -/* line 322, ../../../../general/res/sass/controls/_controls.scss */ +/* line 373, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob-r { -moz-border-radius-topright: 10px; -webkit-border-top-right-radius: 10px; @@ -2350,7 +2457,7 @@ label.checkbox.custom { -webkit-border-bottom-right-radius: 10px; border-bottom-right-radius: 10px; cursor: e-resize; } -/* line 326, ../../../../general/res/sass/controls/_controls.scss */ +/* line 377, ../../../../general/res/sass/controls/_controls.scss */ .slider .range { -moz-transition-property: opacity, background-color, border-color, color; -o-transition-property: opacity, background-color, border-color, color; @@ -2377,12 +2484,12 @@ label.checkbox.custom { left: auto; height: auto; width: auto; } - /* line 337, ../../../../general/res/sass/controls/_controls.scss */ + /* line 388, ../../../../general/res/sass/controls/_controls.scss */ .slider .range:hover { background-color: rgba(0, 153, 204, 0.5); } /******************************************************** DATETIME PICKER */ -/* line 344, ../../../../general/res/sass/controls/_controls.scss */ +/* line 395, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker { -moz-user-select: -moz-none; -ms-user-select: none; @@ -2391,65 +2498,65 @@ label.checkbox.custom { font-size: 0.8rem; padding: 10px !important; width: 230px; } - /* line 350, ../../../../general/res/sass/controls/_controls.scss */ + /* line 401, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager { height: 15px; margin-bottom: 5px; position: relative; } - /* line 420, ../../../../general/res/sass/controls/_controls.scss */ + /* line 413, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager { width: 20px; } - /* line 423, ../../../../general/res/sass/controls/_controls.scss */ + /* line 416, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.prev { right: auto; } - /* line 425, ../../../../general/res/sass/controls/_controls.scss */ + /* line 418, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.prev:before { content: "\3c"; } - /* line 429, ../../../../general/res/sass/controls/_controls.scss */ + /* line 422, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.next { left: auto; text-align: right; } - /* line 432, ../../../../general/res/sass/controls/_controls.scss */ + /* line 425, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.next:before { content: "\3e"; } - /* line 437, ../../../../general/res/sass/controls/_controls.scss */ + /* line 430, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .val { text-align: center; left: 25px; right: 25px; } - /* line 443, ../../../../general/res/sass/controls/_controls.scss */ + /* line 436, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-calendar, .l-datetime-picker .l-time-selects { border-top: 1px solid rgba(153, 153, 153, 0.1); } - /* line 447, ../../../../general/res/sass/controls/_controls.scss */ + /* line 440, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-time-selects { line-height: 22px; } /******************************************************** CALENDAR */ -/* line 397, ../../../../general/res/sass/controls/_controls.scss */ +/* line 448, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row { display: -webkit-flex; display: flex; -webkit-flex-flow: row nowrap; flex-flow: row nowrap; margin-top: 1px; } - /* line 459, ../../../../general/res/sass/controls/_controls.scss */ + /* line 452, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row:first-child { margin-top: 0; } - /* line 462, ../../../../general/res/sass/controls/_controls.scss */ + /* line 455, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row li { -webkit-flex: 1 0; flex: 1 0; margin-left: 1px; padding: 5px; text-align: center; } - /* line 468, ../../../../general/res/sass/controls/_controls.scss */ + /* line 461, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row li:first-child { margin-left: 0; } - /* line 472, ../../../../general/res/sass/controls/_controls.scss */ + /* line 465, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-header li { color: #b3b3b3; } - /* line 475, ../../../../general/res/sass/controls/_controls.scss */ + /* line 468, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li { -moz-transition-property: background-color; -o-transition-property: background-color; @@ -2468,31 +2575,31 @@ label.checkbox.custom { -webkit-transition-delay: 0; transition-delay: 0; cursor: pointer; } - /* line 478, ../../../../general/res/sass/controls/_controls.scss */ + /* line 471, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li.in-month { background-color: #616161; } - /* line 481, ../../../../general/res/sass/controls/_controls.scss */ + /* line 474, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li .sub { color: #b3b3b3; font-size: 0.8em; } - /* line 485, ../../../../general/res/sass/controls/_controls.scss */ + /* line 478, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li.selected { background: #006080; color: #cccccc; } - /* line 488, ../../../../general/res/sass/controls/_controls.scss */ + /* line 481, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li.selected .sub { color: inherit; } - /* line 492, ../../../../general/res/sass/controls/_controls.scss */ + /* line 485, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li:hover { background-color: #0099cc; color: #fff; } - /* line 495, ../../../../general/res/sass/controls/_controls.scss */ + /* line 488, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li:hover .sub { color: inherit; } /******************************************************** BROWSER ELEMENTS */ @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 448, ../../../../general/res/sass/controls/_controls.scss */ + /* line 499, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar { -moz-border-radius: 2px; -webkit-border-radius: 2px; @@ -2507,7 +2614,7 @@ label.checkbox.custom { height: 10px; width: 10px; } - /* line 457, ../../../../general/res/sass/controls/_controls.scss */ + /* line 508, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar-thumb { background-image: url(''); background-size: 100%; @@ -2521,7 +2628,7 @@ label.checkbox.custom { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; } - /* line 466, ../../../../general/res/sass/controls/_controls.scss */ + /* line 517, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar-thumb:hover { background-image: url(''); background-size: 100%; @@ -2530,7 +2637,7 @@ label.checkbox.custom { background-image: -webkit-linear-gradient(#5e5e5e, #525252 20px); background-image: linear-gradient(#5e5e5e, #525252 20px); } - /* line 471, ../../../../general/res/sass/controls/_controls.scss */ + /* line 522, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar-corner { background: rgba(0, 0, 0, 0.4); } } /***************************************************************************** @@ -3918,15 +4025,15 @@ textarea { /* line 29, ../../../../general/res/sass/forms/_datetime.scss */ .complex.datetime { /* - .field-hints, - .fields { - } - - - .field-hints { - - } - */ } + .field-hints, + .fields { + } + + + .field-hints { + + } + */ } /* line 30, ../../../../general/res/sass/forms/_datetime.scss */ .complex.datetime span { display: inline-block; @@ -4173,26 +4280,19 @@ span.req { * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/*.holder-all { - $myM: 0; // $interiorMarginSm; - top: $myM; - right: $myM; - bottom: $myM; - left: $myM; -}*/ -/* line 40, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 23, ../../../../general/res/sass/user-environ/_layout.scss */ .browse-area, .edit-area, .editor { position: absolute; } -/* line 46, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 29, ../../../../general/res/sass/user-environ/_layout.scss */ .editor { -moz-border-radius: 4.5px; -webkit-border-radius: 4.5px; border-radius: 4.5px; } -/* line 50, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 33, ../../../../general/res/sass/user-environ/_layout.scss */ .contents { box-sizing: border-box; position: absolute; @@ -4200,21 +4300,21 @@ span.req { right: 0; bottom: 0; left: 0; } - /* line 58, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 41, ../../../../general/res/sass/user-environ/_layout.scss */ .contents.nomargin { right: 0px; bottom: 0px; left: 0px; } -/* line 67, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 50, ../../../../general/res/sass/user-environ/_layout.scss */ .bar .icon.major, .bar .major.t-item-icon { margin-right: 5px; } -/* line 70, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 53, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs, .bar.l-inspect, .l-datetime-picker .l-month-year-pager .bar.pager, .l-datetime-picker .l-month-year-pager .bar.val, .s-menu-btn span.bar.l-click-area { text-wrap: none; white-space: nowrap; } - /* line 73, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 56, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs.left, .bar.left.l-inspect, .l-datetime-picker .l-month-year-pager .bar.left.pager, .l-datetime-picker .l-month-year-pager .bar.left.val, .s-menu-btn span.bar.left.l-click-area, .bar.abs .left, @@ -4224,7 +4324,7 @@ span.req { .s-menu-btn span.bar.l-click-area .left { width: 45%; right: auto; } - /* line 78, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 61, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs.right, .bar.right.l-inspect, .l-datetime-picker .l-month-year-pager .bar.right.pager, .l-datetime-picker .l-month-year-pager .bar.right.val, .s-menu-btn span.bar.right.l-click-area, .bar.abs .right, @@ -4235,7 +4335,7 @@ span.req { width: 45%; left: auto; text-align: right; } - /* line 83, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 66, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs.right .icon.major, .bar.right.l-inspect .icon.major, .l-datetime-picker .l-month-year-pager .bar.right.pager .icon.major, .l-datetime-picker .l-month-year-pager .bar.right.val .icon.major, .s-menu-btn span.bar.right.l-click-area .icon.major, .bar.abs.right .major.t-item-icon, .bar.right.l-inspect .major.t-item-icon, .l-datetime-picker .l-month-year-pager .bar.right.pager .major.t-item-icon, .l-datetime-picker .l-month-year-pager .bar.right.val .major.t-item-icon, .s-menu-btn span.bar.right.l-click-area .major.t-item-icon, @@ -4250,7 +4350,7 @@ span.req { .l-datetime-picker .l-month-year-pager .bar.val .right .major.t-item-icon, .s-menu-btn span.bar.l-click-area .right .major.t-item-icon { margin-left: 15px; } - /* line 89, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 72, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs .l-flex .left, .bar.l-inspect .l-flex .left, .l-datetime-picker .l-month-year-pager .bar.pager .l-flex .left, .l-datetime-picker .l-month-year-pager .bar.val .l-flex .left, .s-menu-btn span.bar.l-click-area .l-flex .left, .bar.abs .l-flex .right, @@ -4266,34 +4366,34 @@ span.req { .s-menu-btn span.bar.l-flex.l-click-area .right { width: auto; } -/* line 98, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 81, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .browse-area, .user-environ .editor { top: 0; left: 0; right: 0; bottom: 25px; } -/* line 105, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 88, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .browse-area > .contents, .user-environ .edit-area > .contents { left: 0; right: 0; } -/* line 111, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 94, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .edit-area { top: 45px; left: 10px; right: 10px; bottom: 35px; } - /* line 117, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 100, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .edit-area .tool-bar { bottom: auto; height: 30px; line-height: 25px; } - /* line 122, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 105, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .edit-area .object-holder.work-area { top: 40px; overflow: auto; } -/* line 129, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 112, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar { overflow: hidden; position: absolute; @@ -4309,7 +4409,7 @@ span.req { background: #000; color: gray; font-size: .7rem; } - /* line 138, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 121, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar .status-holder { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; @@ -4328,7 +4428,7 @@ span.req { right: 120px; text-transform: uppercase; z-index: 1; } - /* line 147, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 130, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar .app-logo { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; @@ -4345,143 +4445,87 @@ span.req { left: auto; width: 105px; z-index: 2; } - /* line 154, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 137, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar .app-logo.logo-openmctweb { background: url("../../../../general/res/images/logo-openmctweb.svg") no-repeat center center; } -/* line 161, ../../../../general/res/sass/user-environ/_layout.scss */ -.cols { - overflow: hidden; - *zoom: 1; } - /* line 163, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols .col { - -moz-box-sizing: border-box; - -webkit-box-sizing: border-box; - box-sizing: border-box; - overflow: hidden; - *zoom: 1; - float: left; - margin-left: 1.5%; - padding-left: 5px; - position: relative; } - /* line 171, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols .col:first-child { - margin-left: 0; - padding-left: 0; } - /* line 178, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-2 .col-1 { - min-width: 250px; - width: 48.5%; } - /* line 184, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-2-ff .col-100px { - width: 100px; } - /* line 191, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-6 .col-1 { - min-width: 83.33333px; - width: 15.16667%; } - /* line 197, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-16 .col-1 { - min-width: 31.25px; - width: 4.75%; } - /* line 200, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-16 .col-2 { - min-width: 62.5px; - width: 11%; } - /* line 203, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-16 .col-7 { - min-width: 218.75px; - width: 42.25%; } - /* line 209, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-32 .col-2 { - min-width: 31.25px; - width: 4.75%; } - /* line 212, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-32 .col-15 { - min-width: 234.375px; - width: 45.375%; } - /* line 216, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols .l-row { - overflow: hidden; - *zoom: 1; - padding: 5px 0; } - -/* line 226, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 148, ../../../../general/res/sass/user-environ/_layout.scss */ .browse-mode .split-layout .split-pane-component.pane.treeview.left { min-width: 150px; max-width: 800px; width: 25%; } -/* line 231, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 153, ../../../../general/res/sass/user-environ/_layout.scss */ .browse-mode .split-layout .split-pane-component.pane.t-inspect.right { min-width: 200px; max-width: 600px; width: 20%; } -/* line 243, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 165, ../../../../general/res/sass/user-environ/_layout.scss */ .edit-mode .split-layout .split-pane-component.pane.right { width: 15%; } - /* line 245, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 167, ../../../../general/res/sass/user-environ/_layout.scss */ .edit-mode .split-layout .split-pane-component.pane.right .pane.bottom { min-height: 50px; height: 30%; } -/* line 253, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 175, ../../../../general/res/sass/user-environ/_layout.scss */ .pane { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; position: absolute; } - /* line 257, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 179, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .pane-header { text-transform: uppercase; height: 24px; line-height: 24px; margin-bottom: 5px; } - /* line 264, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 186, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .primary-pane { z-index: 2; } - /* line 282, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 204, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .search-holder { top: 34px; } - /* line 285, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 207, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .tree-holder { overflow: auto; top: 64px; } - /* line 291, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 213, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane { z-index: 5; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 291, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 213, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane { top: 10px; height: 24px; line-height: 24px; } - /* line 300, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 222, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane:after { opacity: 0; } - /* line 305, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 227, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.collapsed:before { opacity: 0; } - /* line 308, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 230, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.collapsed:after { opacity: 1; } - /* line 312, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 234, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left { left: 0; -moz-transform: translateX(-34px); -ms-transform: translateX(-34px); -webkit-transform: translateX(-34px); transform: translateX(-34px); } - /* line 315, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 237, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:after { content: '\6d'; } - /* line 318, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 240, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed { left: 0; -moz-transform: translateX(-15px); -ms-transform: translateX(-15px); -webkit-transform: translateX(-15px); transform: translateX(-15px); } - /* line 322, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 244, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -4499,16 +4543,16 @@ span.req { -o-transition-delay: 200ms; -webkit-transition-delay: 200ms; transition-delay: 200ms; } - /* line 326, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 248, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right { right: 10px; } - /* line 328, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 250, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right:after { content: '\e615'; } - /* line 331, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 253, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right.collapsed { right: 5px; } } - /* line 340, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 262, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.items .object-browse-bar .left.abs, .pane.items .object-browse-bar .left.l-inspect, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.pager, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.pager, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.val, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.val, .pane.items .object-browse-bar .s-menu-btn span.left.l-click-area, .s-menu-btn .pane.items .object-browse-bar span.left.l-click-area, @@ -4522,7 +4566,7 @@ span.req { .s-menu-btn .pane.items .object-browse-bar span.right.l-click-area { top: auto; } -/* line 348, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 270, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout { /* &.vertical { // Slides left and right @@ -4537,36 +4581,36 @@ span.req { } } }*/ } - /* line 351, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 273, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout.horizontal > .pane { margin-top: 5px; } - /* line 354, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 276, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout.horizontal > .pane:first-child { margin-top: 0; } - /* line 374, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 296, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-create-and-search { top: 10px; right: 0; bottom: 10px; left: 10px; } - /* line 381, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 303, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-object-and-inspector { top: 0; right: 0; bottom: 0; left: 0; } - /* line 386, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 308, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-object-and-inspector .holder-object { top: 10px; bottom: 10px; } - /* line 390, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 312, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-object-and-inspector .holder-inspector-elements { top: 10px; bottom: 10px; left: 10px; right: 10px; } -/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 322, ../../../../general/res/sass/user-environ/_layout.scss */ .object-holder { overflow: auto; position: absolute; @@ -4577,11 +4621,11 @@ span.req { width: auto; height: auto; top: 34px; } - /* line 293, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 326, ../../../../general/res/sass/user-environ/_layout.scss */ .object-holder.l-controls-visible.l-time-controller-visible { bottom: 88px; } -/* line 299, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 332, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .s-btn, .object-browse-bar .s-menu-btn, .top-bar .buttons-main .s-btn, .top-bar .buttons-main .s-menu-btn, @@ -4593,12 +4637,12 @@ span.req { line-height: 25px; vertical-align: top; } -/* line 426, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 345, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .view-switcher, .top-bar .view-switcher { margin-right: 20px; } -/* line 431, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 350, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar { overflow: visible; position: absolute; @@ -4614,55 +4658,34 @@ span.req { height: 24px; line-height: 24px; white-space: nowrap; } - /* line 439, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 358, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .left { padding-right: 20px; } - /* line 441, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 360, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .left .l-back { display: inline-block; float: left; margin-right: 10px; } -/* line 449, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 368, ../../../../general/res/sass/user-environ/_layout.scss */ .l-flex { display: flex; display: -webkit-flex; flex-flow: row nowrap; -webkit-flex-flow: row nowrap; } - /* line 452, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 371, ../../../../general/res/sass/user-environ/_layout.scss */ .l-flex .left { flex: 1 1 0; -webkit-flex: 1 1 0; padding-right: 10px; } -/* line 462, ../../../../general/res/sass/user-environ/_layout.scss */ -.pane-tree-hidden { - /*.holder-create-and-search { - @include trans-prop-nice((top, left), 250ms); - top: $ueTopBarH + $interiorMargin; - left: -1 * $bodyMargin !important; - .create-btn { - @include border-left-radius(0); - @include trans-prop-nice((width), 250ms); - width: $uePaneMiniTabW !important; - text-align: center !important; - padding: 0; - .title-label, - &:after { - display: none; - } - &:before { - font-size: 9px; - } - } - }*/ } - /* line 465, ../../../../general/res/sass/user-environ/_layout.scss */ - .pane-tree-hidden .tree-holder, - .pane-tree-hidden .splitter-treeview, - .pane-tree-hidden .holder-create-and-search { - opacity: 0; } +/* line 384, ../../../../general/res/sass/user-environ/_layout.scss */ +.pane-tree-hidden .tree-holder, +.pane-tree-hidden .splitter-treeview, +.pane-tree-hidden .holder-create-and-search { + opacity: 0; } -/* line 494, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 394, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .tree-holder, .pane-tree-showing .splitter-treeview { -moz-transition-property: opacity; @@ -4682,7 +4705,7 @@ span.req { -webkit-transition-delay: 250ms; transition-delay: 250ms; opacity: 1; } -/* line 500, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .holder-create-and-search { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -4701,7 +4724,7 @@ span.req { -webkit-transition-delay: 200ms; transition-delay: 200ms; } -/* line 507, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 407, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-showing .l-object-and-inspector .l-inspect, .pane-inspect-showing .l-object-and-inspector .splitter-inspect { -moz-transition-property: opacity; @@ -4722,25 +4745,25 @@ span.req { transition-delay: 250ms; opacity: 1; } -/* line 516, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 416, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .l-inspect, .pane-inspect-hidden .l-object-and-inspector .splitter-inspect { opacity: 0; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 524, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .tree-holder { padding-right: 5px; } - /* line 528, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 428, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .pane.right.primary-pane { left: 20px !important; } - /* line 531, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 431, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .pane.left { right: 20px !important; } - /* line 534, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 434, ../../../../general/res/sass/user-environ/_layout.scss */ .pane:not(.resizing) { -moz-transition-property: width, left, right; -o-transition-property: width, left, right; @@ -5948,9 +5971,9 @@ ul.tree { *****************************************************************************/ /* line 22, ../../../../general/res/sass/user-environ/_top-bar.scss */ .top-bar { - /* .title { - color: #fff; - }*/ } + /* .title { + color: #fff; + }*/ } /* line 23, ../../../../general/res/sass/user-environ/_top-bar.scss */ .top-bar.browse, .top-bar.edit { border-bottom: 1px solid rgba(153, 153, 153, 0.1); diff --git a/platform/commonUI/themes/snow/res/css/theme-snow.css b/platform/commonUI/themes/snow/res/css/theme-snow.css index 6ec5b55434..ed1e1cbcbf 100644 --- a/platform/commonUI/themes/snow/res/css/theme-snow.css +++ b/platform/commonUI/themes/snow/res/css/theme-snow.css @@ -20,7 +20,7 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* line 5, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 5, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, @@ -41,38 +41,38 @@ time, mark, audio, video { font-size: 100%; vertical-align: baseline; } -/* line 22, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 22, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ html { line-height: 1; } -/* line 24, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 24, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ ol, ul { list-style: none; } -/* line 26, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 26, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ table { border-collapse: collapse; border-spacing: 0; } -/* line 28, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 28, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ caption, th, td { text-align: left; font-weight: normal; vertical-align: middle; } -/* line 30, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 30, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ q, blockquote { quotes: none; } - /* line 103, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ + /* line 103, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ q:before, q:after, blockquote:before, blockquote:after { content: ""; content: none; } -/* line 32, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 32, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ a img { border: none; } -/* line 116, ../../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ +/* line 116, ../../../../../../../../../../Library/Ruby/Gems/2.0.0/gems/compass-core-1.0.3/stylesheets/compass/reset/_utilities.scss */ article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary { display: block; } @@ -306,7 +306,7 @@ a.disabled { *****************************************************************************/ /************************** FONTS */ @font-face { - /* + /* * Use https://icomoon.io/app with /platform/commonUI/general/res/fonts/symbols/icomoon.io-WTD-symbols-project.json */ font-family: 'symbolsfont'; @@ -428,6 +428,113 @@ mct-container { .sep { color: rgba(255, 255, 255, 0.2); } +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ +/********************************************* COLUMN LAYOUTS STYLES */ +/* line 34, ../../../../general/res/sass/_archetypes.scss */ +.cols { + overflow: hidden; + *zoom: 1; } + /* line 36, ../../../../general/res/sass/_archetypes.scss */ + .cols .col { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + overflow: hidden; + *zoom: 1; + float: left; + margin-left: 1.5%; + padding-left: 5px; + position: relative; } + /* line 44, ../../../../general/res/sass/_archetypes.scss */ + .cols .col:first-child { + margin-left: 0; + padding-left: 0; } + /* line 51, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-2 .col-1 { + min-width: 250px; + width: 48.5%; } + /* line 57, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-2-ff .col-100px { + width: 100px; } + /* line 64, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-6 .col-1 { + min-width: 83.33333px; + width: 15.16667%; } + /* line 70, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-16 .col-1 { + min-width: 31.25px; + width: 4.75%; } + /* line 73, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-16 .col-2 { + min-width: 62.5px; + width: 11%; } + /* line 76, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-16 .col-7 { + min-width: 218.75px; + width: 42.25%; } + /* line 82, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-32 .col-2 { + min-width: 31.25px; + width: 4.75%; } + /* line 85, ../../../../general/res/sass/_archetypes.scss */ + .cols.cols-32 .col-15 { + min-width: 234.375px; + width: 45.375%; } + /* line 89, ../../../../general/res/sass/_archetypes.scss */ + .cols .l-row { + overflow: hidden; + *zoom: 1; + padding: 5px 0; } + +/********************************************* FLEX STYLES */ +/* line 95, ../../../../general/res/sass/_archetypes.scss */ +.l-flex-row, +.l-flex-col { + display: -webkit-flex; + display: flex; + -webkit-flex-wrap: nowrap; + flex-wrap: nowrap; } + /* line 100, ../../../../general/res/sass/_archetypes.scss */ + .l-flex-row .flex-elem:not(.grows), + .l-flex-col .flex-elem:not(.grows) { + -webkit-flex: 0 1 auto; + flex: 0 1 auto; } + /* line 103, ../../../../general/res/sass/_archetypes.scss */ + .l-flex-row .flex-elem.grows, + .l-flex-col .flex-elem.grows { + -webkit-flex: 1 1 auto; + flex: 1 1 auto; } + +/* line 109, ../../../../general/res/sass/_archetypes.scss */ +.l-flex-row { + -webkit-flex-direction: row; + flex-direction: row; } + +/* line 114, ../../../../general/res/sass/_archetypes.scss */ +.l-flex-col { + -webkit-flex-direction: column; + flex-direction: column; } + /***************************************************************************** * Open MCT Web, Copyright (c) 2014-2015, United States Government * as represented by the Administrator of the National Aeronautics and Space @@ -1025,11 +1132,11 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { background-image: linear-gradient(90deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.05) 70%, rgba(0, 0, 0, 0.2) 100%); } /*.browse-area .splitter { - top: 0; //$ueTopBarH + $interiorMarginLg; + top: 0; //$ueTopBarH + $interiorMarginLg; } .edit-area .splitter { - top: 0; + top: 0; }*/ /***************************************************************************** * Open MCT Web, Copyright (c) 2014-2015, United States Government @@ -2063,23 +2170,23 @@ label.checkbox.custom { /* line 204, ../../../../general/res/sass/controls/_controls.scss */ .object-header { font-size: 1em; } - /* line 236, ../../../../general/res/sass/controls/_controls.scss */ + /* line 208, ../../../../general/res/sass/controls/_controls.scss */ .object-header > .type-icon { color: #b3b3b3; font-size: 120%; float: left; margin-right: 5px; } - /* line 243, ../../../../general/res/sass/controls/_controls.scss */ + /* line 215, ../../../../general/res/sass/controls/_controls.scss */ .object-header .l-elem-wrapper { -webkit-justify-content: flex-start; justify-content: flex-start; } - /* line 247, ../../../../general/res/sass/controls/_controls.scss */ + /* line 218, ../../../../general/res/sass/controls/_controls.scss */ .object-header .l-elem-wrapper mct-representation { min-width: 0.7em; } - /* line 255, ../../../../general/res/sass/controls/_controls.scss */ + /* line 226, ../../../../general/res/sass/controls/_controls.scss */ .object-header .action { margin-right: 5px; } - /* line 259, ../../../../general/res/sass/controls/_controls.scss */ + /* line 230, ../../../../general/res/sass/controls/_controls.scss */ .object-header .title-label { color: #666; overflow: hidden; @@ -2088,13 +2195,13 @@ label.checkbox.custom { flex: 0 1 auto; -webkit-flex: 0 1 auto; padding-right: 0.35em; } - /* line 269, ../../../../general/res/sass/controls/_controls.scss */ + /* line 240, ../../../../general/res/sass/controls/_controls.scss */ .object-header .context-available { font-size: 0.7em; flex: 0 0 1; -webkit-flex: 0 0 1; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 276, ../../../../general/res/sass/controls/_controls.scss */ + /* line 247, ../../../../general/res/sass/controls/_controls.scss */ .object-header .context-available { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -2113,7 +2220,7 @@ label.checkbox.custom { -webkit-transition-delay: 0; transition-delay: 0; opacity: 0; } - /* line 259, ../../../../general/res/sass/controls/_controls.scss */ + /* line 252, ../../../../general/res/sass/controls/_controls.scss */ .object-header:hover .context-available { opacity: 1; } } @@ -2127,12 +2234,12 @@ label.checkbox.custom { @keyframes progress { 100% { background-position: 20px center; } } -/* line 281, ../../../../general/res/sass/controls/_controls.scss */ +/* line 274, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar { display: inline-block; overflow: hidden; position: relative; } - /* line 287, ../../../../general/res/sass/controls/_controls.scss */ + /* line 280, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar .progress-amt-holder { overflow: hidden; position: absolute; @@ -2142,7 +2249,7 @@ label.checkbox.custom { left: 1px; width: auto; height: auto; } - /* line 290, ../../../../general/res/sass/controls/_controls.scss */ + /* line 283, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar .progress-amt, .l-progress-bar .progress-amt:before, .l-progress-bar .progress-amt:after { @@ -2156,14 +2263,14 @@ label.checkbox.custom { height: auto; display: block; content: ''; } - /* line 298, ../../../../general/res/sass/controls/_controls.scss */ + /* line 291, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar .progress-amt { right: auto; } - /* line 303, ../../../../general/res/sass/controls/_controls.scss */ + /* line 296, ../../../../general/res/sass/controls/_controls.scss */ .l-progress-bar.indeterminate .progress-amt { width: 100% !important; } -/* line 309, ../../../../general/res/sass/controls/_controls.scss */ +/* line 302, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar { -moz-border-radius: 4px; -webkit-border-radius: 4px; @@ -2172,7 +2279,7 @@ label.checkbox.custom { -webkit-box-shadow: inset rgba(0, 0, 0, 0.3) 0 1px 4px; box-shadow: inset rgba(0, 0, 0, 0.3) 0 1px 4px; background: rgba(0, 0, 0, 0.1); } - /* line 314, ../../../../general/res/sass/controls/_controls.scss */ + /* line 307, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar .progress-amt { -moz-border-radius: 4px; -webkit-border-radius: 4px; @@ -2199,10 +2306,10 @@ label.checkbox.custom { -o-transition-delay: 0; -webkit-transition-delay: 0; transition-delay: 0; } - /* line 319, ../../../../general/res/sass/controls/_controls.scss */ + /* line 312, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar .progress-amt:before { background-color: #0a0; } - /* line 322, ../../../../general/res/sass/controls/_controls.scss */ + /* line 315, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar .progress-amt:after { background-image: url(''); background-size: 100%; @@ -2210,7 +2317,7 @@ label.checkbox.custom { background-image: -moz-linear-gradient(rgba(0, 0, 0, 0) 5%, rgba(255, 255, 255, 0.25) 30%, rgba(0, 0, 0, 0) 100%); background-image: -webkit-linear-gradient(rgba(0, 0, 0, 0) 5%, rgba(255, 255, 255, 0.25) 30%, rgba(0, 0, 0, 0) 100%); background-image: linear-gradient(rgba(0, 0, 0, 0) 5%, rgba(255, 255, 255, 0.25) 30%, rgba(0, 0, 0, 0) 100%); } - /* line 331, ../../../../general/res/sass/controls/_controls.scss */ + /* line 324, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar:not(.indeterminate) .progress-amt:before { -moz-animation: progress 0.4s linear infinite; -webkit-animation: progress 0.4s linear infinite; @@ -2223,7 +2330,7 @@ label.checkbox.custom { background-position: 0 center; background-repeat: repeat-x; background-size: 20px 40%; } - /* line 339, ../../../../general/res/sass/controls/_controls.scss */ + /* line 332, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar.indeterminate .progress-amt:before { -moz-animation: progress 0.6s linear infinite; -webkit-animation: progress 0.6s linear infinite; @@ -2235,12 +2342,12 @@ label.checkbox.custom { background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%); background-repeat: repeat; background-size: 20px 20px; } - /* line 344, ../../../../general/res/sass/controls/_controls.scss */ + /* line 337, ../../../../general/res/sass/controls/_controls.scss */ .s-progress-bar.indeterminate .progress-amt:after { display: none; } /******************************************************** SLIDERS */ -/* line 352, ../../../../general/res/sass/controls/_controls.scss */ +/* line 345, ../../../../general/res/sass/controls/_controls.scss */ .slider .slot { width: auto; position: absolute; @@ -2248,7 +2355,7 @@ label.checkbox.custom { right: 0; bottom: 0; left: 0; } -/* line 362, ../../../../general/res/sass/controls/_controls.scss */ +/* line 355, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob { -moz-transition-property: opacity, background-color, border-color, color; -o-transition-property: opacity, background-color, border-color, color; @@ -2274,10 +2381,10 @@ label.checkbox.custom { auto: 0; bottom: auto; left: auto; } - /* line 365, ../../../../general/res/sass/controls/_controls.scss */ + /* line 358, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob:hover { background-color: rgba(0, 153, 204, 0.7); } -/* line 376, ../../../../general/res/sass/controls/_controls.scss */ +/* line 369, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob-l { -moz-border-radius-topleft: 10px; -webkit-border-top-left-radius: 10px; @@ -2286,7 +2393,7 @@ label.checkbox.custom { -webkit-border-bottom-left-radius: 10px; border-bottom-left-radius: 10px; cursor: w-resize; } -/* line 322, ../../../../general/res/sass/controls/_controls.scss */ +/* line 373, ../../../../general/res/sass/controls/_controls.scss */ .slider .knob-r { -moz-border-radius-topright: 10px; -webkit-border-top-right-radius: 10px; @@ -2295,7 +2402,7 @@ label.checkbox.custom { -webkit-border-bottom-right-radius: 10px; border-bottom-right-radius: 10px; cursor: e-resize; } -/* line 326, ../../../../general/res/sass/controls/_controls.scss */ +/* line 377, ../../../../general/res/sass/controls/_controls.scss */ .slider .range { -moz-transition-property: opacity, background-color, border-color, color; -o-transition-property: opacity, background-color, border-color, color; @@ -2322,12 +2429,12 @@ label.checkbox.custom { left: auto; height: auto; width: auto; } - /* line 337, ../../../../general/res/sass/controls/_controls.scss */ + /* line 388, ../../../../general/res/sass/controls/_controls.scss */ .slider .range:hover { background-color: rgba(0, 153, 204, 0.4); } /******************************************************** DATETIME PICKER */ -/* line 344, ../../../../general/res/sass/controls/_controls.scss */ +/* line 395, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker { -moz-user-select: -moz-none; -ms-user-select: none; @@ -2336,65 +2443,65 @@ label.checkbox.custom { font-size: 0.8rem; padding: 10px !important; width: 230px; } - /* line 350, ../../../../general/res/sass/controls/_controls.scss */ + /* line 401, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager { height: 15px; margin-bottom: 5px; position: relative; } - /* line 420, ../../../../general/res/sass/controls/_controls.scss */ + /* line 413, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager { width: 20px; } - /* line 423, ../../../../general/res/sass/controls/_controls.scss */ + /* line 416, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.prev { right: auto; } - /* line 425, ../../../../general/res/sass/controls/_controls.scss */ + /* line 418, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.prev:before { content: "\3c"; } - /* line 429, ../../../../general/res/sass/controls/_controls.scss */ + /* line 422, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.next { left: auto; text-align: right; } - /* line 432, ../../../../general/res/sass/controls/_controls.scss */ + /* line 425, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .pager.next:before { content: "\3e"; } - /* line 437, ../../../../general/res/sass/controls/_controls.scss */ + /* line 430, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-month-year-pager .val { text-align: center; left: 25px; right: 25px; } - /* line 443, ../../../../general/res/sass/controls/_controls.scss */ + /* line 436, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-calendar, .l-datetime-picker .l-time-selects { border-top: 1px solid rgba(102, 102, 102, 0.2); } - /* line 447, ../../../../general/res/sass/controls/_controls.scss */ + /* line 440, ../../../../general/res/sass/controls/_controls.scss */ .l-datetime-picker .l-time-selects { line-height: 22px; } /******************************************************** CALENDAR */ -/* line 397, ../../../../general/res/sass/controls/_controls.scss */ +/* line 448, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row { display: -webkit-flex; display: flex; -webkit-flex-flow: row nowrap; flex-flow: row nowrap; margin-top: 1px; } - /* line 459, ../../../../general/res/sass/controls/_controls.scss */ + /* line 452, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row:first-child { margin-top: 0; } - /* line 462, ../../../../general/res/sass/controls/_controls.scss */ + /* line 455, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row li { -webkit-flex: 1 0; flex: 1 0; margin-left: 1px; padding: 5px; text-align: center; } - /* line 468, ../../../../general/res/sass/controls/_controls.scss */ + /* line 461, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row li:first-child { margin-left: 0; } - /* line 472, ../../../../general/res/sass/controls/_controls.scss */ + /* line 465, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-header li { color: #999999; } - /* line 475, ../../../../general/res/sass/controls/_controls.scss */ + /* line 468, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li { -moz-transition-property: background-color; -o-transition-property: background-color; @@ -2413,31 +2520,31 @@ label.checkbox.custom { -webkit-transition-delay: 0; transition-delay: 0; cursor: pointer; } - /* line 478, ../../../../general/res/sass/controls/_controls.scss */ + /* line 471, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li.in-month { background-color: #f2f2f2; } - /* line 481, ../../../../general/res/sass/controls/_controls.scss */ + /* line 474, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li .sub { color: #999999; font-size: 0.8em; } - /* line 485, ../../../../general/res/sass/controls/_controls.scss */ + /* line 478, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li.selected { background: #1ac6ff; color: #fcfcfc; } - /* line 488, ../../../../general/res/sass/controls/_controls.scss */ + /* line 481, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li.selected .sub { color: inherit; } - /* line 492, ../../../../general/res/sass/controls/_controls.scss */ + /* line 485, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li:hover { background-color: #0099cc; color: #fff; } - /* line 495, ../../../../general/res/sass/controls/_controls.scss */ + /* line 488, ../../../../general/res/sass/controls/_controls.scss */ .l-calendar ul.l-cal-row.l-body li:hover .sub { color: inherit; } /******************************************************** BROWSER ELEMENTS */ @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 448, ../../../../general/res/sass/controls/_controls.scss */ + /* line 499, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar { -moz-border-radius: 2px; -webkit-border-radius: 2px; @@ -2452,7 +2559,7 @@ label.checkbox.custom { height: 10px; width: 10px; } - /* line 457, ../../../../general/res/sass/controls/_controls.scss */ + /* line 508, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar-thumb { background-image: url(''); background-size: 100%; @@ -2466,7 +2573,7 @@ label.checkbox.custom { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; } - /* line 466, ../../../../general/res/sass/controls/_controls.scss */ + /* line 517, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar-thumb:hover { background-image: url(''); background-size: 100%; @@ -2475,7 +2582,7 @@ label.checkbox.custom { background-image: -webkit-linear-gradient(#00ace6, #0099cc 20px); background-image: linear-gradient(#00ace6, #0099cc 20px); } - /* line 471, ../../../../general/res/sass/controls/_controls.scss */ + /* line 522, ../../../../general/res/sass/controls/_controls.scss */ ::-webkit-scrollbar-corner { background: rgba(0, 0, 0, 0.1); } } /***************************************************************************** @@ -3840,15 +3947,15 @@ textarea { /* line 29, ../../../../general/res/sass/forms/_datetime.scss */ .complex.datetime { /* - .field-hints, - .fields { - } - - - .field-hints { - - } - */ } + .field-hints, + .fields { + } + + + .field-hints { + + } + */ } /* line 30, ../../../../general/res/sass/forms/_datetime.scss */ .complex.datetime span { display: inline-block; @@ -4095,26 +4202,19 @@ span.req { * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/*.holder-all { - $myM: 0; // $interiorMarginSm; - top: $myM; - right: $myM; - bottom: $myM; - left: $myM; -}*/ -/* line 40, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 23, ../../../../general/res/sass/user-environ/_layout.scss */ .browse-area, .edit-area, .editor { position: absolute; } -/* line 46, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 29, ../../../../general/res/sass/user-environ/_layout.scss */ .editor { -moz-border-radius: 6px; -webkit-border-radius: 6px; border-radius: 6px; } -/* line 50, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 33, ../../../../general/res/sass/user-environ/_layout.scss */ .contents { box-sizing: border-box; position: absolute; @@ -4122,21 +4222,21 @@ span.req { right: 0; bottom: 0; left: 0; } - /* line 58, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 41, ../../../../general/res/sass/user-environ/_layout.scss */ .contents.nomargin { right: 0px; bottom: 0px; left: 0px; } -/* line 67, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 50, ../../../../general/res/sass/user-environ/_layout.scss */ .bar .icon.major, .bar .major.t-item-icon { margin-right: 5px; } -/* line 70, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 53, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs, .bar.l-inspect, .l-datetime-picker .l-month-year-pager .bar.pager, .l-datetime-picker .l-month-year-pager .bar.val, .s-menu-btn span.bar.l-click-area { text-wrap: none; white-space: nowrap; } - /* line 73, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 56, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs.left, .bar.left.l-inspect, .l-datetime-picker .l-month-year-pager .bar.left.pager, .l-datetime-picker .l-month-year-pager .bar.left.val, .s-menu-btn span.bar.left.l-click-area, .bar.abs .left, @@ -4146,7 +4246,7 @@ span.req { .s-menu-btn span.bar.l-click-area .left { width: 45%; right: auto; } - /* line 78, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 61, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs.right, .bar.right.l-inspect, .l-datetime-picker .l-month-year-pager .bar.right.pager, .l-datetime-picker .l-month-year-pager .bar.right.val, .s-menu-btn span.bar.right.l-click-area, .bar.abs .right, @@ -4157,7 +4257,7 @@ span.req { width: 45%; left: auto; text-align: right; } - /* line 83, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 66, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs.right .icon.major, .bar.right.l-inspect .icon.major, .l-datetime-picker .l-month-year-pager .bar.right.pager .icon.major, .l-datetime-picker .l-month-year-pager .bar.right.val .icon.major, .s-menu-btn span.bar.right.l-click-area .icon.major, .bar.abs.right .major.t-item-icon, .bar.right.l-inspect .major.t-item-icon, .l-datetime-picker .l-month-year-pager .bar.right.pager .major.t-item-icon, .l-datetime-picker .l-month-year-pager .bar.right.val .major.t-item-icon, .s-menu-btn span.bar.right.l-click-area .major.t-item-icon, @@ -4172,7 +4272,7 @@ span.req { .l-datetime-picker .l-month-year-pager .bar.val .right .major.t-item-icon, .s-menu-btn span.bar.l-click-area .right .major.t-item-icon { margin-left: 15px; } - /* line 89, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 72, ../../../../general/res/sass/user-environ/_layout.scss */ .bar.abs .l-flex .left, .bar.l-inspect .l-flex .left, .l-datetime-picker .l-month-year-pager .bar.pager .l-flex .left, .l-datetime-picker .l-month-year-pager .bar.val .l-flex .left, .s-menu-btn span.bar.l-click-area .l-flex .left, .bar.abs .l-flex .right, @@ -4188,34 +4288,34 @@ span.req { .s-menu-btn span.bar.l-flex.l-click-area .right { width: auto; } -/* line 98, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 81, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .browse-area, .user-environ .editor { top: 0; left: 0; right: 0; bottom: 25px; } -/* line 105, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 88, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .browse-area > .contents, .user-environ .edit-area > .contents { left: 0; right: 0; } -/* line 111, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 94, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .edit-area { top: 45px; left: 10px; right: 10px; bottom: 35px; } - /* line 117, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 100, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .edit-area .tool-bar { bottom: auto; height: 30px; line-height: 25px; } - /* line 122, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 105, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .edit-area .object-holder.work-area { top: 40px; overflow: auto; } -/* line 129, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 112, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar { overflow: hidden; position: absolute; @@ -4231,7 +4331,7 @@ span.req { background: #000; color: white; font-size: .7rem; } - /* line 138, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 121, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar .status-holder { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; @@ -4250,7 +4350,7 @@ span.req { right: 120px; text-transform: uppercase; z-index: 1; } - /* line 147, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 130, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar .app-logo { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; @@ -4267,143 +4367,87 @@ span.req { left: auto; width: 105px; z-index: 2; } - /* line 154, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 137, ../../../../general/res/sass/user-environ/_layout.scss */ .user-environ .ue-bottom-bar .app-logo.logo-openmctweb { background: url("../../../../general/res/images/logo-openmctweb.svg") no-repeat center center; } -/* line 161, ../../../../general/res/sass/user-environ/_layout.scss */ -.cols { - overflow: hidden; - *zoom: 1; } - /* line 163, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols .col { - -moz-box-sizing: border-box; - -webkit-box-sizing: border-box; - box-sizing: border-box; - overflow: hidden; - *zoom: 1; - float: left; - margin-left: 1.5%; - padding-left: 5px; - position: relative; } - /* line 171, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols .col:first-child { - margin-left: 0; - padding-left: 0; } - /* line 178, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-2 .col-1 { - min-width: 250px; - width: 48.5%; } - /* line 184, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-2-ff .col-100px { - width: 100px; } - /* line 191, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-6 .col-1 { - min-width: 83.33333px; - width: 15.16667%; } - /* line 197, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-16 .col-1 { - min-width: 31.25px; - width: 4.75%; } - /* line 200, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-16 .col-2 { - min-width: 62.5px; - width: 11%; } - /* line 203, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-16 .col-7 { - min-width: 218.75px; - width: 42.25%; } - /* line 209, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-32 .col-2 { - min-width: 31.25px; - width: 4.75%; } - /* line 212, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols.cols-32 .col-15 { - min-width: 234.375px; - width: 45.375%; } - /* line 216, ../../../../general/res/sass/user-environ/_layout.scss */ - .cols .l-row { - overflow: hidden; - *zoom: 1; - padding: 5px 0; } - -/* line 226, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 148, ../../../../general/res/sass/user-environ/_layout.scss */ .browse-mode .split-layout .split-pane-component.pane.treeview.left { min-width: 150px; max-width: 800px; width: 25%; } -/* line 231, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 153, ../../../../general/res/sass/user-environ/_layout.scss */ .browse-mode .split-layout .split-pane-component.pane.t-inspect.right { min-width: 200px; max-width: 600px; width: 20%; } -/* line 243, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 165, ../../../../general/res/sass/user-environ/_layout.scss */ .edit-mode .split-layout .split-pane-component.pane.right { width: 15%; } - /* line 245, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 167, ../../../../general/res/sass/user-environ/_layout.scss */ .edit-mode .split-layout .split-pane-component.pane.right .pane.bottom { min-height: 50px; height: 30%; } -/* line 253, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 175, ../../../../general/res/sass/user-environ/_layout.scss */ .pane { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; position: absolute; } - /* line 257, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 179, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .pane-header { text-transform: uppercase; height: 24px; line-height: 24px; margin-bottom: 5px; } - /* line 264, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 186, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .primary-pane { z-index: 2; } - /* line 282, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 204, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .search-holder { top: 34px; } - /* line 285, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 207, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .tree-holder { overflow: auto; top: 64px; } - /* line 291, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 213, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane { z-index: 5; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 291, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 213, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane { top: 10px; height: 24px; line-height: 24px; } - /* line 300, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 222, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane:after { opacity: 0; } - /* line 305, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 227, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.collapsed:before { opacity: 0; } - /* line 308, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 230, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.collapsed:after { opacity: 1; } - /* line 312, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 234, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left { left: 0; -moz-transform: translateX(-33px); -ms-transform: translateX(-33px); -webkit-transform: translateX(-33px); transform: translateX(-33px); } - /* line 315, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 237, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:after { content: '\6d'; } - /* line 318, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 240, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed { left: 0; -moz-transform: translateX(-15px); -ms-transform: translateX(-15px); -webkit-transform: translateX(-15px); transform: translateX(-15px); } - /* line 322, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 244, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -4421,16 +4465,16 @@ span.req { -o-transition-delay: 200ms; -webkit-transition-delay: 200ms; transition-delay: 200ms; } - /* line 326, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 248, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right { right: 10px; } - /* line 328, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 250, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right:after { content: '\e615'; } - /* line 331, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 253, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right.collapsed { right: 5px; } } - /* line 340, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 262, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.items .object-browse-bar .left.abs, .pane.items .object-browse-bar .left.l-inspect, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.pager, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.pager, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.val, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.val, .pane.items .object-browse-bar .s-menu-btn span.left.l-click-area, .s-menu-btn .pane.items .object-browse-bar span.left.l-click-area, @@ -4444,7 +4488,7 @@ span.req { .s-menu-btn .pane.items .object-browse-bar span.right.l-click-area { top: auto; } -/* line 348, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 270, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout { /* &.vertical { // Slides left and right @@ -4459,36 +4503,36 @@ span.req { } } }*/ } - /* line 351, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 273, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout.horizontal > .pane { margin-top: 5px; } - /* line 354, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 276, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout.horizontal > .pane:first-child { margin-top: 0; } - /* line 374, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 296, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-create-and-search { top: 10px; right: 0; bottom: 10px; left: 10px; } - /* line 381, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 303, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-object-and-inspector { top: 0; right: 0; bottom: 0; left: 0; } - /* line 386, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 308, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-object-and-inspector .holder-object { top: 10px; bottom: 10px; } - /* line 390, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 312, ../../../../general/res/sass/user-environ/_layout.scss */ .split-layout .holder.holder-object-and-inspector .holder-inspector-elements { top: 10px; bottom: 10px; left: 10px; right: 10px; } -/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 322, ../../../../general/res/sass/user-environ/_layout.scss */ .object-holder { overflow: auto; position: absolute; @@ -4499,11 +4543,11 @@ span.req { width: auto; height: auto; top: 34px; } - /* line 293, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 326, ../../../../general/res/sass/user-environ/_layout.scss */ .object-holder.l-controls-visible.l-time-controller-visible { bottom: 88px; } -/* line 299, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 332, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .s-btn, .object-browse-bar .s-menu-btn, .top-bar .buttons-main .s-btn, .top-bar .buttons-main .s-menu-btn, @@ -4515,12 +4559,12 @@ span.req { line-height: 25px; vertical-align: top; } -/* line 426, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 345, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .view-switcher, .top-bar .view-switcher { margin-right: 20px; } -/* line 431, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 350, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar { overflow: visible; position: absolute; @@ -4536,55 +4580,34 @@ span.req { height: 24px; line-height: 24px; white-space: nowrap; } - /* line 439, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 358, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .left { padding-right: 20px; } - /* line 441, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 360, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar .left .l-back { display: inline-block; float: left; margin-right: 10px; } -/* line 335, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 368, ../../../../general/res/sass/user-environ/_layout.scss */ .l-flex { display: flex; display: -webkit-flex; flex-flow: row nowrap; -webkit-flex-flow: row nowrap; } - /* line 452, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 371, ../../../../general/res/sass/user-environ/_layout.scss */ .l-flex .left { flex: 1 1 0; -webkit-flex: 1 1 0; padding-right: 10px; } -/* line 462, ../../../../general/res/sass/user-environ/_layout.scss */ -.pane-tree-hidden { - /*.holder-create-and-search { - @include trans-prop-nice((top, left), 250ms); - top: $ueTopBarH + $interiorMargin; - left: -1 * $bodyMargin !important; - .create-btn { - @include border-left-radius(0); - @include trans-prop-nice((width), 250ms); - width: $uePaneMiniTabW !important; - text-align: center !important; - padding: 0; - .title-label, - &:after { - display: none; - } - &:before { - font-size: 9px; - } - } - }*/ } - /* line 465, ../../../../general/res/sass/user-environ/_layout.scss */ - .pane-tree-hidden .tree-holder, - .pane-tree-hidden .splitter-treeview, - .pane-tree-hidden .holder-create-and-search { - opacity: 0; } +/* line 384, ../../../../general/res/sass/user-environ/_layout.scss */ +.pane-tree-hidden .tree-holder, +.pane-tree-hidden .splitter-treeview, +.pane-tree-hidden .holder-create-and-search { + opacity: 0; } -/* line 494, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 394, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .tree-holder, .pane-tree-showing .splitter-treeview { -moz-transition-property: opacity; @@ -4604,7 +4627,7 @@ span.req { -webkit-transition-delay: 250ms; transition-delay: 250ms; opacity: 1; } -/* line 500, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .holder-create-and-search { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -4623,7 +4646,7 @@ span.req { -webkit-transition-delay: 200ms; transition-delay: 200ms; } -/* line 507, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 407, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-showing .l-object-and-inspector .l-inspect, .pane-inspect-showing .l-object-and-inspector .splitter-inspect { -moz-transition-property: opacity; @@ -4644,25 +4667,25 @@ span.req { transition-delay: 250ms; opacity: 1; } -/* line 516, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 416, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .l-inspect, .pane-inspect-hidden .l-object-and-inspector .splitter-inspect { opacity: 0; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 524, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .tree-holder { padding-right: 5px; } - /* line 528, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 428, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .pane.right.primary-pane { left: 20px !important; } - /* line 531, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 431, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .pane.left { right: 20px !important; } - /* line 534, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 434, ../../../../general/res/sass/user-environ/_layout.scss */ .pane:not(.resizing) { -moz-transition-property: width, left, right; -o-transition-property: width, left, right; @@ -5850,9 +5873,9 @@ ul.tree { *****************************************************************************/ /* line 22, ../../../../general/res/sass/user-environ/_top-bar.scss */ .top-bar { - /* .title { - color: #fff; - }*/ } + /* .title { + color: #fff; + }*/ } /* line 23, ../../../../general/res/sass/user-environ/_top-bar.scss */ .top-bar.browse, .top-bar.edit { border-bottom: 1px solid rgba(102, 102, 102, 0.2); From f4325e2bb3ca745cf4ac3163f6e6b7a16c2a8bcf Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Wed, 4 Nov 2015 15:20:42 -0800 Subject: [PATCH 26/62] [Frontend] Inspector-related fixes open #244 Moved older .l-flex class out of layout and into archetypes, updated definition; --- .../general/res/sass/_archetypes.scss | 15 ++-- .../res/sass/user-environ/_layout.scss | 10 --- .../espresso/res/css/theme-espresso.css | 72 +++++++++---------- .../themes/snow/res/css/theme-snow.css | 72 +++++++++---------- 4 files changed, 81 insertions(+), 88 deletions(-) diff --git a/platform/commonUI/general/res/sass/_archetypes.scss b/platform/commonUI/general/res/sass/_archetypes.scss index 54389b0eac..88c34ad3bd 100644 --- a/platform/commonUI/general/res/sass/_archetypes.scss +++ b/platform/commonUI/general/res/sass/_archetypes.scss @@ -91,6 +91,7 @@ padding: $interiorMargin 0; } } + /********************************************* FLEX STYLES */ .l-flex-row, .l-flex-col { @@ -106,11 +107,13 @@ } } -.l-flex-row { - @include flex-direction(row); +.l-flex-row { @include flex-direction(row); } +.l-flex-col { @include flex-direction(column); } -} - -.l-flex-col { - @include flex-direction(column); +.l-flex { + @extend .l-flex-row; + .left { + @include flex(1 1 0); + padding-right: $interiorMarginLg; + } } \ No newline at end of file diff --git a/platform/commonUI/general/res/sass/user-environ/_layout.scss b/platform/commonUI/general/res/sass/user-environ/_layout.scss index f421487cf0..4e3045fff8 100644 --- a/platform/commonUI/general/res/sass/user-environ/_layout.scss +++ b/platform/commonUI/general/res/sass/user-environ/_layout.scss @@ -365,16 +365,6 @@ } } -.l-flex { - @include webkitVal('display', 'flex'); - @include webkitProp('flex-flow', 'row nowrap'); - .left { - //@include test(red); - @include webkitProp(flex, '1 1 0'); - padding-right: $interiorMarginLg; - } -} - // When the tree is hidden, these are the // classes used for the left menu and the // right representation. diff --git a/platform/commonUI/themes/espresso/res/css/theme-espresso.css b/platform/commonUI/themes/espresso/res/css/theme-espresso.css index 2da486e9bc..6cffc059da 100644 --- a/platform/commonUI/themes/espresso/res/css/theme-espresso.css +++ b/platform/commonUI/themes/espresso/res/css/theme-espresso.css @@ -508,33 +508,39 @@ mct-container { /********************************************* FLEX STYLES */ /* line 95, ../../../../general/res/sass/_archetypes.scss */ -.l-flex-row, +.l-flex-row, .l-flex, .l-flex-col { display: -webkit-flex; display: flex; -webkit-flex-wrap: nowrap; flex-wrap: nowrap; } /* line 100, ../../../../general/res/sass/_archetypes.scss */ - .l-flex-row .flex-elem:not(.grows), + .l-flex-row .flex-elem:not(.grows), .l-flex .flex-elem:not(.grows), .l-flex-col .flex-elem:not(.grows) { -webkit-flex: 0 1 auto; flex: 0 1 auto; } /* line 103, ../../../../general/res/sass/_archetypes.scss */ - .l-flex-row .flex-elem.grows, + .l-flex-row .flex-elem.grows, .l-flex .flex-elem.grows, .l-flex-col .flex-elem.grows { -webkit-flex: 1 1 auto; flex: 1 1 auto; } /* line 109, ../../../../general/res/sass/_archetypes.scss */ -.l-flex-row { +.l-flex-row, .l-flex { -webkit-flex-direction: row; flex-direction: row; } -/* line 114, ../../../../general/res/sass/_archetypes.scss */ +/* line 110, ../../../../general/res/sass/_archetypes.scss */ .l-flex-col { -webkit-flex-direction: column; flex-direction: column; } +/* line 116, ../../../../general/res/sass/_archetypes.scss */ +.l-flex .left { + -webkit-flex: 1 1 0; + flex: 1 1 0; + padding-right: 10px; } + /***************************************************************************** * Open MCT Web, Copyright (c) 2014-2015, United States Government * as represented by the Administrator of the National Aeronautics and Space @@ -1406,14 +1412,20 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { margin-right: 5px; vertical-align: bottom; } /* line 47, ../../../../general/res/sass/_inspector.scss */ + .l-inspect ul { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding-right: 5px; } + /* line 52, ../../../../general/res/sass/_inspector.scss */ .l-inspect ul li, .l-inspect em { display: block; position: relative; } - /* line 53, ../../../../general/res/sass/_inspector.scss */ + /* line 58, ../../../../general/res/sass/_inspector.scss */ .l-inspect ul li { margin-bottom: 10px; } - /* line 57, ../../../../general/res/sass/_inspector.scss */ + /* line 62, ../../../../general/res/sass/_inspector.scss */ .l-inspect em { -moz-border-radius: 3px; -webkit-border-radius: 3px; @@ -1423,34 +1435,34 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { margin-bottom: 5px; padding: 5px 5px; text-transform: uppercase; } - /* line 66, ../../../../general/res/sass/_inspector.scss */ + /* line 71, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties { padding: 3px 0; } - /* line 67, ../../../../general/res/sass/_inspector.scss */ + /* line 72, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties:not(.first) { border-top: 1px solid #474747; } - /* line 71, ../../../../general/res/sass/_inspector.scss */ + /* line 76, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties .label { color: #737373; text-transform: uppercase; } - /* line 75, ../../../../general/res/sass/_inspector.scss */ + /* line 80, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties .value { color: #bfbfbf; word-break: break-all; } - /* line 83, ../../../../general/res/sass/_inspector.scss */ + /* line 88, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location .location-item { cursor: pointer; display: inline-block; position: relative; padding: 2px 4px; } - /* line 88, ../../../../general/res/sass/_inspector.scss */ + /* line 93, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location .location-item:hover { background: rgba(153, 153, 153, 0.1); color: #cccccc; } - /* line 91, ../../../../general/res/sass/_inspector.scss */ + /* line 96, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location .location-item:hover .icon, .l-inspect .inspector-location .location-item:hover .t-item-icon { color: #33ccff; } - /* line 96, ../../../../general/res/sass/_inspector.scss */ + /* line 101, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location:not(.last) .t-object-label .t-title-label:after { color: #737373; content: '\3e'; @@ -4667,25 +4679,13 @@ span.req { float: left; margin-right: 10px; } -/* line 368, ../../../../general/res/sass/user-environ/_layout.scss */ -.l-flex { - display: flex; - display: -webkit-flex; - flex-flow: row nowrap; - -webkit-flex-flow: row nowrap; } - /* line 371, ../../../../general/res/sass/user-environ/_layout.scss */ - .l-flex .left { - flex: 1 1 0; - -webkit-flex: 1 1 0; - padding-right: 10px; } - -/* line 384, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 374, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .tree-holder, .pane-tree-hidden .splitter-treeview, .pane-tree-hidden .holder-create-and-search { opacity: 0; } -/* line 394, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 384, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .tree-holder, .pane-tree-showing .splitter-treeview { -moz-transition-property: opacity; @@ -4705,7 +4705,7 @@ span.req { -webkit-transition-delay: 250ms; transition-delay: 250ms; opacity: 1; } -/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 390, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .holder-create-and-search { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -4724,7 +4724,7 @@ span.req { -webkit-transition-delay: 200ms; transition-delay: 200ms; } -/* line 407, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 397, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-showing .l-object-and-inspector .l-inspect, .pane-inspect-showing .l-object-and-inspector .splitter-inspect { -moz-transition-property: opacity; @@ -4745,25 +4745,25 @@ span.req { transition-delay: 250ms; opacity: 1; } -/* line 416, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 406, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .l-inspect, .pane-inspect-hidden .l-object-and-inspector .splitter-inspect { opacity: 0; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 414, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .tree-holder { padding-right: 5px; } - /* line 428, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 418, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .pane.right.primary-pane { left: 20px !important; } - /* line 431, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 421, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .pane.left { right: 20px !important; } - /* line 434, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ .pane:not(.resizing) { -moz-transition-property: width, left, right; -o-transition-property: width, left, right; diff --git a/platform/commonUI/themes/snow/res/css/theme-snow.css b/platform/commonUI/themes/snow/res/css/theme-snow.css index ed1e1cbcbf..cc80ecd0df 100644 --- a/platform/commonUI/themes/snow/res/css/theme-snow.css +++ b/platform/commonUI/themes/snow/res/css/theme-snow.css @@ -508,33 +508,39 @@ mct-container { /********************************************* FLEX STYLES */ /* line 95, ../../../../general/res/sass/_archetypes.scss */ -.l-flex-row, +.l-flex-row, .l-flex, .l-flex-col { display: -webkit-flex; display: flex; -webkit-flex-wrap: nowrap; flex-wrap: nowrap; } /* line 100, ../../../../general/res/sass/_archetypes.scss */ - .l-flex-row .flex-elem:not(.grows), + .l-flex-row .flex-elem:not(.grows), .l-flex .flex-elem:not(.grows), .l-flex-col .flex-elem:not(.grows) { -webkit-flex: 0 1 auto; flex: 0 1 auto; } /* line 103, ../../../../general/res/sass/_archetypes.scss */ - .l-flex-row .flex-elem.grows, + .l-flex-row .flex-elem.grows, .l-flex .flex-elem.grows, .l-flex-col .flex-elem.grows { -webkit-flex: 1 1 auto; flex: 1 1 auto; } /* line 109, ../../../../general/res/sass/_archetypes.scss */ -.l-flex-row { +.l-flex-row, .l-flex { -webkit-flex-direction: row; flex-direction: row; } -/* line 114, ../../../../general/res/sass/_archetypes.scss */ +/* line 110, ../../../../general/res/sass/_archetypes.scss */ .l-flex-col { -webkit-flex-direction: column; flex-direction: column; } +/* line 116, ../../../../general/res/sass/_archetypes.scss */ +.l-flex .left { + -webkit-flex: 1 1 0; + flex: 1 1 0; + padding-right: 10px; } + /***************************************************************************** * Open MCT Web, Copyright (c) 2014-2015, United States Government * as represented by the Administrator of the National Aeronautics and Space @@ -1387,14 +1393,20 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { margin-right: 5px; vertical-align: bottom; } /* line 47, ../../../../general/res/sass/_inspector.scss */ + .l-inspect ul { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding-right: 5px; } + /* line 52, ../../../../general/res/sass/_inspector.scss */ .l-inspect ul li, .l-inspect em { display: block; position: relative; } - /* line 53, ../../../../general/res/sass/_inspector.scss */ + /* line 58, ../../../../general/res/sass/_inspector.scss */ .l-inspect ul li { margin-bottom: 10px; } - /* line 57, ../../../../general/res/sass/_inspector.scss */ + /* line 62, ../../../../general/res/sass/_inspector.scss */ .l-inspect em { -moz-border-radius: 4px; -webkit-border-radius: 4px; @@ -1404,34 +1416,34 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { margin-bottom: 5px; padding: 5px 5px; text-transform: uppercase; } - /* line 66, ../../../../general/res/sass/_inspector.scss */ + /* line 71, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties { padding: 3px 0; } - /* line 67, ../../../../general/res/sass/_inspector.scss */ + /* line 72, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties:not(.first) { border-top: 1px solid #e3e3e3; } - /* line 71, ../../../../general/res/sass/_inspector.scss */ + /* line 76, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties .label { color: #999999; text-transform: uppercase; } - /* line 75, ../../../../general/res/sass/_inspector.scss */ + /* line 80, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-properties .value { color: #404040; word-break: break-all; } - /* line 83, ../../../../general/res/sass/_inspector.scss */ + /* line 88, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location .location-item { cursor: pointer; display: inline-block; position: relative; padding: 2px 4px; } - /* line 88, ../../../../general/res/sass/_inspector.scss */ + /* line 93, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location .location-item:hover { background: rgba(102, 102, 102, 0.1); color: #333333; } - /* line 91, ../../../../general/res/sass/_inspector.scss */ + /* line 96, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location .location-item:hover .icon, .l-inspect .inspector-location .location-item:hover .t-item-icon { color: #0099cc; } - /* line 96, ../../../../general/res/sass/_inspector.scss */ + /* line 101, ../../../../general/res/sass/_inspector.scss */ .l-inspect .inspector-location:not(.last) .t-object-label .t-title-label:after { color: #8c8c8c; content: '\3e'; @@ -4589,25 +4601,13 @@ span.req { float: left; margin-right: 10px; } -/* line 368, ../../../../general/res/sass/user-environ/_layout.scss */ -.l-flex { - display: flex; - display: -webkit-flex; - flex-flow: row nowrap; - -webkit-flex-flow: row nowrap; } - /* line 371, ../../../../general/res/sass/user-environ/_layout.scss */ - .l-flex .left { - flex: 1 1 0; - -webkit-flex: 1 1 0; - padding-right: 10px; } - -/* line 384, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 374, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .tree-holder, .pane-tree-hidden .splitter-treeview, .pane-tree-hidden .holder-create-and-search { opacity: 0; } -/* line 394, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 384, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .tree-holder, .pane-tree-showing .splitter-treeview { -moz-transition-property: opacity; @@ -4627,7 +4627,7 @@ span.req { -webkit-transition-delay: 250ms; transition-delay: 250ms; opacity: 1; } -/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 390, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-showing .holder-create-and-search { -moz-transition-property: opacity; -o-transition-property: opacity; @@ -4646,7 +4646,7 @@ span.req { -webkit-transition-delay: 200ms; transition-delay: 200ms; } -/* line 407, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 397, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-showing .l-object-and-inspector .l-inspect, .pane-inspect-showing .l-object-and-inspector .splitter-inspect { -moz-transition-property: opacity; @@ -4667,25 +4667,25 @@ span.req { transition-delay: 250ms; opacity: 1; } -/* line 416, ../../../../general/res/sass/user-environ/_layout.scss */ +/* line 406, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .l-inspect, .pane-inspect-hidden .l-object-and-inspector .splitter-inspect { opacity: 0; } @media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) { - /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 414, ../../../../general/res/sass/user-environ/_layout.scss */ .pane.treeview.left .tree-holder { padding-right: 5px; } - /* line 428, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 418, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .pane.right.primary-pane { left: 20px !important; } - /* line 431, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 421, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .pane.left { right: 20px !important; } - /* line 434, ../../../../general/res/sass/user-environ/_layout.scss */ + /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ .pane:not(.resizing) { -moz-transition-property: width, left, right; -o-transition-property: width, left, right; From 5f1f54fa91272046e25847bbc773e80594197f9c Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Wed, 4 Nov 2015 15:47:13 -0800 Subject: [PATCH 27/62] [Frontend] Inspector-related fixes open #243 Enlarged size of mini-tab icon when panes are collapsed; Increased size of edge margin to allow for larger icons; --- .../commonUI/general/res/sass/_constants.scss | 3 +- .../general/res/sass/controls/_buttons.scss | 5 +++ .../espresso/res/css/theme-espresso.css | 42 ++++++++++--------- .../themes/snow/res/css/theme-snow.css | 42 ++++++++++--------- 4 files changed, 53 insertions(+), 39 deletions(-) diff --git a/platform/commonUI/general/res/sass/_constants.scss b/platform/commonUI/general/res/sass/_constants.scss index a3305cf0a4..e0d9f34bd6 100644 --- a/platform/commonUI/general/res/sass/_constants.scss +++ b/platform/commonUI/general/res/sass/_constants.scss @@ -44,9 +44,10 @@ $ueAppLogoW: 105px; $ueEditToolBarH: 25px; $ueBrowseLeftPaneTreeW: 25%; $ueBrowseRightPaneInspectW: 20%; -$ueCollapsedPaneEdgeM: 20px; +$ueCollapsedPaneEdgeM: 22px; $uePaneMiniTabH: $ueTopBarH; $uePaneMiniTabW: 9px; +$uePaneMiniTabCollapsedW: 11px; $ueEditLeftPaneW: 75%; $treeSearchInputBarH: 25px; $ueTimeControlH: (33px, 20px, 20px); diff --git a/platform/commonUI/general/res/sass/controls/_buttons.scss b/platform/commonUI/general/res/sass/controls/_buttons.scss index 956e144899..5431b0f563 100644 --- a/platform/commonUI/general/res/sass/controls/_buttons.scss +++ b/platform/commonUI/general/res/sass/controls/_buttons.scss @@ -225,6 +225,11 @@ $pad: $interiorMargin * $baseRatio; overflow: hidden; word-break: break-all; + &.collapsed { + $d: $uePaneMiniTabCollapsedW; + width: $d; font-size: $d; + } + &:before, &:after { position: absolute; diff --git a/platform/commonUI/themes/espresso/res/css/theme-espresso.css b/platform/commonUI/themes/espresso/res/css/theme-espresso.css index 6cffc059da..d0d1a2c63b 100644 --- a/platform/commonUI/themes/espresso/res/css/theme-espresso.css +++ b/platform/commonUI/themes/espresso/res/css/theme-espresso.css @@ -507,35 +507,35 @@ mct-container { padding: 5px 0; } /********************************************* FLEX STYLES */ -/* line 95, ../../../../general/res/sass/_archetypes.scss */ +/* line 96, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row, .l-flex, .l-flex-col { display: -webkit-flex; display: flex; -webkit-flex-wrap: nowrap; flex-wrap: nowrap; } - /* line 100, ../../../../general/res/sass/_archetypes.scss */ + /* line 101, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row .flex-elem:not(.grows), .l-flex .flex-elem:not(.grows), .l-flex-col .flex-elem:not(.grows) { -webkit-flex: 0 1 auto; flex: 0 1 auto; } - /* line 103, ../../../../general/res/sass/_archetypes.scss */ + /* line 104, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row .flex-elem.grows, .l-flex .flex-elem.grows, .l-flex-col .flex-elem.grows { -webkit-flex: 1 1 auto; flex: 1 1 auto; } -/* line 109, ../../../../general/res/sass/_archetypes.scss */ +/* line 110, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row, .l-flex { -webkit-flex-direction: row; flex-direction: row; } -/* line 110, ../../../../general/res/sass/_archetypes.scss */ +/* line 111, ../../../../general/res/sass/_archetypes.scss */ .l-flex-col { -webkit-flex-direction: column; flex-direction: column; } -/* line 116, ../../../../general/res/sass/_archetypes.scss */ +/* line 115, ../../../../general/res/sass/_archetypes.scss */ .l-flex .left { -webkit-flex: 1 1 0; flex: 1 1 0; @@ -1895,26 +1895,30 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { overflow: hidden; word-break: break-all; } /* line 228, ../../../../general/res/sass/controls/_buttons.scss */ + .mini-tab-icon.collapsed { + width: 11px; + font-size: 11px; } + /* line 233, ../../../../general/res/sass/controls/_buttons.scss */ .mini-tab-icon:before, .mini-tab-icon:after { position: absolute; display: inherit; } - /* line 234, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 239, ../../../../general/res/sass/controls/_buttons.scss */ .mini-tab-icon:before { content: '\78'; } - /* line 238, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 243, ../../../../general/res/sass/controls/_buttons.scss */ .mini-tab-icon:hover { color: #0099cc; } } -/* line 245, ../../../../general/res/sass/controls/_buttons.scss */ +/* line 250, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set { font-size: 0; } - /* line 251, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 256, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set .s-btn, .l-btn-set .s-menu-btn { -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; margin-left: 1px; } - /* line 257, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 262, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set .first .s-btn, .l-btn-set .first .s-menu-btn { -moz-border-radius-topleft: 3px; -webkit-border-top-left-radius: 3px; @@ -1923,7 +1927,7 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { -webkit-border-bottom-left-radius: 3px; border-bottom-left-radius: 3px; margin-left: 0; } - /* line 264, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 269, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set .last .s-btn, .l-btn-set .last .s-menu-btn { -moz-border-radius-topright: 3px; -webkit-border-top-right-radius: 3px; @@ -1932,7 +1936,7 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { -webkit-border-bottom-right-radius: 3px; border-bottom-right-radius: 3px; } -/* line 271, ../../../../general/res/sass/controls/_buttons.scss */ +/* line 276, ../../../../general/res/sass/controls/_buttons.scss */ .paused:not(.s-btn):not(.s-menu-btn) { border-color: #c56f01 !important; color: #c56f01 !important; } @@ -4533,10 +4537,10 @@ span.req { /* line 240, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed { left: 0; - -moz-transform: translateX(-15px); - -ms-transform: translateX(-15px); - -webkit-transform: translateX(-15px); - transform: translateX(-15px); } + -moz-transform: translateX(-17px); + -ms-transform: translateX(-17px); + -webkit-transform: translateX(-17px); + transform: translateX(-17px); } /* line 244, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before { -moz-transition-property: opacity; @@ -4757,11 +4761,11 @@ span.req { /* line 418, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .pane.right.primary-pane { - left: 20px !important; } + left: 22px !important; } /* line 421, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .pane.left { - right: 20px !important; } + right: 22px !important; } /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ .pane:not(.resizing) { diff --git a/platform/commonUI/themes/snow/res/css/theme-snow.css b/platform/commonUI/themes/snow/res/css/theme-snow.css index cc80ecd0df..1e3717427f 100644 --- a/platform/commonUI/themes/snow/res/css/theme-snow.css +++ b/platform/commonUI/themes/snow/res/css/theme-snow.css @@ -507,35 +507,35 @@ mct-container { padding: 5px 0; } /********************************************* FLEX STYLES */ -/* line 95, ../../../../general/res/sass/_archetypes.scss */ +/* line 96, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row, .l-flex, .l-flex-col { display: -webkit-flex; display: flex; -webkit-flex-wrap: nowrap; flex-wrap: nowrap; } - /* line 100, ../../../../general/res/sass/_archetypes.scss */ + /* line 101, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row .flex-elem:not(.grows), .l-flex .flex-elem:not(.grows), .l-flex-col .flex-elem:not(.grows) { -webkit-flex: 0 1 auto; flex: 0 1 auto; } - /* line 103, ../../../../general/res/sass/_archetypes.scss */ + /* line 104, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row .flex-elem.grows, .l-flex .flex-elem.grows, .l-flex-col .flex-elem.grows { -webkit-flex: 1 1 auto; flex: 1 1 auto; } -/* line 109, ../../../../general/res/sass/_archetypes.scss */ +/* line 110, ../../../../general/res/sass/_archetypes.scss */ .l-flex-row, .l-flex { -webkit-flex-direction: row; flex-direction: row; } -/* line 110, ../../../../general/res/sass/_archetypes.scss */ +/* line 111, ../../../../general/res/sass/_archetypes.scss */ .l-flex-col { -webkit-flex-direction: column; flex-direction: column; } -/* line 116, ../../../../general/res/sass/_archetypes.scss */ +/* line 115, ../../../../general/res/sass/_archetypes.scss */ .l-flex .left { -webkit-flex: 1 1 0; flex: 1 1 0; @@ -1840,26 +1840,30 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { overflow: hidden; word-break: break-all; } /* line 228, ../../../../general/res/sass/controls/_buttons.scss */ + .mini-tab-icon.collapsed { + width: 11px; + font-size: 11px; } + /* line 233, ../../../../general/res/sass/controls/_buttons.scss */ .mini-tab-icon:before, .mini-tab-icon:after { position: absolute; display: inherit; } - /* line 234, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 239, ../../../../general/res/sass/controls/_buttons.scss */ .mini-tab-icon:before { content: '\78'; } - /* line 238, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 243, ../../../../general/res/sass/controls/_buttons.scss */ .mini-tab-icon:hover { color: #0099cc; } } -/* line 245, ../../../../general/res/sass/controls/_buttons.scss */ +/* line 250, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set { font-size: 0; } - /* line 251, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 256, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set .s-btn, .l-btn-set .s-menu-btn { -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; margin-left: 1px; } - /* line 257, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 262, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set .first .s-btn, .l-btn-set .first .s-menu-btn { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; @@ -1868,7 +1872,7 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { -webkit-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; margin-left: 0; } - /* line 264, ../../../../general/res/sass/controls/_buttons.scss */ + /* line 269, ../../../../general/res/sass/controls/_buttons.scss */ .l-btn-set .last .s-btn, .l-btn-set .last .s-menu-btn { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; @@ -1877,7 +1881,7 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before { -webkit-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; } -/* line 271, ../../../../general/res/sass/controls/_buttons.scss */ +/* line 276, ../../../../general/res/sass/controls/_buttons.scss */ .paused:not(.s-btn):not(.s-menu-btn) { border-color: #ff9900 !important; color: #ff9900 !important; } @@ -4455,10 +4459,10 @@ span.req { /* line 240, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed { left: 0; - -moz-transform: translateX(-15px); - -ms-transform: translateX(-15px); - -webkit-transform: translateX(-15px); - transform: translateX(-15px); } + -moz-transform: translateX(-17px); + -ms-transform: translateX(-17px); + -webkit-transform: translateX(-17px); + transform: translateX(-17px); } /* line 244, ../../../../general/res/sass/user-environ/_layout.scss */ .pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before { -moz-transition-property: opacity; @@ -4679,11 +4683,11 @@ span.req { /* line 418, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-tree-hidden .pane.right.primary-pane { - left: 20px !important; } + left: 22px !important; } /* line 421, ../../../../general/res/sass/user-environ/_layout.scss */ .pane-inspect-hidden .l-object-and-inspector .pane.left { - right: 20px !important; } + right: 22px !important; } /* line 424, ../../../../general/res/sass/user-environ/_layout.scss */ .pane:not(.resizing) { From e49b55024ffe55eada42a21abc345880c296ab1a Mon Sep 17 00:00:00 2001 From: Charles Hacskaylo Date: Wed, 4 Nov 2015 16:00:22 -0800 Subject: [PATCH 28/62] [Frontend] Inspector-related fixes open #247 Modded styles applied to .object-browse-bar to use overflow:hidden instead of visible; --- platform/commonUI/general/res/sass/user-environ/_layout.scss | 2 +- platform/commonUI/themes/espresso/res/css/theme-espresso.css | 2 +- platform/commonUI/themes/snow/res/css/theme-snow.css | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/platform/commonUI/general/res/sass/user-environ/_layout.scss b/platform/commonUI/general/res/sass/user-environ/_layout.scss index 4e3045fff8..e6e6ba5f93 100644 --- a/platform/commonUI/general/res/sass/user-environ/_layout.scss +++ b/platform/commonUI/general/res/sass/user-environ/_layout.scss @@ -349,7 +349,7 @@ .object-browse-bar { //@include test(blue); - @include absPosDefault(0, visible); + @include absPosDefault(0, hidden); @include box-sizing(border-box); height: $ueTopBarH; line-height: $ueTopBarH; diff --git a/platform/commonUI/themes/espresso/res/css/theme-espresso.css b/platform/commonUI/themes/espresso/res/css/theme-espresso.css index d0d1a2c63b..506a023511 100644 --- a/platform/commonUI/themes/espresso/res/css/theme-espresso.css +++ b/platform/commonUI/themes/espresso/res/css/theme-espresso.css @@ -4660,7 +4660,7 @@ span.req { /* line 350, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar { - overflow: visible; + overflow: hidden; position: absolute; top: 0; right: 0; diff --git a/platform/commonUI/themes/snow/res/css/theme-snow.css b/platform/commonUI/themes/snow/res/css/theme-snow.css index 1e3717427f..3aaf090ae9 100644 --- a/platform/commonUI/themes/snow/res/css/theme-snow.css +++ b/platform/commonUI/themes/snow/res/css/theme-snow.css @@ -4582,7 +4582,7 @@ span.req { /* line 350, ../../../../general/res/sass/user-environ/_layout.scss */ .object-browse-bar { - overflow: visible; + overflow: hidden; position: absolute; top: 0; right: 0; From 6c4c53dde7beef1744f77058d775e73b38dbeffc Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Mon, 2 Nov 2015 08:44:08 -0800 Subject: [PATCH 29/62] Debugging test failures --- .../entanglement/src/services/CopyService.js | 32 ++++++++++--------- .../test/services/CopyServiceSpec.js | 29 +++++++++++++---- 2 files changed, 39 insertions(+), 22 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index d97ec4677b..025a5fda08 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -88,10 +88,13 @@ define( */ function copy(originalObject, originalParent) { //Make a clone of the model of the object to be copied - var modelClone = makeClone(originalObject.getModel()); - delete modelClone.composition; - delete modelClone.location; - modelClone.id = uuid(); + var modelClone = { + id: uuid(), + model: makeClone(originalObject.getModel()), + persistenceSpace: originalParent.getCapability('persistence') + } + delete modelClone.model.composition; + delete modelClone.model.location; return $q.when(originalObject.useCapability('composition')).then(function(composees){ return (composees || []).reduce(function(promise, composee){ //If the object is composed of other @@ -101,18 +104,15 @@ define( return copy(composee, originalObject).then(function(composeeClone){ //Once copied, associate each cloned // composee with its parent clone - composeeClone.location = modelClone.id; - modelClone.composition = modelClone.composition || []; - return modelClone.composition.push(composeeClone.id); + composeeClone.model.location = modelClone.id; + modelClone.model.composition = modelClone.model.composition || []; + return modelClone.model.composition.push(composeeClone.id); }); });}, $q.when(undefined) ).then(function (){ //Add the clone to the list of clones that will //be returned by this function - clones.push({ - model: modelClone, - persistenceSpace: originalParent.getCapability('persistence') - }); + clones.push(modelClone); return modelClone; }); }); @@ -136,11 +136,13 @@ define( self = this; return function(objectClones) { return self.$q.all(objectClones.map(function(clone, index){ - return self.persistenceService.createObject(clone.persistenceSpace, clone.model.id, clone.model) + return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ progress && progress("copying", objectClones.length, ++persisted); }); - })).then(function(){ return objectClones}); + })).then(function(qall){ + return objectClones + }); } } @@ -161,8 +163,8 @@ define( parentClone.model.location = parent.getId(); return self.persistenceService - .updateObject(parentClone.persistenceSpace, parentClone.model.id, parentClone.model) - .then(function(){return parent.getCapability('composition').add(parentClone.model.id)}) + .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) + .then(function(){return parent.getCapability('composition').add(parentClone.id)}) .then(function(){return parent.getCapability("persistence").persist()}); } } diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index 2788fcefa8..7b58d3eab5 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -125,10 +125,12 @@ define( creationService, createObjectPromise, copyService, + mockPersistenceService, object, newParent, copyResult, - copyFinished; + copyFinished, + persistObjectPromise; beforeEach(function () { creationService = jasmine.createSpyObj( @@ -138,6 +140,13 @@ define( createObjectPromise = synchronousPromise(undefined); creationService.createObject.andReturn(createObjectPromise); policyService.allow.andReturn(true); + + mockPersistenceService = jasmine.createSpyObj( + 'persistenceService', + ['createObject'] + ); + persistObjectPromise = synchronousPromise(undefined); + mockPersistenceService.createObject.andReturn(persistObjectPromise); }); describe("on domain object without composition", function () { @@ -156,26 +165,32 @@ define( composition: [] } }); - copyService = new CopyService(null, creationService, policyService); + mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); + mockQ.when.andCallFake(synchronousPromise); + mockQ.all.andCallFake(synchronousPromise); + copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService); copyResult = copyService.perform(object, newParent); copyFinished = jasmine.createSpy('copyFinished'); copyResult.then(copyFinished); }); - it("uses creation service", function () { + /** + * Test invalidated. Copy service no longer uses creation service. + */ + /*it("uses creation service", function () { expect(creationService.createObject) .toHaveBeenCalledWith(jasmine.any(Object), newParent); expect(createObjectPromise.then) .toHaveBeenCalledWith(jasmine.any(Function)); - }); + });*/ it("deep clones object model", function () { - var newModel = creationService + //var newModel = creationService + var newModel = mockPersistenceService .createObject .mostRecentCall - .args[0]; - + .args[2]; expect(newModel).toEqual(object.model); expect(newModel).not.toBe(object.model); }); From 4312857fd45a2f140c983c34bc111d51d16d832b Mon Sep 17 00:00:00 2001 From: Henry Date: Mon, 2 Nov 2015 18:31:14 -0800 Subject: [PATCH 30/62] Fixed failing tests --- .../entanglement/src/services/CopyService.js | 12 ++-- .../test/services/CopyServiceSpec.js | 60 ++++++++++++++++--- 2 files changed, 59 insertions(+), 13 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 025a5fda08..829eba1fe9 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -110,11 +110,11 @@ define( }); });}, $q.when(undefined) ).then(function (){ - //Add the clone to the list of clones that will - //be returned by this function - clones.push(modelClone); - return modelClone; - }); + //Add the clone to the list of clones that will + //be returned by this function + clones.push(modelClone); + return modelClone; + }); }); }; return copy(domainObject, parent).then(function(){ @@ -158,7 +158,7 @@ define( return function(clones) { var parentClone = clones[clones.length-1]; if (!parent.hasCapability('composition')){ - self.$q.reject(); + return self.$q.reject(); } parentClone.model.location = parent.getId(); diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index 7b58d3eab5..b8086d9092 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -31,6 +31,10 @@ define( "use strict"; function synchronousPromise(value) { + if (value && value.then) { + return value; + } + var promise = { then: function (callback) { return synchronousPromise(callback(value)); @@ -143,10 +147,11 @@ define( mockPersistenceService = jasmine.createSpyObj( 'persistenceService', - ['createObject'] + ['createObject', 'updateObject'] ); persistObjectPromise = synchronousPromise(undefined); mockPersistenceService.createObject.andReturn(persistObjectPromise); + mockPersistenceService.updateObject.andReturn(persistObjectPromise); }); describe("on domain object without composition", function () { @@ -167,7 +172,15 @@ define( }); mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); mockQ.when.andCallFake(synchronousPromise); - mockQ.all.andCallFake(synchronousPromise); + //mockQ.all.andCallFake(synchronousPromise); + mockQ.all.andCallFake(function (promises) { + var result = {}; + Object.keys(promises).forEach(function (k) { + promises[k].then(function (v) { result[k] = v; }); + }); + return synchronousPromise(result); + }); + copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService); copyResult = copyService.perform(object, newParent); copyFinished = jasmine.createSpy('copyFinished'); @@ -209,8 +222,16 @@ define( compositionPromise; beforeEach(function () { - mockQ = jasmine.createSpyObj('mockQ', ['when']); + mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); mockQ.when.andCallFake(synchronousPromise); + mockQ.all.andCallFake(function (promises) { + var result = {}; + Object.keys(promises).forEach(function (k) { + promises[k].then(function (v) { result[k] = v; }); + }); + return synchronousPromise(result); + }); + childObject = domainObjectFactory({ name: 'childObject', id: 'def', @@ -220,15 +241,19 @@ define( }); compositionCapability = jasmine.createSpyObj( 'compositionCapability', - ['invoke'] + ['invoke', 'add'] ); compositionPromise = jasmine.createSpyObj( 'compositionPromise', ['then'] ); + + compositionPromise.then.andCallFake(synchronousPromise); + compositionCapability .invoke .andReturn(compositionPromise); + object = domainObjectFactory({ name: 'object', id: 'abc', @@ -263,23 +288,40 @@ define( creationService.createObject.andReturn(createObjectPromise); copyService = new CopyService(mockQ, creationService, policyService); copyResult = copyService.perform(object, newParent); + compositionPromise.then.mostRecentCall.args[0]([childObject]); copyFinished = jasmine.createSpy('copyFinished'); copyResult.then(copyFinished); }); - it("uses creation service", function () { + /** + * Test no longer valid due to creation service not + * being used + */ + /*it("uses creation service", function () { expect(creationService.createObject) .toHaveBeenCalledWith(jasmine.any(Object), newParent); + expect(createObjectPromise.then) + .toHaveBeenCalledWith(jasmine.any(Function)); + });*/ + + it("uses persistence service", function () { + expect(mockPersistenceService.createObject) + .toHaveBeenCalledWith(jasmine.any(Object), jasmine.any(String), newParent); + expect(createObjectPromise.then) .toHaveBeenCalledWith(jasmine.any(Function)); }); it("clears model composition", function () { - var newModel = creationService + /*var newModel = creationService .createObject .mostRecentCall - .args[0]; + .args[0];*/ + var newModel = mockPersistenceService + .createObject + .mostRecentCall + .args[2]; expect(newModel.composition.length).toBe(0); expect(newModel.name).toBe('some object'); @@ -329,6 +371,10 @@ define( expect(perform).toThrow(); }); }); + /** + * Additional tests: + * - Created and persisted dates + */ }); }); From 2f90a89065ab9059d5f888f0869832e7feed6326 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Mon, 2 Nov 2015 22:50:47 -0800 Subject: [PATCH 31/62] Fixed more failing tests --- .../entanglement/src/services/CopyService.js | 6 +++ .../test/services/CopyServiceSpec.js | 38 +++++++++++++++---- 2 files changed, 37 insertions(+), 7 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 829eba1fe9..da8339e965 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -96,12 +96,15 @@ define( delete modelClone.model.composition; delete modelClone.model.location; return $q.when(originalObject.useCapability('composition')).then(function(composees){ + console.log("composees: " + composees); return (composees || []).reduce(function(promise, composee){ + console.log("inside reduce"); //If the object is composed of other // objects, chain a promise.. return promise.then(function(){ // ...to recursively copy it (and its children) return copy(composee, originalObject).then(function(composeeClone){ + console.log("Composing clone"); //Once copied, associate each cloned // composee with its parent clone composeeClone.model.location = modelClone.id; @@ -110,6 +113,7 @@ define( }); });}, $q.when(undefined) ).then(function (){ + console.log("Adding clone to list"); //Add the clone to the list of clones that will //be returned by this function clones.push(modelClone); @@ -118,6 +122,7 @@ define( }); }; return copy(domainObject, parent).then(function(){ + console.log("Done cloning, returning"); return clones; }); } @@ -135,6 +140,7 @@ define( var persisted = 0, self = this; return function(objectClones) { + console.log("Persisting " + objectClones.length + " clones"); return self.$q.all(objectClones.map(function(clone, index){ return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index b8086d9092..c85f689c79 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -134,7 +134,8 @@ define( newParent, copyResult, copyFinished, - persistObjectPromise; + persistObjectPromise, + persistenceCapability; beforeEach(function () { creationService = jasmine.createSpyObj( @@ -152,6 +153,15 @@ define( persistObjectPromise = synchronousPromise(undefined); mockPersistenceService.createObject.andReturn(persistObjectPromise); mockPersistenceService.updateObject.andReturn(persistObjectPromise); + + persistenceCapability = jasmine.createSpyObj( + "persistence", + [ "persist", "getSpace" ] + ); + + persistenceCapability.persist.andReturn(persistObjectPromise); + persistenceCapability.getSpace.andReturn("testSpace"); + }); describe("on domain object without composition", function () { @@ -168,11 +178,13 @@ define( id: '456', model: { composition: [] + }, + capabilities: { + persistence: persistenceCapability } }); mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); mockQ.when.andCallFake(synchronousPromise); - //mockQ.all.andCallFake(synchronousPromise); mockQ.all.andCallFake(function (promises) { var result = {}; Object.keys(promises).forEach(function (k) { @@ -180,7 +192,7 @@ define( }); return synchronousPromise(result); }); - + copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService); copyResult = copyService.perform(object, newParent); copyFinished = jasmine.createSpy('copyFinished'); @@ -198,6 +210,14 @@ define( .toHaveBeenCalledWith(jasmine.any(Function)); });*/ + it("uses persistence service", function () { + expect(mockPersistenceService.createObject) + .toHaveBeenCalledWith(persistenceCapability, jasmine.any(String), object.getModel()); + + expect(persistObjectPromise.then) + .toHaveBeenCalledWith(jasmine.any(Function)); + }); + it("deep clones object model", function () { //var newModel = creationService var newModel = mockPersistenceService @@ -223,7 +243,7 @@ define( beforeEach(function () { mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); - mockQ.when.andCallFake(synchronousPromise); + //mockQ.when.andCallFake(synchronousPromise); mockQ.all.andCallFake(function (promises) { var result = {}; Object.keys(promises).forEach(function (k) { @@ -248,7 +268,7 @@ define( ['then'] ); - compositionPromise.then.andCallFake(synchronousPromise); + //compositionPromise.then.andCallFake(synchronousPromise); compositionCapability .invoke @@ -287,8 +307,12 @@ define( createObjectPromise = synchronousPromise(newObject); creationService.createObject.andReturn(createObjectPromise); copyService = new CopyService(mockQ, creationService, policyService); + console.log("Before perform"); + compositionPromise.then.andReturn(synchronousPromise([childObject])); + mockQ.when.andReturn(compositionPromise); copyResult = copyService.perform(object, newParent); - compositionPromise.then.mostRecentCall.args[0]([childObject]); + console.log("After perform"); + //compositionPromise.then.mostRecentCall.args[0]([childObject]); copyFinished = jasmine.createSpy('copyFinished'); copyResult.then(copyFinished); }); @@ -307,7 +331,7 @@ define( it("uses persistence service", function () { expect(mockPersistenceService.createObject) - .toHaveBeenCalledWith(jasmine.any(Object), jasmine.any(String), newParent); + .toHaveBeenCalledWith(persistenceCapability, jasmine.any(String), newParent); expect(createObjectPromise.then) .toHaveBeenCalledWith(jasmine.any(Function)); From 5cd458a733258180fcacae6816e4634e61a6800f Mon Sep 17 00:00:00 2001 From: Henry Date: Tue, 3 Nov 2015 11:00:30 -0800 Subject: [PATCH 32/62] Updating tests --- .../entanglement/test/services/CopyServiceSpec.js | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index c85f689c79..495c60134e 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -243,7 +243,7 @@ define( beforeEach(function () { mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); - //mockQ.when.andCallFake(synchronousPromise); + mockQ.when.andCallFake(synchronousPromise); mockQ.all.andCallFake(function (promises) { var result = {}; Object.keys(promises).forEach(function (k) { @@ -272,7 +272,7 @@ define( compositionCapability .invoke - .andReturn(compositionPromise); + .andReturn(synchronousPromise([childObject])); object = domainObjectFactory({ name: 'object', @@ -306,10 +306,10 @@ define( createObjectPromise = synchronousPromise(newObject); creationService.createObject.andReturn(createObjectPromise); - copyService = new CopyService(mockQ, creationService, policyService); + copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService); console.log("Before perform"); - compositionPromise.then.andReturn(synchronousPromise([childObject])); - mockQ.when.andReturn(compositionPromise); + //compositionPromise.then.andReturn(synchronousPromise([childObject])); + //mockQ.when.andReturn(compositionPromise); copyResult = copyService.perform(object, newParent); console.log("After perform"); //compositionPromise.then.mostRecentCall.args[0]([childObject]); @@ -330,8 +330,9 @@ define( });*/ it("uses persistence service", function () { + //Need a better way of testing duplication here. expect(mockPersistenceService.createObject) - .toHaveBeenCalledWith(persistenceCapability, jasmine.any(String), newParent); + .toHaveBeenCalledWith(persistenceCapability, jasmine.any(String), jasmine.any(Object)); expect(createObjectPromise.then) .toHaveBeenCalledWith(jasmine.any(Function)); From cbd21212d1f6b5e3e4c8d19b3302add7d7e89a15 Mon Sep 17 00:00:00 2001 From: Henry Date: Tue, 3 Nov 2015 13:16:01 -0800 Subject: [PATCH 33/62] Original tests that are still valid are passing --- .../test/services/CopyServiceSpec.js | 25 ++++++++----------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index 495c60134e..121f35663a 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -332,31 +332,26 @@ define( it("uses persistence service", function () { //Need a better way of testing duplication here. expect(mockPersistenceService.createObject) - .toHaveBeenCalledWith(persistenceCapability, jasmine.any(String), jasmine.any(Object)); - - expect(createObjectPromise.then) - .toHaveBeenCalledWith(jasmine.any(Function)); + .toHaveBeenCalled(); }); - + /* + //Test is no longer relevant it("clears model composition", function () { - /*var newModel = creationService + var newModel = creationService .createObject .mostRecentCall - .args[0];*/ - var newModel = mockPersistenceService - .createObject - .mostRecentCall - .args[2]; + .args[0]; expect(newModel.composition.length).toBe(0); expect(newModel.name).toBe('some object'); - }); + });*/ it("recursively clones it's children", function () { - expect(creationService.createObject.calls.length).toBe(1); + //TODO: This is a valid test, but needs rewritten + /*expect(creationService.createObject.calls.length).toBe(1); expect(compositionCapability.invoke).toHaveBeenCalled(); compositionPromise.then.mostRecentCall.args[0]([childObject]); - expect(creationService.createObject.calls.length).toBe(2); + expect(creationService.createObject.calls.length).toBe(2);*/ }); it("returns a promise", function () { @@ -383,7 +378,7 @@ define( it("throws an error", function () { var copyService = - new CopyService(mockQ, creationService, policyService); + new CopyService(mockQ, creationService, policyService, mockPersistenceService); function perform() { copyService.perform(object, newParent); From bd1c3cb7dac2a1a43f2c6759156875b3dfddfe0a Mon Sep 17 00:00:00 2001 From: Henry Date: Tue, 3 Nov 2015 17:39:05 -0800 Subject: [PATCH 34/62] All test cases passing + added test cases for copy --- platform/entanglement/bundle.json | 2 +- .../entanglement/src/services/CopyService.js | 24 ++-- .../test/services/CopyServiceSpec.js | 119 ++++++++---------- 3 files changed, 63 insertions(+), 82 deletions(-) diff --git a/platform/entanglement/bundle.json b/platform/entanglement/bundle.json index 192a132602..702af234bb 100644 --- a/platform/entanglement/bundle.json +++ b/platform/entanglement/bundle.json @@ -77,7 +77,7 @@ "description": "Provides a service for copying objects", "implementation": "services/CopyService.js", "depends": ["$q", "creationService", "policyService", - "persistenceService"] + "persistenceService", "now"] }, { "key": "locationService", diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index da8339e965..220084f7a5 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -35,11 +35,12 @@ define( * @memberof platform/entanglement * @implements {platform/entanglement.AbstractComposeService} */ - function CopyService($q, creationService, policyService, persistenceService) { + function CopyService($q, creationService, policyService, persistenceService, now) { this.$q = $q; this.creationService = creationService; this.policyService = policyService; this.persistenceService = persistenceService; + this.now = now; } CopyService.prototype.validate = function (object, parentCandidate) { @@ -95,16 +96,15 @@ define( } delete modelClone.model.composition; delete modelClone.model.location; + delete modelClone.model.persisted; + delete modelClone.model.modified; return $q.when(originalObject.useCapability('composition')).then(function(composees){ - console.log("composees: " + composees); return (composees || []).reduce(function(promise, composee){ - console.log("inside reduce"); //If the object is composed of other // objects, chain a promise.. return promise.then(function(){ // ...to recursively copy it (and its children) return copy(composee, originalObject).then(function(composeeClone){ - console.log("Composing clone"); //Once copied, associate each cloned // composee with its parent clone composeeClone.model.location = modelClone.id; @@ -113,7 +113,6 @@ define( }); });}, $q.when(undefined) ).then(function (){ - console.log("Adding clone to list"); //Add the clone to the list of clones that will //be returned by this function clones.push(modelClone); @@ -122,7 +121,6 @@ define( }); }; return copy(domainObject, parent).then(function(){ - console.log("Done cloning, returning"); return clones; }); } @@ -140,13 +138,13 @@ define( var persisted = 0, self = this; return function(objectClones) { - console.log("Persisting " + objectClones.length + " clones"); return self.$q.all(objectClones.map(function(clone, index){ + clone.model.persisted = self.now(); return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ progress && progress("copying", objectClones.length, ++persisted); }); - })).then(function(qall){ + })).then(function(){ return objectClones }); } @@ -170,8 +168,10 @@ define( return self.persistenceService .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) - .then(function(){return parent.getCapability('composition').add(parentClone.id)}) - .then(function(){return parent.getCapability("persistence").persist()}); + .then(function(){return parent.getCapability("composition").add(parentClone.id)}) + .then(function(){return parent.getCapability("persistence").persist()}) + .then(function(){return parentClone}); + // Ensure the clone of the original domainObject is returned } } @@ -181,8 +181,8 @@ define( * @param domainObject * @param parent * @param progress - * @returns a promise that will be completed when the duplication is - * successful, otherwise an error is thrown. + * @returns a promise that will be completed with the clone of + * domainObject when the duplication is successful. */ CopyService.prototype.perform = function (domainObject, parent, progress) { var $q = this.$q; diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index 121f35663a..7839b78a7d 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -130,12 +130,13 @@ define( createObjectPromise, copyService, mockPersistenceService, + mockNow, object, newParent, copyResult, copyFinished, persistObjectPromise, - persistenceCapability; + parentPersistenceCapability; beforeEach(function () { creationService = jasmine.createSpyObj( @@ -154,13 +155,18 @@ define( mockPersistenceService.createObject.andReturn(persistObjectPromise); mockPersistenceService.updateObject.andReturn(persistObjectPromise); - persistenceCapability = jasmine.createSpyObj( + parentPersistenceCapability = jasmine.createSpyObj( "persistence", [ "persist", "getSpace" ] ); - persistenceCapability.persist.andReturn(persistObjectPromise); - persistenceCapability.getSpace.andReturn("testSpace"); + parentPersistenceCapability.persist.andReturn(persistObjectPromise); + parentPersistenceCapability.getSpace.andReturn("testSpace"); + + mockNow = jasmine.createSpyObj("mockNow", ["now"]); + mockNow.now.andCallFake(function(){ + return 1234; + }) }); @@ -170,7 +176,8 @@ define( name: 'object', id: 'abc', model: { - name: 'some object' + name: 'some object', + persisted: mockNow.now() } }); newParent = domainObjectFactory({ @@ -180,7 +187,7 @@ define( composition: [] }, capabilities: { - persistence: persistenceCapability + persistence: parentPersistenceCapability } }); mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); @@ -193,26 +200,15 @@ define( return synchronousPromise(result); }); - copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService); + copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService, mockNow.now); copyResult = copyService.perform(object, newParent); copyFinished = jasmine.createSpy('copyFinished'); copyResult.then(copyFinished); }); - /** - * Test invalidated. Copy service no longer uses creation service. - */ - /*it("uses creation service", function () { - expect(creationService.createObject) - .toHaveBeenCalledWith(jasmine.any(Object), newParent); - - expect(createObjectPromise.then) - .toHaveBeenCalledWith(jasmine.any(Function)); - });*/ - it("uses persistence service", function () { expect(mockPersistenceService.createObject) - .toHaveBeenCalledWith(persistenceCapability, jasmine.any(String), object.getModel()); + .toHaveBeenCalledWith(parentPersistenceCapability, jasmine.any(String), object.getModel()); expect(persistObjectPromise.then) .toHaveBeenCalledWith(jasmine.any(Function)); @@ -301,62 +297,51 @@ define( id: '456', model: { composition: [] + }, + capabilities: { + composition: compositionCapability, + persistence: parentPersistenceCapability } }); createObjectPromise = synchronousPromise(newObject); creationService.createObject.andReturn(createObjectPromise); - copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService); - console.log("Before perform"); - //compositionPromise.then.andReturn(synchronousPromise([childObject])); - //mockQ.when.andReturn(compositionPromise); - copyResult = copyService.perform(object, newParent); - console.log("After perform"); - //compositionPromise.then.mostRecentCall.args[0]([childObject]); - copyFinished = jasmine.createSpy('copyFinished'); - copyResult.then(copyFinished); + copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService, mockNow.now); }); - /** - * Test no longer valid due to creation service not - * being used - */ - /*it("uses creation service", function () { - expect(creationService.createObject) - .toHaveBeenCalledWith(jasmine.any(Object), newParent); + describe("the cloning process", function(){ + beforeEach(function() { + copyResult = copyService.perform(object, newParent); + copyFinished = jasmine.createSpy('copyFinished'); + copyResult.then(copyFinished); + }); + /** + * This is testing that the number of calls to the + * backend is kept to a minimum + */ + it("makes only n+2 persistence calls for n copied" + + " objects", function () { + expect(mockPersistenceService.createObject.calls.length).toEqual(2); + expect(mockPersistenceService.updateObject.calls.length).toEqual(1); + expect(parentPersistenceCapability.persist).toHaveBeenCalled(); + }); - expect(createObjectPromise.then) - .toHaveBeenCalledWith(jasmine.any(Function)); - });*/ + it("copies object and children in a bottom-up" + + " fashion", function () { + expect(mockPersistenceService.createObject.calls[0].args[2].name).toEqual(childObject.model.name) + expect(mockPersistenceService.createObject.calls[1].args[2].name).toEqual(object.model.name) + }); - it("uses persistence service", function () { - //Need a better way of testing duplication here. - expect(mockPersistenceService.createObject) - .toHaveBeenCalled(); - }); - /* - //Test is no longer relevant - it("clears model composition", function () { - var newModel = creationService - .createObject - .mostRecentCall - .args[0]; + it("returns a promise", function () { + expect(copyResult.then).toBeDefined(); + expect(copyFinished).toHaveBeenCalled(); + }); - expect(newModel.composition.length).toBe(0); - expect(newModel.name).toBe('some object'); - });*/ + it("clears modified and sets persisted", function () { + expect(copyFinished.mostRecentCall.args[0].model.modified).toBeUndefined(); + expect(copyFinished.mostRecentCall.args[0].model.persisted).toBe(mockNow.now()); + }); - it("recursively clones it's children", function () { - //TODO: This is a valid test, but needs rewritten - /*expect(creationService.createObject.calls.length).toBe(1); - expect(compositionCapability.invoke).toHaveBeenCalled(); - compositionPromise.then.mostRecentCall.args[0]([childObject]); - expect(creationService.createObject.calls.length).toBe(2);*/ - }); - - it("returns a promise", function () { - expect(copyResult.then).toBeDefined(); - expect(copyFinished).toHaveBeenCalled(); }); }); @@ -378,7 +363,7 @@ define( it("throws an error", function () { var copyService = - new CopyService(mockQ, creationService, policyService, mockPersistenceService); + new CopyService(mockQ, creationService, policyService, mockPersistenceService, mockNow.now); function perform() { copyService.perform(object, newParent); @@ -391,10 +376,6 @@ define( expect(perform).toThrow(); }); }); - /** - * Additional tests: - * - Created and persisted dates - */ }); }); From fa7131ad5cb750211f9ca3bcce3e31521ae33be7 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Tue, 3 Nov 2015 21:06:00 -0800 Subject: [PATCH 35/62] Refactoring to use promises notifications --- .../entanglement/src/actions/CopyAction.js | 66 +++++++++++++++---- .../entanglement/src/services/CopyService.js | 21 +++--- 2 files changed, 65 insertions(+), 22 deletions(-) diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index a8dbf95d4c..62ce5619ba 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -26,6 +26,20 @@ define( function (AbstractComposeAction) { "use strict"; + /* + function CopyAction(locationService, copyService, context) { + return new AbstractComposeAction ( + locationService, + copyService, + context, + "Duplicate", + "to a location" + ); + } + + return CopyAction; + */ + /** * The CopyAction is available from context menus and allows a user to * deep copy an object to another location of their choosing. @@ -34,15 +48,21 @@ define( * @constructor * @memberof platform/entanglement */ - function CopyAction($log, locationService, copyService, dialogService, notificationService, context) { + function CopyAction($log, locationService, copyService, dialogService, + notificationService, context) { this.dialogService = dialogService; this.notificationService = notificationService; this.$log = $log; - AbstractComposeAction.call(this, locationService, copyService, context, "Duplicate", "to a location"); + //Extend the behaviour of the Abstract Compose Action + AbstractComposeAction.call(this, locationService, copyService, + context, "Duplicate", "to a location"); } - CopyAction.prototype = Object.create(AbstractComposeAction.prototype); - + /** + * Executes the CopyAction. The CopyAction uses the default behaviour of + * the AbstractComposeAction, but extends it to support notification + * updates of progress on copy. + */ CopyAction.prototype.perform = function() { var self = this, notification, @@ -51,8 +71,19 @@ define( unknownProgress: false, severity: "info", }; - + + /* + Show banner notification of copy progress. + */ function progress(phase, totalObjects, processed){ + /* + Copy has two distinct phases. In the first phase a copy plan is + made in memory. During this phase of execution, the user is + shown a blocking 'modal' dialog. + + In the second phase, the copying is taking place, and the user + is shown non-invasive banner notifications at the bottom of the screen. + */ if (phase.toLowerCase() === 'preparing'){ self.dialogService.showBlockingMessage({ title: "Preparing to copy objects", @@ -62,19 +93,22 @@ define( } else if (phase.toLowerCase() === "copying") { self.dialogService.dismiss(); if (!notification) { - notification = self.notificationService.notify(notificationModel); + notification = self.notificationService + .notify(notificationModel); } notificationModel.progress = (processed / totalObjects) * 100; - notificationModel.title = ["Copied ", processed, "of ", totalObjects, "objects"].join(" "); + notificationModel.title = ["Copied ", processed, "of ", + totalObjects, "objects"].join(" "); } } - AbstractComposeAction.prototype.perform.call(this, progress) - .then(function(){ - notification.dismiss(); - self.notificationService.info("Copying complete."); - }) - .catch(function (error){ + AbstractComposeAction.prototype.perform.call(this) + .then( + function(){ + notification.dismiss(); + self.notificationService.info("Copying complete."); + }, + function(error){ self.$log.error("Error copying objects. ", error); //Show more general error message self.notificationService.notify({ @@ -82,7 +116,11 @@ define( severity: "error", hint: error.message }); - }); + + }, + function(notification){ + progress(notification.phase, notification.totalObjects, notification.processed); + }) }; return CopyAction; } diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 220084f7a5..710c0ef78b 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -68,7 +68,7 @@ define( * object being copied. The clones are all full composed with * references to their own children. */ - CopyService.prototype.buildCopyPlan = function(domainObject, parent) { + CopyService.prototype.buildCopyPlan = function(domainObject, parent, progress) { var clones = [], $q = this.$q, self = this; @@ -99,6 +99,8 @@ define( delete modelClone.model.persisted; delete modelClone.model.modified; return $q.when(originalObject.useCapability('composition')).then(function(composees){ + + progress({phase: "preparing"}); return (composees || []).reduce(function(promise, composee){ //If the object is composed of other // objects, chain a promise.. @@ -120,6 +122,7 @@ define( }); }); }; + return copy(domainObject, parent).then(function(){ return clones; }); @@ -142,7 +145,7 @@ define( clone.model.persisted = self.now(); return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ - progress && progress("copying", objectClones.length, ++persisted); + progress && progress({phase: "copying", totalObjects: objectClones.length, processed: ++persisted}); }); })).then(function(){ return objectClones @@ -184,13 +187,15 @@ define( * @returns a promise that will be completed with the clone of * domainObject when the duplication is successful. */ - CopyService.prototype.perform = function (domainObject, parent, progress) { - var $q = this.$q; + CopyService.prototype.perform = function (domainObject, parent) { + var $q = this.$q, + deferred = $q.defer(); if (this.validate(domainObject, parent)) { - progress && progress("preparing"); - return this.buildCopyPlan(domainObject, parent) - .then(this.persistObjects(progress)) - .then(this.addClonesToParent(parent, progress)); + this.buildCopyPlan(domainObject, parent, deferred.notify) + .then(this.persistObjects(deferred.notify)) + .then(this.addClonesToParent(parent, deferred.notify)) + .then(deferred.resolve); + return deferred.promise; } else { throw new Error( "Tried to copy objects without validating first." From 05481dcab590b45ef4c846cba3dbc6d370c05d79 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Tue, 3 Nov 2015 21:13:10 -0800 Subject: [PATCH 36/62] reverted AbstractComposeAction --- .../entanglement/src/actions/AbstractComposeAction.js | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/platform/entanglement/src/actions/AbstractComposeAction.js b/platform/entanglement/src/actions/AbstractComposeAction.js index 5538eec3be..f68391adc9 100644 --- a/platform/entanglement/src/actions/AbstractComposeAction.js +++ b/platform/entanglement/src/actions/AbstractComposeAction.js @@ -70,10 +70,6 @@ define( * @param {string} verb the verb to display for the action (e.g. "Move") * @param {string} [suffix] a string to display in the dialog title; * default is "to a new location" - * @param {function} progressCallback a callback function that will - * be invoked to update invoker on progress. This is optional and - * may not be implemented by all composing actions. The signature of - * the callback function will depend on the service being invoked. */ function AbstractComposeAction(locationService, composeService, context, verb, suffix) { if (context.selectedObject) { @@ -93,7 +89,7 @@ define( this.suffix = suffix || "to a new location"; } - AbstractComposeAction.prototype.perform = function (progressCallback) { + AbstractComposeAction.prototype.perform = function () { var dialogTitle, label, validateLocation, @@ -122,7 +118,7 @@ define( validateLocation, currentParent ).then(function (newParent) { - return composeService.perform(object, newParent, progressCallback); + return composeService.perform(object, newParent); }); }; From 4e69ca50fb68441420844a18605256f906cf7d0c Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Tue, 3 Nov 2015 21:31:19 -0800 Subject: [PATCH 37/62] Fixed blocking dialog --- platform/entanglement/src/actions/CopyAction.js | 5 +++-- platform/entanglement/src/services/CopyService.js | 3 +-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index 62ce5619ba..c7a1c14ba7 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -66,6 +66,7 @@ define( CopyAction.prototype.perform = function() { var self = this, notification, + dialog, notificationModel = { title: "Copying objects", unknownProgress: false, @@ -84,8 +85,8 @@ define( In the second phase, the copying is taking place, and the user is shown non-invasive banner notifications at the bottom of the screen. */ - if (phase.toLowerCase() === 'preparing'){ - self.dialogService.showBlockingMessage({ + if (phase.toLowerCase() === 'preparing' && !dialog){ + dialog = self.dialogService.showBlockingMessage({ title: "Preparing to copy objects", unknownProgress: true, severity: "info", diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 710c0ef78b..53053fef8e 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -99,7 +99,6 @@ define( delete modelClone.model.persisted; delete modelClone.model.modified; return $q.when(originalObject.useCapability('composition')).then(function(composees){ - progress({phase: "preparing"}); return (composees || []).reduce(function(promise, composee){ //If the object is composed of other @@ -191,7 +190,7 @@ define( var $q = this.$q, deferred = $q.defer(); if (this.validate(domainObject, parent)) { - this.buildCopyPlan(domainObject, parent, deferred.notify) + this.buildCopyPlan(domainObject, parent, deferred.notify) .then(this.persistObjects(deferred.notify)) .then(this.addClonesToParent(parent, deferred.notify)) .then(deferred.resolve); From 5e1b0f38b76b87614287d88beccd6ee385ffa5e2 Mon Sep 17 00:00:00 2001 From: Henry Date: Wed, 4 Nov 2015 15:38:22 -0800 Subject: [PATCH 38/62] Migrated to using notifications and fixed tests --- .../entanglement/src/services/CopyService.js | 17 +++- .../test/actions/AbstractComposeActionSpec.js | 2 +- .../test/services/CopyServiceSpec.js | 94 +++++++++++-------- 3 files changed, 68 insertions(+), 45 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 53053fef8e..353afa3d14 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -95,7 +95,6 @@ define( persistenceSpace: originalParent.getCapability('persistence') } delete modelClone.model.composition; - delete modelClone.model.location; delete modelClone.model.persisted; delete modelClone.model.modified; return $q.when(originalObject.useCapability('composition')).then(function(composees){ @@ -108,7 +107,11 @@ define( return copy(composee, originalObject).then(function(composeeClone){ //Once copied, associate each cloned // composee with its parent clone - composeeClone.model.location = modelClone.id; + if ( !(composee.hasCapability("location") && composee.getCapability("location").isLink())) { + //If the object is not a link, + // locate it within its parent + composeeClone.model.location = modelClone.id; + } modelClone.model.composition = modelClone.model.composition || []; return modelClone.model.composition.push(composeeClone.id); }); @@ -122,7 +125,12 @@ define( }); }; - return copy(domainObject, parent).then(function(){ + return copy(domainObject, parent).then(function(domainObjectClone){ + //If the domain object being cloned is not a link, set its + // location to the new parent + if ( !(domainObject.hasCapability("location") && domainObject.getCapability("location").isLink())) { + domainObjectClone.model.location = parent.getId(); + } return clones; }); } @@ -166,8 +174,7 @@ define( if (!parent.hasCapability('composition')){ return self.$q.reject(); } - parentClone.model.location = parent.getId(); - + return self.persistenceService .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) .then(function(){return parent.getCapability("composition").add(parentClone.id)}) diff --git a/platform/entanglement/test/actions/AbstractComposeActionSpec.js b/platform/entanglement/test/actions/AbstractComposeActionSpec.js index b65e0569ff..5be0604ec3 100644 --- a/platform/entanglement/test/actions/AbstractComposeActionSpec.js +++ b/platform/entanglement/test/actions/AbstractComposeActionSpec.js @@ -140,7 +140,7 @@ define( .args[0](newParent); expect(composeService.perform) - .toHaveBeenCalledWith(selectedObject, newParent, undefined); + .toHaveBeenCalledWith(selectedObject, newParent); }); }); }); diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index 7839b78a7d..a41b69afbd 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -126,6 +126,7 @@ define( describe("perform", function () { var mockQ, + mockDeferred, creationService, createObjectPromise, copyService, @@ -167,19 +168,33 @@ define( mockNow.now.andCallFake(function(){ return 1234; }) + + var resolvedValue; + + mockDeferred = jasmine.createSpyObj('mockDeferred', ['notify', 'resolve']); + mockDeferred.notify.andCallFake(function(notification){}); + mockDeferred.resolve.andCallFake(function(value){resolvedValue = value}) + mockDeferred.promise = { + then: function(callback){ + return synchronousPromise(callback(resolvedValue)); + } + } + + mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject', 'defer']); + mockQ.when.andCallFake(synchronousPromise); + mockQ.all.andCallFake(function (promises) { + var result = {}; + Object.keys(promises).forEach(function (k) { + promises[k].then(function (v) { result[k] = v; }); + }); + return synchronousPromise(result); + }); + mockQ.defer.andReturn(mockDeferred); }); describe("on domain object without composition", function () { beforeEach(function () { - object = domainObjectFactory({ - name: 'object', - id: 'abc', - model: { - name: 'some object', - persisted: mockNow.now() - } - }); newParent = domainObjectFactory({ name: 'newParent', id: '456', @@ -190,14 +205,15 @@ define( persistence: parentPersistenceCapability } }); - mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); - mockQ.when.andCallFake(synchronousPromise); - mockQ.all.andCallFake(function (promises) { - var result = {}; - Object.keys(promises).forEach(function (k) { - promises[k].then(function (v) { result[k] = v; }); - }); - return synchronousPromise(result); + + object = domainObjectFactory({ + name: 'object', + id: 'abc', + model: { + name: 'some object', + location: newParent.id, + persisted: mockNow.now() + } }); copyService = new CopyService(mockQ, creationService, policyService, mockPersistenceService, mockNow.now); @@ -235,18 +251,14 @@ define( var newObject, childObject, compositionCapability, + locationCapability, compositionPromise; beforeEach(function () { - mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject']); - mockQ.when.andCallFake(synchronousPromise); - mockQ.all.andCallFake(function (promises) { - var result = {}; - Object.keys(promises).forEach(function (k) { - promises[k].then(function (v) { result[k] = v; }); - }); - return synchronousPromise(result); - }); + + + locationCapability = jasmine.createSpyObj('locationCapability', ['isLink']); + locationCapability.isLink.andReturn(true); childObject = domainObjectFactory({ name: 'childObject', @@ -264,8 +276,6 @@ define( ['then'] ); - //compositionPromise.then.andCallFake(synchronousPromise); - compositionCapability .invoke .andReturn(synchronousPromise([childObject])); @@ -275,10 +285,12 @@ define( id: 'abc', model: { name: 'some object', - composition: ['def'] + composition: ['def'], + location: 'testLocation' }, capabilities: { - composition: compositionCapability + composition: compositionCapability, + location: locationCapability } }); newObject = domainObjectFactory({ @@ -315,16 +327,6 @@ define( copyFinished = jasmine.createSpy('copyFinished'); copyResult.then(copyFinished); }); - /** - * This is testing that the number of calls to the - * backend is kept to a minimum - */ - it("makes only n+2 persistence calls for n copied" + - " objects", function () { - expect(mockPersistenceService.createObject.calls.length).toEqual(2); - expect(mockPersistenceService.updateObject.calls.length).toEqual(1); - expect(parentPersistenceCapability.persist).toHaveBeenCalled(); - }); it("copies object and children in a bottom-up" + " fashion", function () { @@ -342,6 +344,20 @@ define( expect(copyFinished.mostRecentCall.args[0].model.persisted).toBe(mockNow.now()); }); + /** + Preserves links + */ + it ("preserves links", function() { + expect(copyFinished.mostRecentCall.args[0].model.location).toBe("testLocation"); + }); + + /** + Preserves links + */ + it ("correctly locates cloned objects", function() { + expect(mockPersistenceService.createObject.calls[0].args[2].location).toEqual(mockPersistenceService.createObject.calls[1].args[1]) + }); + }); }); From 7d1a1acc11bbdbce4221763151b7d286840f9c14 Mon Sep 17 00:00:00 2001 From: Henry Date: Wed, 4 Nov 2015 17:39:44 -0800 Subject: [PATCH 39/62] Adding tests for Copy Action --- .../entanglement/src/actions/CopyAction.js | 112 ++++++----- .../test/actions/CopyActionSpec.js | 58 +++++- .../test/actions/LinkActionSpec.js | 174 ------------------ .../test/actions/MoveActionSpec.js | 174 ------------------ platform/entanglement/test/suite.json | 1 + 5 files changed, 109 insertions(+), 410 deletions(-) delete mode 100644 platform/entanglement/test/actions/LinkActionSpec.js delete mode 100644 platform/entanglement/test/actions/MoveActionSpec.js diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index c7a1c14ba7..6df372b45c 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -26,20 +26,6 @@ define( function (AbstractComposeAction) { "use strict"; - /* - function CopyAction(locationService, copyService, context) { - return new AbstractComposeAction ( - locationService, - copyService, - context, - "Duplicate", - "to a location" - ); - } - - return CopyAction; - */ - /** * The CopyAction is available from context menus and allows a user to * deep copy an object to another location of their choosing. @@ -50,6 +36,8 @@ define( */ function CopyAction($log, locationService, copyService, dialogService, notificationService, context) { + this.dialog = undefined; + this.notification = undefined; this.dialogService = dialogService; this.notificationService = notificationService; this.$log = $log; @@ -58,58 +46,61 @@ define( context, "Duplicate", "to a location"); } + /** + * Updates user about progress of copy. Should not be invoked by + * client code under any circumstances. + * + * @private + * @param phase + * @param totalObjects + * @param processed + */ + CopyAction.prototype.progress = function(phase, totalObjects, processed){ + /* + Copy has two distinct phases. In the first phase a copy plan is + made in memory. During this phase of execution, the user is + shown a blocking 'modal' dialog. + + In the second phase, the copying is taking place, and the user + is shown non-invasive banner notifications at the bottom of the screen. + */ + if (phase.toLowerCase() === 'preparing' && !this.dialog){ + this.dialog = self.dialogService.showBlockingMessage({ + title: "Preparing to copy objects", + unknownProgress: true, + severity: "info", + }); + } else if (phase.toLowerCase() === "copying") { + self.dialogService.dismiss(); + if (!notification) { + this.notification = self.notificationService + .notify({ + title: "Copying objects", + unknownProgress: false, + severity: "info" + }); + } + this.notification.model.progress = (processed / totalObjects) * 100; + this.notification.model.title = ["Copied ", processed, "of ", + totalObjects, "objects"].join(" "); + } + } + /** * Executes the CopyAction. The CopyAction uses the default behaviour of * the AbstractComposeAction, but extends it to support notification * updates of progress on copy. */ CopyAction.prototype.perform = function() { - var self = this, - notification, - dialog, - notificationModel = { - title: "Copying objects", - unknownProgress: false, - severity: "info", - }; - - /* - Show banner notification of copy progress. - */ - function progress(phase, totalObjects, processed){ - /* - Copy has two distinct phases. In the first phase a copy plan is - made in memory. During this phase of execution, the user is - shown a blocking 'modal' dialog. - - In the second phase, the copying is taking place, and the user - is shown non-invasive banner notifications at the bottom of the screen. - */ - if (phase.toLowerCase() === 'preparing' && !dialog){ - dialog = self.dialogService.showBlockingMessage({ - title: "Preparing to copy objects", - unknownProgress: true, - severity: "info", - }); - } else if (phase.toLowerCase() === "copying") { - self.dialogService.dismiss(); - if (!notification) { - notification = self.notificationService - .notify(notificationModel); - } - notificationModel.progress = (processed / totalObjects) * 100; - notificationModel.title = ["Copied ", processed, "of ", - totalObjects, "objects"].join(" "); - } - } + var self = this; - AbstractComposeAction.prototype.perform.call(this) + return AbstractComposeAction.prototype.perform.call(this) .then( - function(){ - notification.dismiss(); + function success(){ + self.notification.dismiss(); self.notificationService.info("Copying complete."); }, - function(error){ + function error(error){ self.$log.error("Error copying objects. ", error); //Show more general error message self.notificationService.notify({ @@ -119,10 +110,11 @@ define( }); }, - function(notification){ - progress(notification.phase, notification.totalObjects, notification.processed); - }) - }; + function notification(notification){ + this.progress(notification.phase, notification.totalObjects, notification.processed); + } + ); + }; return CopyAction; } ); diff --git a/platform/entanglement/test/actions/CopyActionSpec.js b/platform/entanglement/test/actions/CopyActionSpec.js index 4284a22e59..3fa4055f4c 100644 --- a/platform/entanglement/test/actions/CopyActionSpec.js +++ b/platform/entanglement/test/actions/CopyActionSpec.js @@ -41,7 +41,12 @@ define( selectedObject, selectedObjectContextCapability, currentParent, - newParent; + newParent, + notificationService, + notification, + dialogService, + mockLog, + abstractComposePromise; beforeEach(function () { selectedObjectContextCapability = jasmine.createSpyObj( @@ -87,10 +92,47 @@ define( ] ); + abstractComposePromise = jasmine.createSpyObj( + 'abstractComposePromise', + [ + 'then' + ] + ); + + abstractComposePromise.then.andCallFake(function(success, error, notify){ + notify({phase: "copying", totalObjects: 10, processed: 10}); + success(); + } + ) + + locationServicePromise.then.andCallFake(function(callback){ + callback(newParent); + return abstractComposePromise; + }); + locationService .getLocationFromUser .andReturn(locationServicePromise); + dialogService = jasmine.createSpyObj('dialogService', + ['showBlockingMessage'] + ); + dialogService.showBlockingMessage.andReturn(); + + notification = jasmine.createSpyObj('notification', + ['dismiss', 'model'] + ); + notification.dismiss.andReturn(); + + notificationService = jasmine.createSpyObj('notificationService', + ['notify'] + ); + + notificationService.notify.andReturn(notification); + + mockLog = jasmine.createSpyObj('log', ['error']); + mockLog.error.andReturn(); + copyService = new MockCopyService(); }); @@ -102,8 +144,11 @@ define( }; copyAction = new CopyAction( + mockLog, locationService, copyService, + dialogService, + notificationService, context ); }); @@ -114,6 +159,7 @@ define( describe("when performed it", function () { beforeEach(function () { + spyOn(copyAction, 'progress').andCallThrough(); copyAction.perform(); }); @@ -132,7 +178,7 @@ define( .toHaveBeenCalledWith(jasmine.any(Function)); }); - it("copys object to selected location", function () { + it("copies object to selected location", function () { locationServicePromise .then .mostRecentCall @@ -141,6 +187,11 @@ define( expect(copyService.perform) .toHaveBeenCalledWith(selectedObject, newParent); }); + + it("notifies the user of progress", function(){ + expect(copyAction.progress.calls.length).toBeGreaterThan(0) + }); + }); }); @@ -152,8 +203,11 @@ define( }; copyAction = new CopyAction( + mockLog, locationService, copyService, + dialogService, + notificationService, context ); }); diff --git a/platform/entanglement/test/actions/LinkActionSpec.js b/platform/entanglement/test/actions/LinkActionSpec.js deleted file mode 100644 index 03967a6672..0000000000 --- a/platform/entanglement/test/actions/LinkActionSpec.js +++ /dev/null @@ -1,174 +0,0 @@ -/***************************************************************************** - * Open MCT Web, Copyright (c) 2014-2015, United States Government - * as represented by the Administrator of the National Aeronautics and Space - * Administration. All rights reserved. - * - * Open MCT Web is licensed under the Apache License, Version 2.0 (the - * "License"); you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * http://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * Open MCT Web includes source code licensed under additional open source - * licenses. See the Open Source Licenses file (LICENSES.md) included with - * this source code distribution or the Licensing information page available - * at runtime from the About dialog for additional information. - *****************************************************************************/ - -/*global define,describe,beforeEach,it,jasmine,expect */ - -define( - [ - '../../src/actions/LinkAction', - '../services/MockLinkService', - '../DomainObjectFactory' - ], - function (LinkAction, MockLinkService, domainObjectFactory) { - "use strict"; - - describe("Link Action", function () { - - var linkAction, - locationService, - locationServicePromise, - linkService, - context, - selectedObject, - selectedObjectContextCapability, - currentParent, - newParent; - - beforeEach(function () { - selectedObjectContextCapability = jasmine.createSpyObj( - 'selectedObjectContextCapability', - [ - 'getParent' - ] - ); - - selectedObject = domainObjectFactory({ - name: 'selectedObject', - model: { - name: 'selectedObject' - }, - capabilities: { - context: selectedObjectContextCapability - } - }); - - currentParent = domainObjectFactory({ - name: 'currentParent' - }); - - selectedObjectContextCapability - .getParent - .andReturn(currentParent); - - newParent = domainObjectFactory({ - name: 'newParent' - }); - - locationService = jasmine.createSpyObj( - 'locationService', - [ - 'getLocationFromUser' - ] - ); - - locationServicePromise = jasmine.createSpyObj( - 'locationServicePromise', - [ - 'then' - ] - ); - - locationService - .getLocationFromUser - .andReturn(locationServicePromise); - - linkService = new MockLinkService(); - }); - - - describe("with context from context-action", function () { - beforeEach(function () { - context = { - domainObject: selectedObject - }; - - linkAction = new LinkAction( - locationService, - linkService, - context - ); - }); - - it("initializes happily", function () { - expect(linkAction).toBeDefined(); - }); - - describe("when performed it", function () { - beforeEach(function () { - linkAction.perform(); - }); - - it("prompts for location", function () { - expect(locationService.getLocationFromUser) - .toHaveBeenCalledWith( - "Link selectedObject to a new location", - "Link To", - jasmine.any(Function), - currentParent - ); - }); - - it("waits for location from user", function () { - expect(locationServicePromise.then) - .toHaveBeenCalledWith(jasmine.any(Function)); - }); - - it("links object to selected location", function () { - locationServicePromise - .then - .mostRecentCall - .args[0](newParent); - - expect(linkService.perform) - .toHaveBeenCalledWith(selectedObject, newParent); - }); - }); - }); - - describe("with context from drag-drop", function () { - beforeEach(function () { - context = { - selectedObject: selectedObject, - domainObject: newParent - }; - - linkAction = new LinkAction( - locationService, - linkService, - context - ); - }); - - it("initializes happily", function () { - expect(linkAction).toBeDefined(); - }); - - - it("performs link immediately", function () { - linkAction.perform(); - expect(linkService.perform) - .toHaveBeenCalledWith(selectedObject, newParent); - }); - }); - }); - } -); diff --git a/platform/entanglement/test/actions/MoveActionSpec.js b/platform/entanglement/test/actions/MoveActionSpec.js deleted file mode 100644 index 52a7c6e301..0000000000 --- a/platform/entanglement/test/actions/MoveActionSpec.js +++ /dev/null @@ -1,174 +0,0 @@ -/***************************************************************************** - * Open MCT Web, Copyright (c) 2014-2015, United States Government - * as represented by the Administrator of the National Aeronautics and Space - * Administration. All rights reserved. - * - * Open MCT Web is licensed under the Apache License, Version 2.0 (the - * "License"); you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * http://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * Open MCT Web includes source code licensed under additional open source - * licenses. See the Open Source Licenses file (LICENSES.md) included with - * this source code distribution or the Licensing information page available - * at runtime from the About dialog for additional information. - *****************************************************************************/ - -/*global define,describe,beforeEach,it,jasmine,expect */ - -define( - [ - '../../src/actions/MoveAction', - '../services/MockMoveService', - '../DomainObjectFactory' - ], - function (MoveAction, MockMoveService, domainObjectFactory) { - "use strict"; - - describe("Move Action", function () { - - var moveAction, - locationService, - locationServicePromise, - moveService, - context, - selectedObject, - selectedObjectContextCapability, - currentParent, - newParent; - - beforeEach(function () { - selectedObjectContextCapability = jasmine.createSpyObj( - 'selectedObjectContextCapability', - [ - 'getParent' - ] - ); - - selectedObject = domainObjectFactory({ - name: 'selectedObject', - model: { - name: 'selectedObject' - }, - capabilities: { - context: selectedObjectContextCapability - } - }); - - currentParent = domainObjectFactory({ - name: 'currentParent' - }); - - selectedObjectContextCapability - .getParent - .andReturn(currentParent); - - newParent = domainObjectFactory({ - name: 'newParent' - }); - - locationService = jasmine.createSpyObj( - 'locationService', - [ - 'getLocationFromUser' - ] - ); - - locationServicePromise = jasmine.createSpyObj( - 'locationServicePromise', - [ - 'then' - ] - ); - - locationService - .getLocationFromUser - .andReturn(locationServicePromise); - - moveService = new MockMoveService(); - }); - - - describe("with context from context-action", function () { - beforeEach(function () { - context = { - domainObject: selectedObject - }; - - moveAction = new MoveAction( - locationService, - moveService, - context - ); - }); - - it("initializes happily", function () { - expect(moveAction).toBeDefined(); - }); - - describe("when performed it", function () { - beforeEach(function () { - moveAction.perform(); - }); - - it("prompts for location", function () { - expect(locationService.getLocationFromUser) - .toHaveBeenCalledWith( - "Move selectedObject to a new location", - "Move To", - jasmine.any(Function), - currentParent - ); - }); - - it("waits for location from user", function () { - expect(locationServicePromise.then) - .toHaveBeenCalledWith(jasmine.any(Function)); - }); - - it("moves object to selected location", function () { - locationServicePromise - .then - .mostRecentCall - .args[0](newParent); - - expect(moveService.perform) - .toHaveBeenCalledWith(selectedObject, newParent); - }); - }); - }); - - describe("with context from drag-drop", function () { - beforeEach(function () { - context = { - selectedObject: selectedObject, - domainObject: newParent - }; - - moveAction = new MoveAction( - locationService, - moveService, - context - ); - }); - - it("initializes happily", function () { - expect(moveAction).toBeDefined(); - }); - - - it("performs move immediately", function () { - moveAction.perform(); - expect(moveService.perform) - .toHaveBeenCalledWith(selectedObject, newParent); - }); - }); - }); - } -); diff --git a/platform/entanglement/test/suite.json b/platform/entanglement/test/suite.json index 12831b407a..a4db45a909 100644 --- a/platform/entanglement/test/suite.json +++ b/platform/entanglement/test/suite.json @@ -1,5 +1,6 @@ [ "actions/AbstractComposeAction", + "actions/CopyAction", "services/CopyService", "services/LinkService", "services/MoveService", From 529dde57b99a359025dbca59ab9a972b8ce74dee Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 4 Nov 2015 20:12:36 -0800 Subject: [PATCH 40/62] Added test for notification to CopyActionSpec --- platform/entanglement/src/actions/CopyAction.js | 10 +++++----- .../entanglement/test/actions/CopyActionSpec.js | 17 +++++++++-------- 2 files changed, 14 insertions(+), 13 deletions(-) diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index 6df372b45c..abbc521077 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -65,15 +65,15 @@ define( is shown non-invasive banner notifications at the bottom of the screen. */ if (phase.toLowerCase() === 'preparing' && !this.dialog){ - this.dialog = self.dialogService.showBlockingMessage({ + this.dialog = this.dialogService.showBlockingMessage({ title: "Preparing to copy objects", unknownProgress: true, severity: "info", }); } else if (phase.toLowerCase() === "copying") { - self.dialogService.dismiss(); - if (!notification) { - this.notification = self.notificationService + this.dialogService.dismiss(); + if (!this.notification) { + this.notification = this.notificationService .notify({ title: "Copying objects", unknownProgress: false, @@ -111,7 +111,7 @@ define( }, function notification(notification){ - this.progress(notification.phase, notification.totalObjects, notification.processed); + self.progress(notification.phase, notification.totalObjects, notification.processed); } ); }; diff --git a/platform/entanglement/test/actions/CopyActionSpec.js b/platform/entanglement/test/actions/CopyActionSpec.js index 3fa4055f4c..ebedf066db 100644 --- a/platform/entanglement/test/actions/CopyActionSpec.js +++ b/platform/entanglement/test/actions/CopyActionSpec.js @@ -46,7 +46,8 @@ define( notification, dialogService, mockLog, - abstractComposePromise; + abstractComposePromise, + progress = {phase: "copying", totalObjects: 10, processed: 1}; beforeEach(function () { selectedObjectContextCapability = jasmine.createSpyObj( @@ -100,7 +101,7 @@ define( ); abstractComposePromise.then.andCallFake(function(success, error, notify){ - notify({phase: "copying", totalObjects: 10, processed: 10}); + notify(progress); success(); } ) @@ -115,23 +116,23 @@ define( .andReturn(locationServicePromise); dialogService = jasmine.createSpyObj('dialogService', - ['showBlockingMessage'] + ['showBlockingMessage', 'dismiss'] ); - dialogService.showBlockingMessage.andReturn(); + //dialogService.showBlockingMessage.andReturn(); notification = jasmine.createSpyObj('notification', ['dismiss', 'model'] ); - notification.dismiss.andReturn(); + //notification.dismiss.andReturn(); notificationService = jasmine.createSpyObj('notificationService', - ['notify'] + ['notify', 'info'] ); notificationService.notify.andReturn(notification); mockLog = jasmine.createSpyObj('log', ['error']); - mockLog.error.andReturn(); + //mockLog.error.andReturn(); copyService = new MockCopyService(); }); @@ -189,7 +190,7 @@ define( }); it("notifies the user of progress", function(){ - expect(copyAction.progress.calls.length).toBeGreaterThan(0) + expect(notificationService.info).toHaveBeenCalled(); }); }); From 10e711f71737e99f8e4d6ed8d7f31ee0476b3a0d Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 4 Nov 2015 20:13:24 -0800 Subject: [PATCH 41/62] Removed commented code --- platform/entanglement/test/actions/CopyActionSpec.js | 3 --- 1 file changed, 3 deletions(-) diff --git a/platform/entanglement/test/actions/CopyActionSpec.js b/platform/entanglement/test/actions/CopyActionSpec.js index ebedf066db..7362772dbd 100644 --- a/platform/entanglement/test/actions/CopyActionSpec.js +++ b/platform/entanglement/test/actions/CopyActionSpec.js @@ -118,12 +118,10 @@ define( dialogService = jasmine.createSpyObj('dialogService', ['showBlockingMessage', 'dismiss'] ); - //dialogService.showBlockingMessage.andReturn(); notification = jasmine.createSpyObj('notification', ['dismiss', 'model'] ); - //notification.dismiss.andReturn(); notificationService = jasmine.createSpyObj('notificationService', ['notify', 'info'] @@ -132,7 +130,6 @@ define( notificationService.notify.andReturn(notification); mockLog = jasmine.createSpyObj('log', ['error']); - //mockLog.error.andReturn(); copyService = new MockCopyService(); }); From 863c3f172043ffb6014e34d242f8268894a6fdde Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 4 Nov 2015 20:48:22 -0800 Subject: [PATCH 42/62] Fixed jslint issues --- .../notification/src/NotificationService.js | 2 +- .../entanglement/src/actions/CopyAction.js | 14 +++++----- .../entanglement/src/services/CopyService.js | 26 +++++++++---------- .../test/actions/CopyActionSpec.js | 9 +++---- .../test/services/CopyServiceSpec.js | 17 ++++++------ 5 files changed, 33 insertions(+), 35 deletions(-) diff --git a/platform/commonUI/notification/src/NotificationService.js b/platform/commonUI/notification/src/NotificationService.js index d6fac910a7..5064dceb0f 100644 --- a/platform/commonUI/notification/src/NotificationService.js +++ b/platform/commonUI/notification/src/NotificationService.js @@ -222,7 +222,7 @@ define( * functions to dismiss or minimize */ NotificationService.prototype.info = function (model) { - var notificationModel = typeof model === "string" ? {title: model} : model + var notificationModel = typeof model === "string" ? {title: model} : model; notificationModel.autoDismiss = notificationModel.autoDismiss || true; notificationModel.severity = "info"; return this.notify(notificationModel); diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index abbc521077..a336ffd2c9 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -68,7 +68,7 @@ define( this.dialog = this.dialogService.showBlockingMessage({ title: "Preparing to copy objects", unknownProgress: true, - severity: "info", + severity: "info" }); } else if (phase.toLowerCase() === "copying") { this.dialogService.dismiss(); @@ -84,7 +84,7 @@ define( this.notification.model.title = ["Copied ", processed, "of ", totalObjects, "objects"].join(" "); } - } + }; /** * Executes the CopyAction. The CopyAction uses the default behaviour of @@ -100,18 +100,18 @@ define( self.notification.dismiss(); self.notificationService.info("Copying complete."); }, - function error(error){ - self.$log.error("Error copying objects. ", error); + function error(errorDetails){ + self.$log.error("Error copying objects. ", errorDetails); //Show more general error message self.notificationService.notify({ title: "Error copying objects.", severity: "error", - hint: error.message + hint: errorDetails.message }); }, - function notification(notification){ - self.progress(notification.phase, notification.totalObjects, notification.processed); + function notification(details){ + self.progress(details.phase, details.totalObjects, details.processed); } ); }; diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 353afa3d14..3d0a730e7c 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -93,7 +93,7 @@ define( id: uuid(), model: makeClone(originalObject.getModel()), persistenceSpace: originalParent.getCapability('persistence') - } + }; delete modelClone.model.composition; delete modelClone.model.persisted; delete modelClone.model.modified; @@ -123,7 +123,7 @@ define( return modelClone; }); }); - }; + } return copy(domainObject, parent).then(function(domainObjectClone){ //If the domain object being cloned is not a link, set its @@ -133,7 +133,7 @@ define( } return clones; }); - } + }; /** * Will persist a list of {@link objectClones}. It will persist all @@ -152,13 +152,13 @@ define( clone.model.persisted = self.now(); return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ - progress && progress({phase: "copying", totalObjects: objectClones.length, processed: ++persisted}); + return progress && progress({phase: "copying", totalObjects: objectClones.length, processed: ++persisted}); }); })).then(function(){ - return objectClones + return objectClones; }); - } - } + }; + }; /** * Will add a list of clones to the specified parent's composition @@ -177,12 +177,12 @@ define( return self.persistenceService .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) - .then(function(){return parent.getCapability("composition").add(parentClone.id)}) - .then(function(){return parent.getCapability("persistence").persist()}) - .then(function(){return parentClone}); + .then(function(){return parent.getCapability("composition").add(parentClone.id);}) + .then(function(){return parent.getCapability("persistence").persist();}) + .then(function(){return parentClone;}); // Ensure the clone of the original domainObject is returned - } - } + }; + }; /** * Creates a duplicate of the object tree starting at domainObject to @@ -207,7 +207,7 @@ define( "Tried to copy objects without validating first." ); } - } + }; return CopyService; } diff --git a/platform/entanglement/test/actions/CopyActionSpec.js b/platform/entanglement/test/actions/CopyActionSpec.js index 7362772dbd..fc8e615960 100644 --- a/platform/entanglement/test/actions/CopyActionSpec.js +++ b/platform/entanglement/test/actions/CopyActionSpec.js @@ -20,7 +20,7 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -/*global define,describe,beforeEach,it,jasmine,expect */ +/*global define,describe,beforeEach,it,jasmine,expect,spyOn */ define( [ @@ -101,10 +101,9 @@ define( ); abstractComposePromise.then.andCallFake(function(success, error, notify){ - notify(progress); - success(); - } - ) + notify(progress); + success(); + }); locationServicePromise.then.andCallFake(function(callback){ callback(newParent); diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index a41b69afbd..af612dff92 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -137,7 +137,8 @@ define( copyResult, copyFinished, persistObjectPromise, - parentPersistenceCapability; + parentPersistenceCapability, + resolvedValue; beforeEach(function () { creationService = jasmine.createSpyObj( @@ -167,18 +168,16 @@ define( mockNow = jasmine.createSpyObj("mockNow", ["now"]); mockNow.now.andCallFake(function(){ return 1234; - }) - - var resolvedValue; + }); mockDeferred = jasmine.createSpyObj('mockDeferred', ['notify', 'resolve']); mockDeferred.notify.andCallFake(function(notification){}); - mockDeferred.resolve.andCallFake(function(value){resolvedValue = value}) + mockDeferred.resolve.andCallFake(function(value){resolvedValue = value;}); mockDeferred.promise = { then: function(callback){ return synchronousPromise(callback(resolvedValue)); } - } + }; mockQ = jasmine.createSpyObj('mockQ', ['when', 'all', 'reject', 'defer']); mockQ.when.andCallFake(synchronousPromise); @@ -330,8 +329,8 @@ define( it("copies object and children in a bottom-up" + " fashion", function () { - expect(mockPersistenceService.createObject.calls[0].args[2].name).toEqual(childObject.model.name) - expect(mockPersistenceService.createObject.calls[1].args[2].name).toEqual(object.model.name) + expect(mockPersistenceService.createObject.calls[0].args[2].name).toEqual(childObject.model.name); + expect(mockPersistenceService.createObject.calls[1].args[2].name).toEqual(object.model.name); }); it("returns a promise", function () { @@ -355,7 +354,7 @@ define( Preserves links */ it ("correctly locates cloned objects", function() { - expect(mockPersistenceService.createObject.calls[0].args[2].location).toEqual(mockPersistenceService.createObject.calls[1].args[1]) + expect(mockPersistenceService.createObject.calls[0].args[2].location).toEqual(mockPersistenceService.createObject.calls[1].args[1]); }); }); From f2efb07d9399f548b6dd1a5c007cbeef04a1ca67 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 4 Nov 2015 21:05:55 -0800 Subject: [PATCH 43/62] Remove UUID path --- platform/entanglement/src/services/CopyService.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 3d0a730e7c..4733c902ad 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -23,7 +23,7 @@ /*global define */ define( - ["../../../commonUI/browse/lib/uuid"], + ["uuid"], function (uuid) { "use strict"; From 2bdc95eb95a6730b731653db8a373e1e25202597 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 4 Nov 2015 21:11:26 -0800 Subject: [PATCH 44/62] Restored MoveActionSpec.js and LinkActionSpec.js --- .../test/actions/LinkActionSpec.js | 174 ++++++++++++++++++ .../test/actions/MoveActionSpec.js | 174 ++++++++++++++++++ 2 files changed, 348 insertions(+) create mode 100644 platform/entanglement/test/actions/LinkActionSpec.js create mode 100644 platform/entanglement/test/actions/MoveActionSpec.js diff --git a/platform/entanglement/test/actions/LinkActionSpec.js b/platform/entanglement/test/actions/LinkActionSpec.js new file mode 100644 index 0000000000..03967a6672 --- /dev/null +++ b/platform/entanglement/test/actions/LinkActionSpec.js @@ -0,0 +1,174 @@ +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ + +/*global define,describe,beforeEach,it,jasmine,expect */ + +define( + [ + '../../src/actions/LinkAction', + '../services/MockLinkService', + '../DomainObjectFactory' + ], + function (LinkAction, MockLinkService, domainObjectFactory) { + "use strict"; + + describe("Link Action", function () { + + var linkAction, + locationService, + locationServicePromise, + linkService, + context, + selectedObject, + selectedObjectContextCapability, + currentParent, + newParent; + + beforeEach(function () { + selectedObjectContextCapability = jasmine.createSpyObj( + 'selectedObjectContextCapability', + [ + 'getParent' + ] + ); + + selectedObject = domainObjectFactory({ + name: 'selectedObject', + model: { + name: 'selectedObject' + }, + capabilities: { + context: selectedObjectContextCapability + } + }); + + currentParent = domainObjectFactory({ + name: 'currentParent' + }); + + selectedObjectContextCapability + .getParent + .andReturn(currentParent); + + newParent = domainObjectFactory({ + name: 'newParent' + }); + + locationService = jasmine.createSpyObj( + 'locationService', + [ + 'getLocationFromUser' + ] + ); + + locationServicePromise = jasmine.createSpyObj( + 'locationServicePromise', + [ + 'then' + ] + ); + + locationService + .getLocationFromUser + .andReturn(locationServicePromise); + + linkService = new MockLinkService(); + }); + + + describe("with context from context-action", function () { + beforeEach(function () { + context = { + domainObject: selectedObject + }; + + linkAction = new LinkAction( + locationService, + linkService, + context + ); + }); + + it("initializes happily", function () { + expect(linkAction).toBeDefined(); + }); + + describe("when performed it", function () { + beforeEach(function () { + linkAction.perform(); + }); + + it("prompts for location", function () { + expect(locationService.getLocationFromUser) + .toHaveBeenCalledWith( + "Link selectedObject to a new location", + "Link To", + jasmine.any(Function), + currentParent + ); + }); + + it("waits for location from user", function () { + expect(locationServicePromise.then) + .toHaveBeenCalledWith(jasmine.any(Function)); + }); + + it("links object to selected location", function () { + locationServicePromise + .then + .mostRecentCall + .args[0](newParent); + + expect(linkService.perform) + .toHaveBeenCalledWith(selectedObject, newParent); + }); + }); + }); + + describe("with context from drag-drop", function () { + beforeEach(function () { + context = { + selectedObject: selectedObject, + domainObject: newParent + }; + + linkAction = new LinkAction( + locationService, + linkService, + context + ); + }); + + it("initializes happily", function () { + expect(linkAction).toBeDefined(); + }); + + + it("performs link immediately", function () { + linkAction.perform(); + expect(linkService.perform) + .toHaveBeenCalledWith(selectedObject, newParent); + }); + }); + }); + } +); diff --git a/platform/entanglement/test/actions/MoveActionSpec.js b/platform/entanglement/test/actions/MoveActionSpec.js new file mode 100644 index 0000000000..52a7c6e301 --- /dev/null +++ b/platform/entanglement/test/actions/MoveActionSpec.js @@ -0,0 +1,174 @@ +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ + +/*global define,describe,beforeEach,it,jasmine,expect */ + +define( + [ + '../../src/actions/MoveAction', + '../services/MockMoveService', + '../DomainObjectFactory' + ], + function (MoveAction, MockMoveService, domainObjectFactory) { + "use strict"; + + describe("Move Action", function () { + + var moveAction, + locationService, + locationServicePromise, + moveService, + context, + selectedObject, + selectedObjectContextCapability, + currentParent, + newParent; + + beforeEach(function () { + selectedObjectContextCapability = jasmine.createSpyObj( + 'selectedObjectContextCapability', + [ + 'getParent' + ] + ); + + selectedObject = domainObjectFactory({ + name: 'selectedObject', + model: { + name: 'selectedObject' + }, + capabilities: { + context: selectedObjectContextCapability + } + }); + + currentParent = domainObjectFactory({ + name: 'currentParent' + }); + + selectedObjectContextCapability + .getParent + .andReturn(currentParent); + + newParent = domainObjectFactory({ + name: 'newParent' + }); + + locationService = jasmine.createSpyObj( + 'locationService', + [ + 'getLocationFromUser' + ] + ); + + locationServicePromise = jasmine.createSpyObj( + 'locationServicePromise', + [ + 'then' + ] + ); + + locationService + .getLocationFromUser + .andReturn(locationServicePromise); + + moveService = new MockMoveService(); + }); + + + describe("with context from context-action", function () { + beforeEach(function () { + context = { + domainObject: selectedObject + }; + + moveAction = new MoveAction( + locationService, + moveService, + context + ); + }); + + it("initializes happily", function () { + expect(moveAction).toBeDefined(); + }); + + describe("when performed it", function () { + beforeEach(function () { + moveAction.perform(); + }); + + it("prompts for location", function () { + expect(locationService.getLocationFromUser) + .toHaveBeenCalledWith( + "Move selectedObject to a new location", + "Move To", + jasmine.any(Function), + currentParent + ); + }); + + it("waits for location from user", function () { + expect(locationServicePromise.then) + .toHaveBeenCalledWith(jasmine.any(Function)); + }); + + it("moves object to selected location", function () { + locationServicePromise + .then + .mostRecentCall + .args[0](newParent); + + expect(moveService.perform) + .toHaveBeenCalledWith(selectedObject, newParent); + }); + }); + }); + + describe("with context from drag-drop", function () { + beforeEach(function () { + context = { + selectedObject: selectedObject, + domainObject: newParent + }; + + moveAction = new MoveAction( + locationService, + moveService, + context + ); + }); + + it("initializes happily", function () { + expect(moveAction).toBeDefined(); + }); + + + it("performs move immediately", function () { + moveAction.perform(); + expect(moveService.perform) + .toHaveBeenCalledWith(selectedObject, newParent); + }); + }); + }); + } +); From 3443780ac7112914619caf4b788b06e7059dbf81 Mon Sep 17 00:00:00 2001 From: Andrew Henry Date: Wed, 4 Nov 2015 22:09:28 -0800 Subject: [PATCH 45/62] Improved commenting --- platform/entanglement/src/actions/CopyAction.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index fd9569b1ed..ae18f2e418 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -119,8 +119,9 @@ define( self.notification.dismiss(); // Clear the progress notification } self.$log.error("Error copying objects. ", errorDetails); - //Show more general error message + //Show a minimized notification of error for posterity self.notificationService.notify(errorMessage); + //Display a blocking message self.dialogService.showBlockingMessage(errorMessage); }, From 43e920d3b63ae03431f6f2b1173139ea507f1ae8 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 10:27:50 -0800 Subject: [PATCH 46/62] Reverted to local storage --- bundles.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bundles.json b/bundles.json index fb4ca901ad..291553ba11 100644 --- a/bundles.json +++ b/bundles.json @@ -23,7 +23,7 @@ "platform/features/events", "platform/forms", "platform/identity", - "platform/persistence/elastic", + "platform/persistence/local", "platform/persistence/queue", "platform/policy", "platform/entanglement", From 5b3f780204f07f8ea36ee165dcbbcbdd52c0b195 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 11:38:41 -0800 Subject: [PATCH 47/62] [UI] Progress indicator for pending operations (e.g. duplicate) #249- Fixed serious issue with persistence --- platform/entanglement/src/services/CopyService.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index b5f274ee7b..729e009f7c 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -92,7 +92,7 @@ define( var modelClone = { id: uuid(), model: makeClone(originalObject.getModel()), - persistenceSpace: originalParent.getCapability('persistence') + persistenceSpace: originalParent.hasCapability('persistence') && originalParent.getCapability('persistence').getSpace() }; delete modelClone.model.composition; delete modelClone.model.persisted; From 21a37db15b03db3657830c226ea3271da9c4df67 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 11:50:56 -0800 Subject: [PATCH 48/62] #127 fixed failing test caused by fix for persistence spaces --- platform/entanglement/test/services/CopyServiceSpec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index af612dff92..0cba1c9399 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -223,7 +223,7 @@ define( it("uses persistence service", function () { expect(mockPersistenceService.createObject) - .toHaveBeenCalledWith(parentPersistenceCapability, jasmine.any(String), object.getModel()); + .toHaveBeenCalledWith(parentPersistenceCapability.getSpace(), jasmine.any(String), object.getModel()); expect(persistObjectPromise.then) .toHaveBeenCalledWith(jasmine.any(Function)); From aa2a835cb165c91cbeff80149266b8e2c4fc7f0f Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 16:19:01 -0800 Subject: [PATCH 49/62] Created CopyTask class --- .../entanglement/src/services/CopyService.js | 135 +------------- .../entanglement/src/services/CopyTask.js | 168 ++++++++++++++++++ 2 files changed, 170 insertions(+), 133 deletions(-) create mode 100644 platform/entanglement/src/services/CopyTask.js diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 729e009f7c..42e192911d 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -57,133 +57,6 @@ define( ); }; - /** - * Will build a graph of an object and all of its child objects in - * memory - * @param domainObject The original object to be copied - * @param parent The parent of the original object to be copied - * @returns {Promise} resolved with an array of clones of the models - * of the object tree being copied. Copying is done in a bottom-up - * fashion, so that the last member in the array is a clone of the model - * object being copied. The clones are all full composed with - * references to their own children. - */ - CopyService.prototype.buildCopyPlan = function(domainObject, parent, progress) { - var clones = [], - $q = this.$q, - self = this; - - function makeClone(object) { - return JSON.parse(JSON.stringify(object)); - } - - /** - * A recursive function that will perform a bottom-up copy of - * the object tree with originalObject at the root. Recurses to - * the farthest leaf, then works its way back up again, - * cloning objects, and composing them with their child clones - * as it goes - * @param originalObject - * @param originalParent - * @returns {*} - */ - function copy(originalObject, originalParent) { - //Make a clone of the model of the object to be copied - var modelClone = { - id: uuid(), - model: makeClone(originalObject.getModel()), - persistenceSpace: originalParent.hasCapability('persistence') && originalParent.getCapability('persistence').getSpace() - }; - delete modelClone.model.composition; - delete modelClone.model.persisted; - delete modelClone.model.modified; - return $q.when(originalObject.useCapability('composition')).then(function(composees){ - progress({phase: "preparing"}); - return (composees || []).reduce(function(promise, composee){ - //If the object is composed of other - // objects, chain a promise.. - return promise.then(function(){ - // ...to recursively copy it (and its children) - return copy(composee, originalObject).then(function(composeeClone){ - //Once copied, associate each cloned - // composee with its parent clone - if ( !(composee.hasCapability("location") && composee.getCapability("location").isLink())) { - //If the object is not a link, - // locate it within its parent - composeeClone.model.location = modelClone.id; - } - modelClone.model.composition = modelClone.model.composition || []; - return modelClone.model.composition.push(composeeClone.id); - }); - });}, $q.when(undefined) - ).then(function (){ - //Add the clone to the list of clones that will - //be returned by this function - clones.push(modelClone); - return modelClone; - }); - }); - } - - return copy(domainObject, parent).then(function(domainObjectClone){ - //If the domain object being cloned is not a link, set its - // location to the new parent - if ( !(domainObject.hasCapability("location") && domainObject.getCapability("location").isLink())) { - domainObjectClone.model.location = parent.getId(); - } - return clones; - }); - }; - - /** - * Will persist a list of {@link objectClones}. It will persist all - * simultaneously, irrespective of order in the list. This may - * result in automatic request batching by the browser. - * @private - * @param progress - * @returns {Function} a function that will perform the persistence - * with a progress callback curried into it. - */ - CopyService.prototype.persistObjects = function(progress) { - var persisted = 0, - self = this; - return function(objectClones) { - return self.$q.all(objectClones.map(function(clone, index){ - clone.model.persisted = self.now(); - return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) - .then(function(){ - return progress && progress({phase: "copying", totalObjects: objectClones.length, processed: ++persisted}); - }); - })).then(function(){ - return objectClones; - }); - }; - }; - - /** - * Will add a list of clones to the specified parent's composition - * @private - * @param parent - * @param progress - * @returns {Function} - */ - CopyService.prototype.addClonesToParent = function(parent, progress) { - var self = this; - return function(clones) { - var parentClone = clones[clones.length-1]; - if (!parent.hasCapability('composition')){ - return self.$q.reject(); - } - - return self.persistenceService - .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) - .then(function(){return parent.getCapability("composition").add(parentClone.id);}) - .then(function(){return parent.getCapability("persistence").persist();}) - .then(function(){return parentClone;}); - // Ensure the clone of the original domainObject is returned - }; - }; - /** * Creates a duplicate of the object tree starting at domainObject to * the new parent specified. @@ -195,13 +68,9 @@ define( */ CopyService.prototype.perform = function (domainObject, parent) { var $q = this.$q, - deferred = $q.defer(); + copyTask = new CopyTask(domainObject, parent, this.persistenceService, this.$q, this.now); if (this.validate(domainObject, parent)) { - this.buildCopyPlan(domainObject, parent, deferred.notify) - .then(this.persistObjects(deferred.notify)) - .then(this.addClonesToParent(parent, deferred.notify)) - .then(deferred.resolve, deferred.reject); - return deferred.promise; + return copyTask.perform(); } else { throw new Error( "Tried to copy objects without validating first." diff --git a/platform/entanglement/src/services/CopyTask.js b/platform/entanglement/src/services/CopyTask.js new file mode 100644 index 0000000000..c02293f22d --- /dev/null +++ b/platform/entanglement/src/services/CopyTask.js @@ -0,0 +1,168 @@ +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ + +/*global define */ + +define( + ["uuid"], + function (uuid) { + "use strict"; + + function CopyTask (domainObject, parent, persistenceService, $q, now){ + this.domainObject = domainObject; + this.parent = parent; + this.$q = $q; + this.deferred = undefined; + this.persistenceService = persistenceService; + this.persisted = 0; + this.now = now; + } + + /** + * Will persist a list of {@link objectClones}. It will persist all + * simultaneously, irrespective of order in the list. This may + * result in automatic request batching by the browser. + * @private + */ + CopyTask.prototype.persistObjects = function(objectClones) { + var self = this; + + return this.$q.all(objectClones.map(function(clone){ + clone.model.persisted = self.now(); + return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) + .then(function(){ + return self.deferred.notify({phase: "copying", totalObjects: objectClones.length, processed: ++persisted}); + }); + })).then(function(){ + return objectClones; + }); + }; + + /** + * Will add a list of clones to the specified parent's composition + * @private + */ + CopyTask.prototype.addClonesToParent = function(clones) { + var parentClone = clones[clones.length-1], + self = this; + + if (!this.parent.hasCapability('composition')){ + return this.deferred.reject(); + } + + return this.persistenceService + .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) + .then(function(){return self.parent.getCapability("composition").add(parentClone.id);}) + .then(function(){return self.parent.getCapability("persistence").persist();}) + .then(function(){return parentClone;}); + // Ensure the clone of the original domainObject is returned + }; + + /** + * Will build a graph of an object and all of its child objects in + * memory + * @private + * @param domainObject The original object to be copied + * @param parent The parent of the original object to be copied + * @returns {Promise} resolved with an array of clones of the models + * of the object tree being copied. Copying is done in a bottom-up + * fashion, so that the last member in the array is a clone of the model + * object being copied. The clones are all full composed with + * references to their own children. + */ + CopyTask.prototype.buildCopyPlan = function() { + var clones = [], + $q = this.$q, + self = this; + + function makeClone(object) { + return JSON.parse(JSON.stringify(object)); + } + + /** + * A recursive function that will perform a bottom-up copy of + * the object tree with originalObject at the root. Recurses to + * the farthest leaf, then works its way back up again, + * cloning objects, and composing them with their child clones + * as it goes + * @param originalObject + * @param originalParent + * @returns {*} + */ + function copy(originalObject, originalParent) { + //Make a clone of the model of the object to be copied + var modelClone = { + id: uuid(), + model: makeClone(originalObject.getModel()), + persistenceSpace: originalParent.hasCapability('persistence') && originalParent.getCapability('persistence').getSpace() + }; + + delete modelClone.model.composition; + delete modelClone.model.persisted; + delete modelClone.model.modified; + + return $q.when(originalObject.useCapability('composition')).then(function(composees){ + self.deferred.notify({phase: "preparing"}); + return (composees || []).reduce(function(promise, composee){ + //If the object is composed of other + // objects, chain a promise.. + return promise.then(function(){ + // ...to recursively copy it (and its children) + return copy(composee, originalObject).then(function(composeeClone){ + //Once copied, associate each cloned + // composee with its parent clone + composeeClone.model.location = modelClone.id; + modelClone.model.composition = modelClone.model.composition || []; + return modelClone.model.composition.push(composeeClone.id); + }); + });}, $q.when(undefined) + ).then(function (){ + //Add the clone to the list of clones that will + //be returned by this function + clones.push(modelClone); + return modelClone; + }); + }); + } + + return copy(self.domainObject, self.parent).then(function(domainObjectClone){ + domainObjectClone.model.location = parent.getId(); + return clones; + }); + }; + + CopyTask.prototype.perform = function(){ + var persistObjects = this.persistObjects.bind(this), + addClonesToParent = this.addClonesToParent.bind(this); + + this.deferred = this.$q.defer(); + + return this.buildCopyPlan() + .then(persistObjects) + .then(addClonesToParent) + .then(this.deferred.resolve) + .catch(this.deferred.reject); + } + + return CopyTask; + } +); \ No newline at end of file From e1c6c7661234942e4953d1eff346b731603d9c98 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 16:39:46 -0800 Subject: [PATCH 50/62] Refactored some CopyService functions out to CopyTask --- platform/entanglement/src/services/CopyService.js | 7 +++++-- platform/entanglement/src/services/CopyTask.js | 13 +++++++------ .../entanglement/test/services/CopyServiceSpec.js | 12 +----------- 3 files changed, 13 insertions(+), 19 deletions(-) diff --git a/platform/entanglement/src/services/CopyService.js b/platform/entanglement/src/services/CopyService.js index 42e192911d..29c6be4d10 100644 --- a/platform/entanglement/src/services/CopyService.js +++ b/platform/entanglement/src/services/CopyService.js @@ -23,8 +23,11 @@ /*global define */ define( - ["uuid"], - function (uuid) { + [ + "uuid", + "./CopyTask" + ], + function (uuid, CopyTask) { "use strict"; /** diff --git a/platform/entanglement/src/services/CopyTask.js b/platform/entanglement/src/services/CopyTask.js index c02293f22d..ca65ef18f6 100644 --- a/platform/entanglement/src/services/CopyTask.js +++ b/platform/entanglement/src/services/CopyTask.js @@ -50,7 +50,7 @@ define( clone.model.persisted = self.now(); return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ - return self.deferred.notify({phase: "copying", totalObjects: objectClones.length, processed: ++persisted}); + return self.deferred.notify({phase: "copying", totalObjects: objectClones.length, processed: ++self.persisted}); }); })).then(function(){ return objectClones; @@ -66,7 +66,7 @@ define( self = this; if (!this.parent.hasCapability('composition')){ - return this.deferred.reject(); + return this.$q.reject(); } return this.persistenceService @@ -145,7 +145,7 @@ define( } return copy(self.domainObject, self.parent).then(function(domainObjectClone){ - domainObjectClone.model.location = parent.getId(); + domainObjectClone.model.location = self.parent.getId(); return clones; }); }; @@ -156,11 +156,12 @@ define( this.deferred = this.$q.defer(); - return this.buildCopyPlan() + this.buildCopyPlan() .then(persistObjects) .then(addClonesToParent) - .then(this.deferred.resolve) - .catch(this.deferred.reject); + .then(this.deferred.resolve, this.deferred.reject); + + return this.deferred.promise; } return CopyTask; diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index 0cba1c9399..e696054a98 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -342,17 +342,7 @@ define( expect(copyFinished.mostRecentCall.args[0].model.modified).toBeUndefined(); expect(copyFinished.mostRecentCall.args[0].model.persisted).toBe(mockNow.now()); }); - - /** - Preserves links - */ - it ("preserves links", function() { - expect(copyFinished.mostRecentCall.args[0].model.location).toBe("testLocation"); - }); - - /** - Preserves links - */ + it ("correctly locates cloned objects", function() { expect(mockPersistenceService.createObject.calls[0].args[2].location).toEqual(mockPersistenceService.createObject.calls[1].args[1]); }); From 793ed7ebe608555b994f2eaeac50dfca7066172b Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 17:32:39 -0800 Subject: [PATCH 51/62] [UI] Progress indicator for pending operations - Refactoring for code clarity --- .../entanglement/src/actions/CopyAction.js | 69 ++++---- .../entanglement/src/services/CopyTask.js | 161 +++++++++++------- .../test/services/CopyServiceSpec.js | 2 +- 3 files changed, 134 insertions(+), 98 deletions(-) diff --git a/platform/entanglement/src/actions/CopyAction.js b/platform/entanglement/src/actions/CopyAction.js index ae18f2e418..cdcefeb935 100644 --- a/platform/entanglement/src/actions/CopyAction.js +++ b/platform/entanglement/src/actions/CopyAction.js @@ -94,41 +94,42 @@ define( CopyAction.prototype.perform = function() { var self = this; - return AbstractComposeAction.prototype.perform.call(this) - .then( - function success(){ - self.notification.dismiss(); - self.notificationService.info("Copying complete."); - }, - function error(errorDetails){ - var errorMessage = { - title: "Error copying objects.", - severity: "error", - hint: errorDetails.message, - minimized: true, // want the notification to be minimized initially (don't show banner) - options: [{ - label: "OK", - callback: function() { - self.dialogService.dismiss(); - } - }] - }; - - self.dialogService.dismiss(); - if (self.notification) { - self.notification.dismiss(); // Clear the progress notification + function success(){ + self.notification.dismiss(); + self.notificationService.info("Copying complete."); + } + + function error(errorDetails){ + var errorMessage = { + title: "Error copying objects.", + severity: "error", + hint: errorDetails.message, + minimized: true, // want the notification to be minimized initially (don't show banner) + options: [{ + label: "OK", + callback: function() { + self.dialogService.dismiss(); } - self.$log.error("Error copying objects. ", errorDetails); - //Show a minimized notification of error for posterity - self.notificationService.notify(errorMessage); - //Display a blocking message - self.dialogService.showBlockingMessage(errorMessage); - - }, - function notification(details){ - self.progress(details.phase, details.totalObjects, details.processed); - } - ); + }] + }; + + self.dialogService.dismiss(); + if (self.notification) { + self.notification.dismiss(); // Clear the progress notification + } + self.$log.error("Error copying objects. ", errorDetails); + //Show a minimized notification of error for posterity + self.notificationService.notify(errorMessage); + //Display a blocking message + self.dialogService.showBlockingMessage(errorMessage); + + } + function notification(details){ + self.progress(details.phase, details.totalObjects, details.processed); + } + + return AbstractComposeAction.prototype.perform.call(this) + .then(success, error, notification); }; return CopyAction; } diff --git a/platform/entanglement/src/services/CopyTask.js b/platform/entanglement/src/services/CopyTask.js index ca65ef18f6..57ef24385f 100644 --- a/platform/entanglement/src/services/CopyTask.js +++ b/platform/entanglement/src/services/CopyTask.js @@ -27,6 +27,17 @@ define( function (uuid) { "use strict"; + /** + * This class encapsulates the process of copying a domain object + * and all of its children. + * + * @param domainObject The object to copy + * @param parent The new location of the cloned object tree + * @param persistenceService + * @param $q + * @param now + * @constructor + */ function CopyTask (domainObject, parent, persistenceService, $q, now){ this.domainObject = domainObject; this.parent = parent; @@ -35,6 +46,25 @@ define( this.persistenceService = persistenceService; this.persisted = 0; this.now = now; + this.clones = []; + } + + function composeChild(child, parent) { + //Once copied, associate each cloned + // composee with its parent clone + child.model.location = parent.id; + parent.model.composition = parent.model.composition || []; + return parent.model.composition.push(child.id); + } + + function cloneObjectModel(objectModel) { + var clone = JSON.parse(JSON.stringify(objectModel)); + + delete clone.composition; + delete clone.persisted; + delete clone.modified; + + return clone; } /** @@ -43,26 +73,24 @@ define( * result in automatic request batching by the browser. * @private */ - CopyTask.prototype.persistObjects = function(objectClones) { + CopyTask.prototype.persistObjects = function() { var self = this; - return this.$q.all(objectClones.map(function(clone){ + return this.$q.all(this.clones.map(function(clone){ clone.model.persisted = self.now(); return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ - return self.deferred.notify({phase: "copying", totalObjects: objectClones.length, processed: ++self.persisted}); + return self.deferred.notify({phase: "copying", totalObjects: self.clones.length, processed: ++self.persisted}); }); - })).then(function(){ - return objectClones; - }); + })); }; /** * Will add a list of clones to the specified parent's composition * @private */ - CopyTask.prototype.addClonesToParent = function(clones) { - var parentClone = clones[clones.length-1], + CopyTask.prototype.addClonesToParent = function() { + var parentClone = this.clones[this.clones.length-1], self = this; if (!this.parent.hasCapability('composition')){ @@ -77,6 +105,61 @@ define( // Ensure the clone of the original domainObject is returned }; + /** + * Given an array of objects composed by a parent, clone them, then + * add them to the parent. + * @private + * @returns {*} + */ + CopyTask.prototype.copyComposees = function(composees, clonedParent, originalParent){ + var self = this; + + return (composees || []).reduce(function(promise, composee){ + //If the composee is composed of other + // objects, chain a promise.. + return promise.then(function(){ + // ...to recursively copy it (and its children) + return self.copy(composee, originalParent).then(function(composee){ + composeChild(composee, clonedParent) + }); + });}, self.$q.when(undefined) + ) + } + + /** + * A recursive function that will perform a bottom-up copy of + * the object tree with originalObject at the root. Recurses to + * the farthest leaf, then works its way back up again, + * cloning objects, and composing them with their child clones + * as it goes + * @private + * @param originalObject + * @param originalParent + * @returns {*} + */ + CopyTask.prototype.copy = function(originalObject, originalParent) { + var self = this; + + //Make a clone of the model of the object to be copied + var modelClone = { + id: uuid(), + model: cloneObjectModel(originalObject.getModel()), + persistenceSpace: originalParent.hasCapability('persistence') && originalParent.getCapability('persistence').getSpace() + }; + + return this.$q.when(originalObject.useCapability('composition')).then(function(composees){ + self.deferred.notify({phase: "preparing"}); + //Duplicate the object's children, and their children, and + // so on down to the leaf nodes of the tree. + return self.copyComposees(composees, modelClone, originalObject).then(function (){ + //Add the clone to the list of clones that will + //be returned by this function + self.clones.push(modelClone); + return modelClone; + }); + }); + } + /** * Will build a graph of an object and all of its child objects in * memory @@ -90,66 +173,18 @@ define( * references to their own children. */ CopyTask.prototype.buildCopyPlan = function() { - var clones = [], - $q = this.$q, - self = this; + var self = this; - function makeClone(object) { - return JSON.parse(JSON.stringify(object)); - } - - /** - * A recursive function that will perform a bottom-up copy of - * the object tree with originalObject at the root. Recurses to - * the farthest leaf, then works its way back up again, - * cloning objects, and composing them with their child clones - * as it goes - * @param originalObject - * @param originalParent - * @returns {*} - */ - function copy(originalObject, originalParent) { - //Make a clone of the model of the object to be copied - var modelClone = { - id: uuid(), - model: makeClone(originalObject.getModel()), - persistenceSpace: originalParent.hasCapability('persistence') && originalParent.getCapability('persistence').getSpace() - }; - - delete modelClone.model.composition; - delete modelClone.model.persisted; - delete modelClone.model.modified; - - return $q.when(originalObject.useCapability('composition')).then(function(composees){ - self.deferred.notify({phase: "preparing"}); - return (composees || []).reduce(function(promise, composee){ - //If the object is composed of other - // objects, chain a promise.. - return promise.then(function(){ - // ...to recursively copy it (and its children) - return copy(composee, originalObject).then(function(composeeClone){ - //Once copied, associate each cloned - // composee with its parent clone - composeeClone.model.location = modelClone.id; - modelClone.model.composition = modelClone.model.composition || []; - return modelClone.model.composition.push(composeeClone.id); - }); - });}, $q.when(undefined) - ).then(function (){ - //Add the clone to the list of clones that will - //be returned by this function - clones.push(modelClone); - return modelClone; - }); - }); - } - - return copy(self.domainObject, self.parent).then(function(domainObjectClone){ + return this.copy(self.domainObject, self.parent).then(function(domainObjectClone){ domainObjectClone.model.location = self.parent.getId(); - return clones; }); }; + /** + * Execute the copy task with the objects provided in the constructor. + * @returns {promise} Which will resolve with a clone of the object + * once complete. + */ CopyTask.prototype.perform = function(){ var persistObjects = this.persistObjects.bind(this), addClonesToParent = this.addClonesToParent.bind(this); diff --git a/platform/entanglement/test/services/CopyServiceSpec.js b/platform/entanglement/test/services/CopyServiceSpec.js index e696054a98..391d90913c 100644 --- a/platform/entanglement/test/services/CopyServiceSpec.js +++ b/platform/entanglement/test/services/CopyServiceSpec.js @@ -342,7 +342,7 @@ define( expect(copyFinished.mostRecentCall.args[0].model.modified).toBeUndefined(); expect(copyFinished.mostRecentCall.args[0].model.persisted).toBe(mockNow.now()); }); - + it ("correctly locates cloned objects", function() { expect(mockPersistenceService.createObject.calls[0].args[2].location).toEqual(mockPersistenceService.createObject.calls[1].args[1]); }); From 2f658348a83ba5ea129e379b392e0988806850d2 Mon Sep 17 00:00:00 2001 From: Henry Date: Thu, 5 Nov 2015 17:40:22 -0800 Subject: [PATCH 52/62] Fixed JSLint --- platform/entanglement/src/services/CopyTask.js | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/platform/entanglement/src/services/CopyTask.js b/platform/entanglement/src/services/CopyTask.js index 57ef24385f..75ed96925a 100644 --- a/platform/entanglement/src/services/CopyTask.js +++ b/platform/entanglement/src/services/CopyTask.js @@ -120,11 +120,11 @@ define( return promise.then(function(){ // ...to recursively copy it (and its children) return self.copy(composee, originalParent).then(function(composee){ - composeChild(composee, clonedParent) + composeChild(composee, clonedParent); }); });}, self.$q.when(undefined) - ) - } + ); + }; /** * A recursive function that will perform a bottom-up copy of @@ -138,10 +138,8 @@ define( * @returns {*} */ CopyTask.prototype.copy = function(originalObject, originalParent) { - var self = this; - - //Make a clone of the model of the object to be copied - var modelClone = { + var self = this, + modelClone = { id: uuid(), model: cloneObjectModel(originalObject.getModel()), persistenceSpace: originalParent.hasCapability('persistence') && originalParent.getCapability('persistence').getSpace() @@ -158,7 +156,7 @@ define( return modelClone; }); }); - } + }; /** * Will build a graph of an object and all of its child objects in @@ -197,7 +195,7 @@ define( .then(this.deferred.resolve, this.deferred.reject); return this.deferred.promise; - } + }; return CopyTask; } From 31d3ec5d20f746162051fe013ff83fa44be43cb4 Mon Sep 17 00:00:00 2001 From: Henry Date: Fri, 6 Nov 2015 10:06:17 -0800 Subject: [PATCH 53/62] Removed usage of function.prototype.bind --- .../entanglement/src/services/CopyTask.js | 28 ++++++++----------- 1 file changed, 12 insertions(+), 16 deletions(-) diff --git a/platform/entanglement/src/services/CopyTask.js b/platform/entanglement/src/services/CopyTask.js index 75ed96925a..7efc426cd4 100644 --- a/platform/entanglement/src/services/CopyTask.js +++ b/platform/entanglement/src/services/CopyTask.js @@ -71,33 +71,31 @@ define( * Will persist a list of {@link objectClones}. It will persist all * simultaneously, irrespective of order in the list. This may * result in automatic request batching by the browser. - * @private */ - CopyTask.prototype.persistObjects = function() { - var self = this; + function persistObjects(self) { - return this.$q.all(this.clones.map(function(clone){ + return self.$q.all(self.clones.map(function(clone){ clone.model.persisted = self.now(); return self.persistenceService.createObject(clone.persistenceSpace, clone.id, clone.model) .then(function(){ - return self.deferred.notify({phase: "copying", totalObjects: self.clones.length, processed: ++self.persisted}); + self.deferred.notify({phase: "copying", totalObjects: self.clones.length, processed: ++self.persisted}); }); - })); + })).then(function(){ + return self; + }); }; /** * Will add a list of clones to the specified parent's composition - * @private */ - CopyTask.prototype.addClonesToParent = function() { - var parentClone = this.clones[this.clones.length-1], - self = this; + function addClonesToParent(self) { + var parentClone = self.clones[self.clones.length-1]; - if (!this.parent.hasCapability('composition')){ - return this.$q.reject(); + if (!self.parent.hasCapability('composition')){ + return self.$q.reject(); } - return this.persistenceService + return self.persistenceService .updateObject(parentClone.persistenceSpace, parentClone.id, parentClone.model) .then(function(){return self.parent.getCapability("composition").add(parentClone.id);}) .then(function(){return self.parent.getCapability("persistence").persist();}) @@ -175,6 +173,7 @@ define( return this.copy(self.domainObject, self.parent).then(function(domainObjectClone){ domainObjectClone.model.location = self.parent.getId(); + return self; }); }; @@ -184,9 +183,6 @@ define( * once complete. */ CopyTask.prototype.perform = function(){ - var persistObjects = this.persistObjects.bind(this), - addClonesToParent = this.addClonesToParent.bind(this); - this.deferred = this.$q.defer(); this.buildCopyPlan() From 148a5eb248234690eec0c00170c4c81c3cc43c18 Mon Sep 17 00:00:00 2001 From: Henry Date: Fri, 6 Nov 2015 10:14:59 -0800 Subject: [PATCH 54/62] JSLint issue --- platform/entanglement/src/services/CopyTask.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/platform/entanglement/src/services/CopyTask.js b/platform/entanglement/src/services/CopyTask.js index 7efc426cd4..f484856448 100644 --- a/platform/entanglement/src/services/CopyTask.js +++ b/platform/entanglement/src/services/CopyTask.js @@ -83,7 +83,7 @@ define( })).then(function(){ return self; }); - }; + } /** * Will add a list of clones to the specified parent's composition @@ -101,7 +101,7 @@ define( .then(function(){return self.parent.getCapability("persistence").persist();}) .then(function(){return parentClone;}); // Ensure the clone of the original domainObject is returned - }; + } /** * Given an array of objects composed by a parent, clone them, then From bdc99950c61ec033e69d7696c7993c42e31530c5 Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 13:56:07 -0800 Subject: [PATCH 55/62] [Creation] Add instantiate service ...to allow insantiating domain objects completely externally from any other domain object. Desired by code review feedback for nasa/openmctweb#255. --- platform/core/bundle.json | 5 +++ platform/core/src/services/Instantiate.js | 54 +++++++++++++++++++++++ 2 files changed, 59 insertions(+) create mode 100644 platform/core/src/services/Instantiate.js diff --git a/platform/core/bundle.json b/platform/core/bundle.json index 5f5031a737..76c94435ce 100644 --- a/platform/core/bundle.json +++ b/platform/core/bundle.json @@ -223,6 +223,11 @@ "key": "contextualize", "implementation": "services/Contextualize.js", "depends": [ "$log" ] + }, + { + "key": "instantiate", + "implementation": "services/Instantiate.js", + "depends": [ "capabilityService" ] } ], "roots": [ diff --git a/platform/core/src/services/Instantiate.js b/platform/core/src/services/Instantiate.js new file mode 100644 index 0000000000..f59916c938 --- /dev/null +++ b/platform/core/src/services/Instantiate.js @@ -0,0 +1,54 @@ +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ +/*global define,Promise*/ + +define( + ['../objects/DomainObjectImpl', 'uuid'], + function (DomainObjectImpl, uuid) { + 'use strict'; + + /** + * The `instantiate` service allows new domain object instances to be + * created. These objects are not persisted to any back-end or + * placed anywhere in the object hierarchy by default. + * + * Usage: `instantiate(model, [id])` + * + * ...returns a new instance of a domain object with the specified + * model. An identifier may be provided; if omitted, one will be + * generated instead. + * + * @constructor + * @memberof platform/core + * @param $injector Angular's `$injector` + */ + function Instantiate(capabilityService) { + return function (model, id) { + var capabilities = capabilityService.getCapabilities(model); + id = id || uuid(); + return new DomainObjectImpl(id, model, capabilities); + }; + } + + return Instantiate; + } +); From d05911678217b94e5838d5b413224f2685a98a1c Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 14:07:53 -0800 Subject: [PATCH 56/62] [Creation] Rename creation capability ...to instantiation, to distinguish from creation (which typically includes persistence.) --- .../browse/src/creation/CreationService.js | 2 +- .../test/creation/CreationServiceSpec.js | 10 +++++----- platform/core/bundle.json | 4 ++-- ...apability.js => InstantiationCapability.js} | 4 ++-- ...ySpec.js => InstantiationCapabilitySpec.js} | 18 +++++++++--------- platform/core/test/suite.json | 2 +- 6 files changed, 20 insertions(+), 20 deletions(-) rename platform/core/src/capabilities/{CreationCapability.js => InstantiationCapability.js} (96%) rename platform/core/test/capabilities/{CreationCapabilitySpec.js => InstantiationCapabilitySpec.js} (86%) diff --git a/platform/commonUI/browse/src/creation/CreationService.js b/platform/commonUI/browse/src/creation/CreationService.js index bfd8a0c403..4b7c0119c9 100644 --- a/platform/commonUI/browse/src/creation/CreationService.js +++ b/platform/commonUI/browse/src/creation/CreationService.js @@ -68,7 +68,7 @@ define( */ CreationService.prototype.createObject = function (model, parent) { var persistence = parent.getCapability("persistence"), - newObject = parent.useCapability("creation", model), + newObject = parent.useCapability("instantiation", model), newObjectPersistence = newObject.getCapability("persistence"), self = this; diff --git a/platform/commonUI/browse/test/creation/CreationServiceSpec.js b/platform/commonUI/browse/test/creation/CreationServiceSpec.js index a35bf39f97..e0704ba702 100644 --- a/platform/commonUI/browse/test/creation/CreationServiceSpec.js +++ b/platform/commonUI/browse/test/creation/CreationServiceSpec.js @@ -91,14 +91,14 @@ define( ); mockCreationCapability = jasmine.createSpyObj( "creation", - ["create", "invoke"] + ["instantiate", "invoke"] ); mockCapabilities = { mutation: mockMutationCapability, persistence: mockPersistenceCapability, composition: mockCompositionCapability, context: mockContextCapability, - creation: mockCreationCapability + instantiation: mockCreationCapability }; mockNewPersistenceCapability = jasmine.createSpyObj( "new-persistence", @@ -130,9 +130,9 @@ define( mockPromise([mockNewObject]) ); mockCompositionCapability.add.andReturn(mockPromise(true)); - mockCreationCapability.create.andReturn(mockNewObject); + mockCreationCapability.instantiate.andReturn(mockNewObject); mockCreationCapability.invoke.andCallFake(function (model) { - return mockCreationCapability.create(model); + return mockCreationCapability.instantiate(model); }); creationService = new CreationService( @@ -144,7 +144,7 @@ define( it("allows new objects to be created", function () { var model = { someKey: "some value" }; creationService.createObject(model, mockParentObject); - expect(mockCreationCapability.create) + expect(mockCreationCapability.instantiate) .toHaveBeenCalledWith(model); }); diff --git a/platform/core/bundle.json b/platform/core/bundle.json index 76c94435ce..558e8292a5 100644 --- a/platform/core/bundle.json +++ b/platform/core/bundle.json @@ -200,8 +200,8 @@ "depends": [ "$q" ] }, { - "key": "creation", - "implementation": "capabilities/CreationCapability.js", + "key": "instantiation", + "implementation": "capabilities/InstantiationCapability.js", "depends": [ "$injector" ] } ], diff --git a/platform/core/src/capabilities/CreationCapability.js b/platform/core/src/capabilities/InstantiationCapability.js similarity index 96% rename from platform/core/src/capabilities/CreationCapability.js rename to platform/core/src/capabilities/InstantiationCapability.js index 334cb17d9e..1d1e38ce8a 100644 --- a/platform/core/src/capabilities/CreationCapability.js +++ b/platform/core/src/capabilities/InstantiationCapability.js @@ -61,7 +61,7 @@ define( * * @returns {DomainObject} the new domain object */ - CreationCapability.prototype.create = function (model) { + CreationCapability.prototype.instantiate = function (model) { var id = uuid(), capabilities = this.getCapabilities(model); return new DomainObjectImpl(id, model, capabilities); @@ -72,7 +72,7 @@ define( * @see {platform/core.CreationCapability#create} */ CreationCapability.prototype.invoke = - CreationCapability.prototype.create; + CreationCapability.prototype.instantiate; return CreationCapability; } diff --git a/platform/core/test/capabilities/CreationCapabilitySpec.js b/platform/core/test/capabilities/InstantiationCapabilitySpec.js similarity index 86% rename from platform/core/test/capabilities/CreationCapabilitySpec.js rename to platform/core/test/capabilities/InstantiationCapabilitySpec.js index bfc847fcc7..90b0108721 100644 --- a/platform/core/test/capabilities/CreationCapabilitySpec.js +++ b/platform/core/test/capabilities/InstantiationCapabilitySpec.js @@ -25,14 +25,14 @@ * ContextCapability. Created by vwoeltje on 11/6/14. */ define( - ["../../src/capabilities/CreationCapability"], - function (CreationCapability) { + ["../../src/capabilities/InstantiationCapability"], + function (InstantiationCapability) { 'use strict'; - describe("The 'creation' capability", function () { + describe("The 'instantiation' capability", function () { var mockInjector, mockCapabilityService, - creation; + instantiation; beforeEach(function () { mockInjector = jasmine.createSpyObj("$injector", ["get"]); @@ -46,12 +46,12 @@ define( mockCapabilityService : undefined; }); - creation = new CreationCapability(mockInjector); + instantiation = new InstantiationCapability(mockInjector); }); - it("aliases 'create' as 'invoke'", function () { - expect(creation.invoke).toBe(creation.create); + it("aliases 'instantiate' as 'invoke'", function () { + expect(instantiation.invoke).toBe(instantiation.instantiate); }); describe("when creating an object", function () { @@ -71,7 +71,7 @@ define( testModel = { someKey: "some value" }; - domainObject = creation.create(testModel); + domainObject = instantiation.instantiate(testModel); }); it("loads capabilities from the capability service", function () { @@ -92,7 +92,7 @@ define( it("provides unique identifiers", function () { expect(domainObject.getId()).toEqual(jasmine.any(String)); - expect(creation.create(testModel).getId()) + expect(instantiation.instantiate(testModel).getId()) .not.toEqual(domainObject.getId()); }); }); diff --git a/platform/core/test/suite.json b/platform/core/test/suite.json index 3b0613629d..390962f22a 100644 --- a/platform/core/test/suite.json +++ b/platform/core/test/suite.json @@ -8,8 +8,8 @@ "capabilities/ContextCapability", "capabilities/ContextualDomainObject", "capabilities/CoreCapabilityProvider", - "capabilities/CreationCapability", "capabilities/DelegationCapability", + "capabilities/InstantiationCapability", "capabilities/MetadataCapability", "capabilities/MutationCapability", "capabilities/PersistenceCapability", From 81b136eab1f2ea933b30a4037ddc47a0f41b5f50 Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 14:15:22 -0800 Subject: [PATCH 57/62] [Creation] Use instantiate service ...from instantiation capability. --- .../capabilities/InstantiationCapability.js | 19 +-------- .../InstantiationCapabilitySpec.js | 40 ++++++++++++------- 2 files changed, 28 insertions(+), 31 deletions(-) diff --git a/platform/core/src/capabilities/InstantiationCapability.js b/platform/core/src/capabilities/InstantiationCapability.js index 1d1e38ce8a..2f709b5b85 100644 --- a/platform/core/src/capabilities/InstantiationCapability.js +++ b/platform/core/src/capabilities/InstantiationCapability.js @@ -38,20 +38,6 @@ define( this.$injector = $injector; } - /** - * Alias of `capabilityService.getCapabilities`; handles lazy loading - * of `capabilityService`, since it cannot be declared as a - * dependency directly without creating a cycle. - * @private - */ - CreationCapability.prototype.getCapabilities = function (model) { - if (!this.capabilityService) { - this.capabilityService = - this.$injector.get('capabilityService'); - } - return this.capabilityService.getCapabilities(model); - }; - /** * Instantiate a new domain object with the provided model. * @@ -62,9 +48,8 @@ define( * @returns {DomainObject} the new domain object */ CreationCapability.prototype.instantiate = function (model) { - var id = uuid(), - capabilities = this.getCapabilities(model); - return new DomainObjectImpl(id, model, capabilities); + this.instantiate = this.$injector.get("instantiate"); + return this.instantiate(model); }; /** diff --git a/platform/core/test/capabilities/InstantiationCapabilitySpec.js b/platform/core/test/capabilities/InstantiationCapabilitySpec.js index 90b0108721..3fac74d410 100644 --- a/platform/core/test/capabilities/InstantiationCapabilitySpec.js +++ b/platform/core/test/capabilities/InstantiationCapabilitySpec.js @@ -19,7 +19,7 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/ +/*global define,Promise,describe,it,xdescribe,expect,beforeEach,waitsFor,jasmine*/ /** * ContextCapability. Created by vwoeltje on 11/6/14. @@ -31,19 +31,16 @@ define( describe("The 'instantiation' capability", function () { var mockInjector, - mockCapabilityService, + mockInstantiate, instantiation; beforeEach(function () { mockInjector = jasmine.createSpyObj("$injector", ["get"]); - mockCapabilityService = jasmine.createSpyObj( - "capabilityService", - [ "getCapabilities" ] - ); + mockInstantiate = jasmine.createSpy("instantiate"); mockInjector.get.andCallFake(function (key) { - return key === 'capabilityService' ? - mockCapabilityService : undefined; + return key === 'instantiate' ? + mockInstantiate : undefined; }); instantiation = new InstantiationCapability(mockInjector); @@ -54,7 +51,22 @@ define( expect(instantiation.invoke).toBe(instantiation.instantiate); }); - describe("when creating an object", function () { + it("uses the instantiate service to create domain objects", function () { + var mockDomainObject = jasmine.createSpyObj('domainObject', [ + 'getId', + 'getModel', + 'getCapability', + 'useCapability', + 'hasCapability' + ]), testModel = { someKey: "some value" }; + mockInstantiate.andReturn(mockDomainObject); + expect(instantiation.instantiate(testModel)) + .toBe(mockDomainObject); + expect(mockInstantiate).toHaveBeenCalledWith(testModel); + }); + + // TODO: Move to instantiate service + xdescribe("when creating an object", function () { var mockCapabilityConstructor, mockCapabilityInstance, mockCapabilities, @@ -64,9 +76,9 @@ define( beforeEach(function () { mockCapabilityConstructor = jasmine.createSpy('capability'); mockCapabilityInstance = {}; - mockCapabilityService.getCapabilities.andReturn({ - something: mockCapabilityConstructor - }); +// mockCapabilityService.getCapabilities.andReturn({ +// something: mockCapabilityConstructor +// }); mockCapabilityConstructor.andReturn(mockCapabilityInstance); testModel = { someKey: "some value" }; @@ -75,8 +87,8 @@ define( }); it("loads capabilities from the capability service", function () { - expect(mockCapabilityService.getCapabilities) - .toHaveBeenCalledWith(testModel); +// expect(mockCapabilityService.getCapabilities) +// .toHaveBeenCalledWith(testModel); }); it("exposes loaded capabilities from the created object", function () { From cca1928b82405d2f389b62e4dc7e9892bb3efeaf Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 14:23:34 -0800 Subject: [PATCH 58/62] [Creation] Use instantiate from objectService Use instantiate from DomainObjectProvider, to remove redundant code around DomainObject instantiation. --- platform/core/bundle.json | 2 +- .../core/src/objects/DomainObjectProvider.js | 48 +++++-------------- .../test/objects/DomainObjectProviderSpec.js | 30 ++++++------ 3 files changed, 27 insertions(+), 53 deletions(-) diff --git a/platform/core/bundle.json b/platform/core/bundle.json index 558e8292a5..89c059eee8 100644 --- a/platform/core/bundle.json +++ b/platform/core/bundle.json @@ -38,7 +38,7 @@ "provides": "objectService", "type": "provider", "implementation": "objects/DomainObjectProvider.js", - "depends": [ "modelService", "capabilityService", "$q" ] + "depends": [ "modelService", "instantiate" ] }, { "provides": "capabilityService", diff --git a/platform/core/src/objects/DomainObjectProvider.js b/platform/core/src/objects/DomainObjectProvider.js index c846cbf665..800d31f5d5 100644 --- a/platform/core/src/objects/DomainObjectProvider.js +++ b/platform/core/src/objects/DomainObjectProvider.js @@ -27,8 +27,8 @@ * @namespace platform/core */ define( - ["./DomainObjectImpl"], - function (DomainObjectImpl) { + [], + function () { "use strict"; /** @@ -57,62 +57,36 @@ define( * * @param {ModelService} modelService the service which shall * provide models (persistent state) for domain objects - * @param {CapabilityService} capabilityService the service - * which provides capabilities (dynamic behavior) - * for domain objects. + * @param {Function} instantiate a service to instantiate new + * domain object instances * @param $q Angular's $q, for promise consolidation * @memberof platform/core * @constructor */ - function DomainObjectProvider(modelService, capabilityService, $q) { + function DomainObjectProvider(modelService, instantiate, $q) { this.modelService = modelService; - this.capabilityService = capabilityService; - this.$q = $q; + this.instantiate = instantiate; } DomainObjectProvider.prototype.getObjects = function getObjects(ids) { var modelService = this.modelService, - capabilityService = this.capabilityService, - $q = this.$q; - - // Given a models object (containing key-value id-model pairs) - // create a function that will look up from the capability - // service based on id; for handy mapping below. - function capabilityResolver(models) { - return function (id) { - var model = models[id]; - return model ? - capabilityService.getCapabilities(model) : - undefined; - }; - } + instantiate = this.instantiate; // Assemble the results from the model service and the // capability service into one value, suitable to return - // from this service. Note that ids are matched to capabilities - // by index. - function assembleResult(ids, models, capabilities) { + // from this service. + function assembleResult(models) { var result = {}; ids.forEach(function (id, index) { if (models[id]) { // Create the domain object - result[id] = new DomainObjectImpl( - id, - models[id], - capabilities[index] - ); + result[id] = instantiate(models[id], id); } }); return result; } - return modelService.getModels(ids).then(function (models) { - return $q.all( - ids.map(capabilityResolver(models)) - ).then(function (capabilities) { - return assembleResult(ids, models, capabilities); - }); - }); + return modelService.getModels(ids).then(assembleResult); }; return DomainObjectProvider; diff --git a/platform/core/test/objects/DomainObjectProviderSpec.js b/platform/core/test/objects/DomainObjectProviderSpec.js index 3aca982260..438c91f103 100644 --- a/platform/core/test/objects/DomainObjectProviderSpec.js +++ b/platform/core/test/objects/DomainObjectProviderSpec.js @@ -25,14 +25,16 @@ * DomainObjectProviderSpec. Created by vwoeltje on 11/6/14. */ define( - ["../../src/objects/DomainObjectProvider"], - function (DomainObjectProvider) { + [ + "../../src/objects/DomainObjectProvider", + "../../src/objects/DomainObjectImpl" + ], + function (DomainObjectProvider, DomainObjectImpl) { "use strict"; describe("The domain object provider", function () { var mockModelService, - mockCapabilityService, - mockQ, + mockInstantiate, provider; function mockPromise(value) { @@ -57,18 +59,15 @@ define( "modelService", [ "getModels" ] ); - mockCapabilityService = jasmine.createSpyObj( - "capabilityService", - [ "getCapabilities" ] - ); - mockQ = { - when: mockPromise, - all: mockAll - }; + mockInstantiate = jasmine.createSpy("instantiate"); + + mockInstantiate.andCallFake(function (model, id) { + return new DomainObjectImpl(id, model, {}); + }); + provider = new DomainObjectProvider( mockModelService, - mockCapabilityService, - mockQ + mockInstantiate ); }); @@ -86,10 +85,11 @@ define( result; mockModelService.getModels.andReturn(mockPromise({ a: model })); result = provider.getObjects(ids).testValue; + expect(mockInstantiate).toHaveBeenCalledWith(model, 'a'); expect(result.a.getId()).toEqual("a"); expect(result.a.getModel()).toEqual(model); }); }); } -); \ No newline at end of file +); From 62e2114349a2c5ea9ed073f2b0dfc5f34591033f Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 14:30:39 -0800 Subject: [PATCH 59/62] [Creation] Move test cases Move test cases from instantiation capability over to instantiate service. --- .../InstantiationCapabilitySpec.js | 44 ---------- .../core/test/services/InstantiateSpec.js | 84 +++++++++++++++++++ platform/core/test/suite.json | 1 + 3 files changed, 85 insertions(+), 44 deletions(-) create mode 100644 platform/core/test/services/InstantiateSpec.js diff --git a/platform/core/test/capabilities/InstantiationCapabilitySpec.js b/platform/core/test/capabilities/InstantiationCapabilitySpec.js index 3fac74d410..6712882bcc 100644 --- a/platform/core/test/capabilities/InstantiationCapabilitySpec.js +++ b/platform/core/test/capabilities/InstantiationCapabilitySpec.js @@ -65,50 +65,6 @@ define( expect(mockInstantiate).toHaveBeenCalledWith(testModel); }); - // TODO: Move to instantiate service - xdescribe("when creating an object", function () { - var mockCapabilityConstructor, - mockCapabilityInstance, - mockCapabilities, - testModel, - domainObject; - - beforeEach(function () { - mockCapabilityConstructor = jasmine.createSpy('capability'); - mockCapabilityInstance = {}; -// mockCapabilityService.getCapabilities.andReturn({ -// something: mockCapabilityConstructor -// }); - mockCapabilityConstructor.andReturn(mockCapabilityInstance); - - testModel = { someKey: "some value" }; - - domainObject = instantiation.instantiate(testModel); - }); - - it("loads capabilities from the capability service", function () { -// expect(mockCapabilityService.getCapabilities) -// .toHaveBeenCalledWith(testModel); - }); - - it("exposes loaded capabilities from the created object", function () { - expect(domainObject.getCapability('something')) - .toBe(mockCapabilityInstance); - expect(mockCapabilityConstructor) - .toHaveBeenCalledWith(domainObject); - }); - - it("exposes the provided model", function () { - expect(domainObject.getModel()).toEqual(testModel); - }); - - it("provides unique identifiers", function () { - expect(domainObject.getId()).toEqual(jasmine.any(String)); - expect(instantiation.instantiate(testModel).getId()) - .not.toEqual(domainObject.getId()); - }); - }); - }); } ); diff --git a/platform/core/test/services/InstantiateSpec.js b/platform/core/test/services/InstantiateSpec.js new file mode 100644 index 0000000000..4778e68722 --- /dev/null +++ b/platform/core/test/services/InstantiateSpec.js @@ -0,0 +1,84 @@ +/***************************************************************************** + * Open MCT Web, Copyright (c) 2014-2015, United States Government + * as represented by the Administrator of the National Aeronautics and Space + * Administration. All rights reserved. + * + * Open MCT Web is licensed under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * Open MCT Web includes source code licensed under additional open source + * licenses. See the Open Source Licenses file (LICENSES.md) included with + * this source code distribution or the Licensing information page available + * at runtime from the About dialog for additional information. + *****************************************************************************/ +/*global define,Promise,describe,it,xdescribe,expect,beforeEach,waitsFor,jasmine*/ + +/** + * ContextCapability. Created by vwoeltje on 11/6/14. + */ +define( + ["../../src/services/Instantiate"], + function (Instantiate) { + 'use strict'; + + describe("The 'instantiate' service", function () { + + var mockCapabilityService, + mockCapabilityConstructor, + mockCapabilityInstance, + mockCapabilities, + testModel, + instantiate, + domainObject; + + beforeEach(function () { + mockCapabilityService = jasmine.createSpyObj( + 'capabilityService', + ['getCapabilities'] + ); + mockCapabilityConstructor = jasmine.createSpy('capability'); + mockCapabilityInstance = {}; + mockCapabilityService.getCapabilities.andReturn({ + something: mockCapabilityConstructor + }); + mockCapabilityConstructor.andReturn(mockCapabilityInstance); + + testModel = { someKey: "some value" }; + + instantiate = new Instantiate(mockCapabilityService); + domainObject = instantiate(testModel); + }); + + it("loads capabilities from the capability service", function () { + expect(mockCapabilityService.getCapabilities) + .toHaveBeenCalledWith(testModel); + }); + + it("exposes loaded capabilities from the created object", function () { + expect(domainObject.getCapability('something')) + .toBe(mockCapabilityInstance); + expect(mockCapabilityConstructor) + .toHaveBeenCalledWith(domainObject); + }); + + it("exposes the provided model", function () { + expect(domainObject.getModel()).toEqual(testModel); + }); + + it("provides unique identifiers", function () { + expect(domainObject.getId()).toEqual(jasmine.any(String)); + expect(instantiate(testModel).getId()) + .not.toEqual(domainObject.getId()); + }); + }); + + } +); diff --git a/platform/core/test/suite.json b/platform/core/test/suite.json index 390962f22a..d6afc373ef 100644 --- a/platform/core/test/suite.json +++ b/platform/core/test/suite.json @@ -26,6 +26,7 @@ "objects/DomainObjectProvider", "services/Contextualize", + "services/Instantiate", "services/Now", "services/Throttle", "services/Topic", From c184a9ce7c208edd2e6e788b19e198a23caecfdf Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 14:31:26 -0800 Subject: [PATCH 60/62] [Creation] Complete rename of capability --- .../core/src/capabilities/InstantiationCapability.js | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/platform/core/src/capabilities/InstantiationCapability.js b/platform/core/src/capabilities/InstantiationCapability.js index 2f709b5b85..64aa271240 100644 --- a/platform/core/src/capabilities/InstantiationCapability.js +++ b/platform/core/src/capabilities/InstantiationCapability.js @@ -27,14 +27,14 @@ define( 'use strict'; /** - * Implements the `creation` capability. This allows new domain + * Implements the `instantiation` capability. This allows new domain * objects to be instantiated. * * @constructor * @memberof platform/core * @param $injector Angular's `$injector` */ - function CreationCapability($injector) { + function InstantiationCapability($injector) { this.$injector = $injector; } @@ -47,7 +47,7 @@ define( * * @returns {DomainObject} the new domain object */ - CreationCapability.prototype.instantiate = function (model) { + InstantiationCapability.prototype.instantiate = function (model) { this.instantiate = this.$injector.get("instantiate"); return this.instantiate(model); }; @@ -56,9 +56,9 @@ define( * Alias of `create`. * @see {platform/core.CreationCapability#create} */ - CreationCapability.prototype.invoke = - CreationCapability.prototype.instantiate; + InstantiationCapability.prototype.invoke = + InstantiationCapability.prototype.instantiate; - return CreationCapability; + return InstantiationCapability; } ); From cb432051dce9f3f788c08460637fead10943d42e Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 14:32:47 -0800 Subject: [PATCH 61/62] [Creation] Tweak lazy initialization approach --- platform/core/src/capabilities/InstantiationCapability.js | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/platform/core/src/capabilities/InstantiationCapability.js b/platform/core/src/capabilities/InstantiationCapability.js index 64aa271240..52384e993e 100644 --- a/platform/core/src/capabilities/InstantiationCapability.js +++ b/platform/core/src/capabilities/InstantiationCapability.js @@ -48,8 +48,11 @@ define( * @returns {DomainObject} the new domain object */ InstantiationCapability.prototype.instantiate = function (model) { - this.instantiate = this.$injector.get("instantiate"); - return this.instantiate(model); + // Lazily initialize; instantiate depends on capabilityService, + // which depends on all capabilities, including this one. + this.instantiateFn = this.instantiateFn || + this.$injector.get("instantiate"); + return this.instantiateFn(model); }; /** From 64607b8e56d0e1444a3c5ec0164b62e0946357be Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 6 Nov 2015 15:47:33 -0800 Subject: [PATCH 62/62] [Creation] Remove errant comments --- platform/core/test/capabilities/InstantiationCapabilitySpec.js | 3 --- platform/core/test/services/InstantiateSpec.js | 3 --- 2 files changed, 6 deletions(-) diff --git a/platform/core/test/capabilities/InstantiationCapabilitySpec.js b/platform/core/test/capabilities/InstantiationCapabilitySpec.js index 6712882bcc..0798a68f0c 100644 --- a/platform/core/test/capabilities/InstantiationCapabilitySpec.js +++ b/platform/core/test/capabilities/InstantiationCapabilitySpec.js @@ -21,9 +21,6 @@ *****************************************************************************/ /*global define,Promise,describe,it,xdescribe,expect,beforeEach,waitsFor,jasmine*/ -/** - * ContextCapability. Created by vwoeltje on 11/6/14. - */ define( ["../../src/capabilities/InstantiationCapability"], function (InstantiationCapability) { diff --git a/platform/core/test/services/InstantiateSpec.js b/platform/core/test/services/InstantiateSpec.js index 4778e68722..31a5731dd3 100644 --- a/platform/core/test/services/InstantiateSpec.js +++ b/platform/core/test/services/InstantiateSpec.js @@ -21,9 +21,6 @@ *****************************************************************************/ /*global define,Promise,describe,it,xdescribe,expect,beforeEach,waitsFor,jasmine*/ -/** - * ContextCapability. Created by vwoeltje on 11/6/14. - */ define( ["../../src/services/Instantiate"], function (Instantiate) {