mirror of
https://github.com/nasa/openmct.git
synced 2025-06-15 13:48:12 +00:00
Merged from master
This commit is contained in:
@ -16,14 +16,16 @@
|
|||||||
"platform/execution",
|
"platform/execution",
|
||||||
"platform/telemetry",
|
"platform/telemetry",
|
||||||
"platform/features/clock",
|
"platform/features/clock",
|
||||||
|
"platform/features/events",
|
||||||
"platform/features/imagery",
|
"platform/features/imagery",
|
||||||
"platform/features/layout",
|
"platform/features/layout",
|
||||||
"platform/features/pages",
|
"platform/features/pages",
|
||||||
"platform/features/plot",
|
"platform/features/plot",
|
||||||
"platform/features/scrolling",
|
"platform/features/scrolling",
|
||||||
"platform/features/events",
|
"platform/features/timeline",
|
||||||
"platform/forms",
|
"platform/forms",
|
||||||
"platform/identity",
|
"platform/identity",
|
||||||
|
"platform/persistence/aggregator",
|
||||||
"platform/persistence/local",
|
"platform/persistence/local",
|
||||||
"platform/persistence/queue",
|
"platform/persistence/queue",
|
||||||
"platform/policy",
|
"platform/policy",
|
||||||
|
@ -677,6 +677,40 @@ If the provided capability has no invoke method, the return value here functions
|
|||||||
as `getCapability` including returning `undefined` if the capability is not
|
as `getCapability` including returning `undefined` if the capability is not
|
||||||
exposed.
|
exposed.
|
||||||
|
|
||||||
|
### Identifier Syntax
|
||||||
|
|
||||||
|
For most purposes, a domain object identifier can be treated as a purely
|
||||||
|
symbolic string; these are typically generated by Open MCT Web and plug-ins
|
||||||
|
should rarely be concerned with its internal structure.
|
||||||
|
|
||||||
|
A domain object identifier has one or two parts, separated by a colon.
|
||||||
|
|
||||||
|
* If two parts are present, the part before the colon refers to the space
|
||||||
|
in which the domain object resides. This may be a persistence space or
|
||||||
|
a purely symbolic space recognized by a specific model provider. The
|
||||||
|
part after the colon is the key to use when looking up the domain object
|
||||||
|
model within that space.
|
||||||
|
* If only one part is present, the domain object has no space specified,
|
||||||
|
and may presume to reside in the application-configured default space
|
||||||
|
defined by the `PERSISTENCE_SPACE` constant.
|
||||||
|
* Both the key and the space identifier may consist of any combination
|
||||||
|
of alphanumeric characters, underscores, dashes, and periods.
|
||||||
|
|
||||||
|
Some examples:
|
||||||
|
|
||||||
|
* A domain object with the identifier `foo:xyz` would have its model
|
||||||
|
loaded using key `xyz` from persistence space `foo`.
|
||||||
|
* A domain object with the identifier `bar` would have its model loaded
|
||||||
|
using key `bar` from the space identified by the `PERSISTENCE_SPACE`
|
||||||
|
constant.
|
||||||
|
|
||||||
|
```bnf
|
||||||
|
<identifier> ::= <space> ":" <key> | <key>
|
||||||
|
<space> ::= <id char>+
|
||||||
|
<key> ::= <id char>+
|
||||||
|
<id char> ::= <letter> | <digit> | "-" | "." | "_"
|
||||||
|
```
|
||||||
|
|
||||||
## Domain Object Actions
|
## Domain Object Actions
|
||||||
|
|
||||||
An `Action` is behavior that can be performed upon/using a `DomainObject`. An
|
An `Action` is behavior that can be performed upon/using a `DomainObject`. An
|
||||||
@ -1254,6 +1288,22 @@ object, or the current view proxy.
|
|||||||
* `all()`: Get an array of all objects in the selection state. Will include
|
* `all()`: Get an array of all objects in the selection state. Will include
|
||||||
either or both of the view proxy and selected object.
|
either or both of the view proxy and selected object.
|
||||||
|
|
||||||
|
## Workers Category
|
||||||
|
|
||||||
|
The `workers` extension category allows scripts to be run as web workers
|
||||||
|
using the `workerService`.
|
||||||
|
|
||||||
|
An extension of this category has no implementation. The following properties
|
||||||
|
are supported:
|
||||||
|
|
||||||
|
* `key`: A symbolic string used to identify this worker.
|
||||||
|
* `workerUrl`: The path, relative to this bundle's `src` folder, where
|
||||||
|
this worker's source code resides.
|
||||||
|
* `shared`: Optional; a boolean flag which, if true, indicates that this
|
||||||
|
worker should be instantiated as a
|
||||||
|
[`SharedWorker`](https://developer.mozilla.org/en-US/docs/Web/API/SharedWorker/SharedWorker).
|
||||||
|
Default value is `false`.
|
||||||
|
|
||||||
# Directives
|
# Directives
|
||||||
|
|
||||||
Open MCT Web defines several Angular directives that are intended for use both
|
Open MCT Web defines several Angular directives that are intended for use both
|
||||||
@ -1849,6 +1899,14 @@ the TelemetrySeries itself, in that order.
|
|||||||
* `getSeries(domainObject)`: Get the latest `TelemetrySeries` (as resulted from
|
* `getSeries(domainObject)`: Get the latest `TelemetrySeries` (as resulted from
|
||||||
a previous `request(...)` call) available for this domain object.
|
a previous `request(...)` call) available for this domain object.
|
||||||
|
|
||||||
|
### Worker Service
|
||||||
|
|
||||||
|
The `workerService` may be used to run web workers defined via the
|
||||||
|
`workers` extension category. It has the following method:
|
||||||
|
|
||||||
|
* `run(key)`: Run the worker identified by the provided `key`. Returns
|
||||||
|
a `Worker` (or `SharedWorker`, if the specified worker is defined
|
||||||
|
as a shared worker); if the `key` is unknown, returns `undefined`.
|
||||||
|
|
||||||
# Models
|
# Models
|
||||||
Domain object models in Open MCT Web are JavaScript objects describing the
|
Domain object models in Open MCT Web are JavaScript objects describing the
|
||||||
@ -2353,6 +2411,11 @@ default paths to reach external services are all correct.
|
|||||||
|
|
||||||
### Configuration Constants
|
### Configuration Constants
|
||||||
|
|
||||||
|
The following constants have global significance:
|
||||||
|
* `PERSISTENCE_SPACE`: The space in which domain objects should be persisted
|
||||||
|
(or read from) when not otherwise specified. Typically this will not need
|
||||||
|
to be overridden by other bundles, but persistence adapters may wish to
|
||||||
|
consume this constant in order to provide persistence for that space.
|
||||||
|
|
||||||
The following configuration constants are recognized by Open MCT Web bundles:
|
The following configuration constants are recognized by Open MCT Web bundles:
|
||||||
* Common UI elements - `platform/commonUI/general`
|
* Common UI elements - `platform/commonUI/general`
|
||||||
|
2
example/scratchpad/README.md
Normal file
2
example/scratchpad/README.md
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
Example of using multiple persistence stores by exposing a root
|
||||||
|
object with a different space prefix.
|
23
example/scratchpad/bundle.json
Normal file
23
example/scratchpad/bundle.json
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
{
|
||||||
|
"extensions": {
|
||||||
|
"roots": [
|
||||||
|
{
|
||||||
|
"id": "scratch:root",
|
||||||
|
"model": {
|
||||||
|
"type": "folder",
|
||||||
|
"composition": [],
|
||||||
|
"name": "Scratchpad"
|
||||||
|
},
|
||||||
|
"priority": "preferred"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"components": [
|
||||||
|
{
|
||||||
|
"provides": "persistenceService",
|
||||||
|
"type": "provider",
|
||||||
|
"implementation": "ScratchPersistenceProvider.js",
|
||||||
|
"depends": [ "$q" ]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
79
example/scratchpad/src/ScratchPersistenceProvider.js
Normal file
79
example/scratchpad/src/ScratchPersistenceProvider.js
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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,window*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The ScratchPersistenceProvider keeps JSON documents in memory
|
||||||
|
* and provides a persistence interface, but changes are lost on reload.
|
||||||
|
* @memberof example/scratchpad
|
||||||
|
* @constructor
|
||||||
|
* @implements {PersistenceService}
|
||||||
|
* @param q Angular's $q, for promises
|
||||||
|
*/
|
||||||
|
function ScratchPersistenceProvider($q) {
|
||||||
|
this.$q = $q;
|
||||||
|
this.table = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
ScratchPersistenceProvider.prototype.listSpaces = function () {
|
||||||
|
return this.$q.when(['scratch']);
|
||||||
|
};
|
||||||
|
|
||||||
|
ScratchPersistenceProvider.prototype.listObjects = function (space) {
|
||||||
|
return this.$q.when(
|
||||||
|
space === 'scratch' ? Object.keys(this.table) : []
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
ScratchPersistenceProvider.prototype.createObject = function (space, key, value) {
|
||||||
|
if (space === 'scratch') {
|
||||||
|
this.table[key] = JSON.stringify(value);
|
||||||
|
}
|
||||||
|
return this.$q.when(space === 'scratch');
|
||||||
|
};
|
||||||
|
|
||||||
|
ScratchPersistenceProvider.prototype.readObject = function (space, key) {
|
||||||
|
return this.$q.when(
|
||||||
|
(space === 'scratch' && this.table[key]) ?
|
||||||
|
JSON.parse(this.table[key]) : undefined
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
ScratchPersistenceProvider.prototype.deleteObject = function (space, key, value) {
|
||||||
|
if (space === 'scratch') {
|
||||||
|
delete this.table[key];
|
||||||
|
}
|
||||||
|
return this.$q.when(space === 'scratch');
|
||||||
|
};
|
||||||
|
|
||||||
|
ScratchPersistenceProvider.prototype.updateObject =
|
||||||
|
ScratchPersistenceProvider.prototype.createObject;
|
||||||
|
|
||||||
|
return ScratchPersistenceProvider;
|
||||||
|
}
|
||||||
|
);
|
@ -108,10 +108,7 @@ $pad: $interiorMargin * $baseRatio;
|
|||||||
|
|
||||||
.s-icon-btn {
|
.s-icon-btn {
|
||||||
@extend .ui-symbol;
|
@extend .ui-symbol;
|
||||||
color: $colorBtnIcon;
|
// Color and styling additionally in _controls.scss
|
||||||
&:hover {
|
|
||||||
color: lighten($colorBtnIcon, $ltGamma);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.mini-tab {
|
.mini-tab {
|
||||||
|
@ -187,7 +187,8 @@ label.checkbox.custom {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.context-available {
|
.context-available,
|
||||||
|
.s-icon-btn {
|
||||||
$c: $colorKey;
|
$c: $colorKey;
|
||||||
color: $c;
|
color: $c;
|
||||||
&:hover {
|
&:hover {
|
||||||
|
@ -1,46 +1,32 @@
|
|||||||
.l-time-display {
|
.l-time-display {
|
||||||
$transTime: 200ms;
|
$transTime: 200ms;
|
||||||
// Layout
|
line-height: 140%;
|
||||||
&:hover {
|
&:hover {
|
||||||
.l-btn.control {
|
.l-btn.control {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.l-elem-wrapper {
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
.l-elem {
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.l-timer {
|
&.l-timer {
|
||||||
.l-elem.l-value {
|
.control {
|
||||||
@include trans-prop-nice(left, $transTime);
|
@include trans-prop-nice((width, opacity), $transTime);
|
||||||
position: absolute;
|
line-height: inherit;
|
||||||
left: 0;
|
margin-right: 0;
|
||||||
z-index: 1;
|
opacity: 0;
|
||||||
.ui-symbol.direction {
|
width: 0;
|
||||||
font-size: 0.8em;
|
}
|
||||||
}
|
&:hover .control {
|
||||||
}
|
margin-right: $interiorMargin;
|
||||||
&:hover .l-elem.l-value {
|
opacity: 1;
|
||||||
left: 20px;
|
width: 1em;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Look-and-feel
|
.value {
|
||||||
.l-elem {
|
color: pullForward($colorBodyFg, 50%);
|
||||||
.value.active,
|
font-weight: 400;
|
||||||
&.value.active {
|
.direction {
|
||||||
color: $colorKeyFg;
|
font-size: 0.8em;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.l-btn.control {
|
|
||||||
@include trans-prop-nice-fade($transTime);
|
|
||||||
opacity: 0;
|
|
||||||
font-size: 0.65em;
|
|
||||||
vertical-align: top;
|
|
||||||
//line-height: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
margin: 0 0 2px 0; // Needed to avoid dropshadow from being clipped by parent containers
|
margin: 0 0 2px 0; // Needed to avoid dropshadow from being clipped by parent containers
|
||||||
}
|
}
|
||||||
padding: 0 $interiorMargin;
|
padding: 0 $interiorMargin;
|
||||||
overflow: hidden;
|
|
||||||
position: relative;
|
position: relative;
|
||||||
line-height: $formInputH;
|
line-height: $formInputH;
|
||||||
select {
|
select {
|
||||||
|
@ -34,51 +34,31 @@ $mobileTreeItemH: 35px;
|
|||||||
$mobileTreeItemIndent: 20px;
|
$mobileTreeItemIndent: 20px;
|
||||||
$mobileTreeRightArrowW: 30px;
|
$mobileTreeRightArrowW: 30px;
|
||||||
|
|
||||||
/************************** WINDOW DIMENSIONS FOR RWD */
|
/************************** DEVICE WIDTHS */
|
||||||
|
// IMPORTANT! Usage assumes that ranges are mutually exclusive and have no gaps
|
||||||
$phoMaxW: 514px;
|
$phoMaxW: 514px;
|
||||||
$phoMaxH: 740px;
|
|
||||||
|
|
||||||
$tabMinW: 515px;
|
$tabMinW: 515px;
|
||||||
$tabMaxW: 799px;
|
$tabMaxW: 1280px;
|
||||||
|
$desktopMinW: 1281px;
|
||||||
$tabMinH: 741px;
|
|
||||||
$tabMaxH: 1024px;
|
|
||||||
|
|
||||||
$compMinW: 800px;
|
|
||||||
$compMinH: 1025px;
|
|
||||||
|
|
||||||
/************************** MEDIA QUERIES: WINDOW CHECKS FOR SPECIFIC ORIENTATIONS FOR EACH DEVICE */
|
/************************** MEDIA QUERIES: WINDOW CHECKS FOR SPECIFIC ORIENTATIONS FOR EACH DEVICE */
|
||||||
$screenPortrait: "screen and (orientation: portrait)";
|
$screenPortrait: "screen and (orientation: portrait)";
|
||||||
$screenLandscape: "screen and (orientation: landscape)";
|
$screenLandscape: "screen and (orientation: landscape)";
|
||||||
|
|
||||||
$mobileDevice: "(max-device-width: #{$tabMaxW}) and (max-device-height: #{$tabMaxH})";
|
$mobileDevice: "(max-device-width: #{$tabMaxW})";
|
||||||
$mobileDeviceEmu: "(max-device-width: #{$tabMaxH}) and (max-device-height: #{$tabMaxW})";
|
|
||||||
|
|
||||||
$phonePortraitCheck: "(max-width: #{$phoMaxW}) and (max-height: #{$phoMaxH})";
|
$phoneCheck: "(max-device-width: #{$phoMaxW})";
|
||||||
$phoneLandscapeCheck: "(max-height: #{$phoMaxW}) and (max-width: #{$phoMaxH})";
|
$tabletCheck: $mobileDevice;
|
||||||
|
$desktopCheck: "(min-device-width: #{$desktopMinW})";
|
||||||
$tabWidPorCheck: "(min-width: #{$tabMinW}) and (max-width: #{$tabMaxW})";
|
|
||||||
$tabHeiPorCheck: "(min-height: #{$tabMinH}) and (max-height: #{$tabMaxH})";
|
|
||||||
$tabletPortraitCheck: "#{$tabWidPorCheck} and #{$tabHeiPorCheck}";
|
|
||||||
|
|
||||||
$tabWidLanCheck: "(min-height: #{$tabMinW}) and (max-height: #{$tabMaxW})";
|
|
||||||
$tabHeiLanCheck: "(min-width: #{$tabMinH}) and (max-width: #{$tabMaxH})";
|
|
||||||
$tabletLandscapeCheck: "#{$tabWidLanCheck} and #{$tabHeiLanCheck}";
|
|
||||||
|
|
||||||
$desktopPortraitCheck: "(min-device-width: #{$compMinW}) and (min-device-height: #{$compMinH})";
|
|
||||||
$desktopLandscapeCheck: "(min-device-width: #{$compMinH}) and (min-device-height: #{$compMinW})";
|
|
||||||
|
|
||||||
/************************** MEDIA QUERIES: WINDOWS FOR SPECIFIC ORIENTATIONS FOR EACH DEVICE */
|
/************************** MEDIA QUERIES: WINDOWS FOR SPECIFIC ORIENTATIONS FOR EACH DEVICE */
|
||||||
$phonePortrait: "#{$screenPortrait} and #{$phonePortraitCheck} and #{$mobileDevice}";
|
$phonePortrait: "#{$screenPortrait} and #{$phoneCheck} and #{$mobileDevice}";
|
||||||
$phoneLandscape: "#{$screenLandscape} and #{$phoneLandscapeCheck} and #{$mobileDevice}";
|
$phoneLandscape: "#{$screenLandscape} and #{$phoneCheck} and #{$mobileDevice}";
|
||||||
$phoneLandscapeEmu: "#{$screenLandscape} and #{$phoneLandscapeCheck} and #{$mobileDeviceEmu}";
|
|
||||||
|
|
||||||
$tabletPortrait: "#{$screenPortrait} and #{$tabletPortraitCheck} and #{$mobileDevice}";
|
$tabletPortrait: "#{$screenPortrait} and #{$tabletCheck} and #{$mobileDevice}";
|
||||||
$tabletLandscape: "#{$screenLandscape} and #{$tabletLandscapeCheck} and #{$mobileDevice}";
|
$tabletLandscape: "#{$screenLandscape} and #{$tabletCheck} and #{$mobileDevice}";
|
||||||
$tabletLandscapeEmu: "#{$screenLandscape} and #{$tabletLandscapeCheck} and #{$mobileDeviceEmu}";
|
|
||||||
|
|
||||||
$desktopPortrait: "screen and #{$desktopPortraitCheck}";
|
$desktop: "screen and #{$desktopCheck}";
|
||||||
$desktopLandscape: "screen and #{$desktopLandscapeCheck}";
|
|
||||||
|
|
||||||
/************************** DEVICE PARAMETERS FOR MENUS/REPRESENTATIONS */
|
/************************** DEVICE PARAMETERS FOR MENUS/REPRESENTATIONS */
|
||||||
$proporMenuOnly: 90%;
|
$proporMenuOnly: 90%;
|
||||||
|
@ -25,8 +25,7 @@
|
|||||||
// Phones in any orientation
|
// Phones in any orientation
|
||||||
@mixin phone {
|
@mixin phone {
|
||||||
@media #{$phonePortrait},
|
@media #{$phonePortrait},
|
||||||
#{$phoneLandscape},
|
#{$phoneLandscape} {
|
||||||
#{$phoneLandscapeEmu} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -40,8 +39,7 @@
|
|||||||
|
|
||||||
// Phones in landscape orientation
|
// Phones in landscape orientation
|
||||||
@mixin phoneLandscape {
|
@mixin phoneLandscape {
|
||||||
@media #{$phoneLandscape},
|
@media #{$phoneLandscape} {
|
||||||
#{$phoneLandscapeEmu} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -49,8 +47,7 @@
|
|||||||
// Tablets in any orientation
|
// Tablets in any orientation
|
||||||
@mixin tablet {
|
@mixin tablet {
|
||||||
@media #{$tabletPortrait},
|
@media #{$tabletPortrait},
|
||||||
#{$tabletLandscape},
|
#{$tabletLandscape} {
|
||||||
#{$tabletLandscapeEmu} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -64,8 +61,7 @@
|
|||||||
|
|
||||||
// Tablets in landscape orientation
|
// Tablets in landscape orientation
|
||||||
@mixin tabletLandscape {
|
@mixin tabletLandscape {
|
||||||
@media #{$tabletLandscape},
|
@media #{$tabletLandscape} {
|
||||||
#{$tabletLandscapeEmu} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -74,10 +70,8 @@
|
|||||||
@mixin phoneandtablet {
|
@mixin phoneandtablet {
|
||||||
@media #{$phonePortrait},
|
@media #{$phonePortrait},
|
||||||
#{$phoneLandscape},
|
#{$phoneLandscape},
|
||||||
#{$phoneLandscapeEmu},
|
|
||||||
#{$tabletPortrait},
|
#{$tabletPortrait},
|
||||||
#{$tabletLandscape},
|
#{$tabletLandscape} {
|
||||||
#{$tabletLandscapeEmu} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -86,17 +80,14 @@
|
|||||||
@mixin desktopandtablet {
|
@mixin desktopandtablet {
|
||||||
@media #{$tabletPortrait},
|
@media #{$tabletPortrait},
|
||||||
#{$tabletLandscape},
|
#{$tabletLandscape},
|
||||||
#{$tabletLandscapeEmu},
|
#{$desktop} {
|
||||||
#{$desktopPortrait},
|
|
||||||
#{$desktopLandscape} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Desktop monitors in any orientation
|
// Desktop monitors in any orientation
|
||||||
@mixin desktop {
|
@mixin desktop {
|
||||||
@media #{$desktopPortrait},
|
@media #{$desktop} {
|
||||||
#{$desktopLandscape} {
|
|
||||||
@content
|
@content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,11 +20,9 @@
|
|||||||
* at runtime from the About dialog for additional information.
|
* at runtime from the About dialog for additional information.
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
$yBarW: 60px;
|
$yBarW: 60px;
|
||||||
$yLabelW: auto;
|
$yLabelW: 10px;
|
||||||
$xBarH: 32px;
|
$xBarH: 32px;
|
||||||
$legendH: 20px;
|
$legendH: 20px;
|
||||||
//$colorHash: rgba(white, 0.3); // MOVED INTO CONSTANTS
|
|
||||||
//$styleHash: dashed; // MOVED INTO CONSTANTS
|
|
||||||
$swatchD: 8px;
|
$swatchD: 8px;
|
||||||
$plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBarW); // Top, right, bottom, left
|
$plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBarW); // Top, right, bottom, left
|
||||||
|
|
||||||
@ -36,7 +34,6 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
height: 100%;
|
height: 100%;
|
||||||
|
|
||||||
.gl-plot-axis-area {
|
.gl-plot-axis-area {
|
||||||
// @include test(green);
|
|
||||||
position: absolute;
|
position: absolute;
|
||||||
&.gl-plot-x {
|
&.gl-plot-x {
|
||||||
top: auto;
|
top: auto;
|
||||||
@ -59,7 +56,7 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
.gl-plot-coords {
|
.gl-plot-coords {
|
||||||
@include box-sizing(border-box);
|
@include box-sizing(border-box);
|
||||||
@include border-radius($controlCr);
|
@include border-radius($controlCr);
|
||||||
background: black; //rgba($colorKey, 0.5);
|
background: black;
|
||||||
color: lighten($colorBodyFg, 30%);
|
color: lighten($colorBodyFg, 30%);
|
||||||
padding: 2px 5px;
|
padding: 2px 5px;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -88,11 +85,9 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
|
|
||||||
.gl-plot-label,
|
.gl-plot-label,
|
||||||
.l-plot-label {
|
.l-plot-label {
|
||||||
// @include test(yellow);
|
|
||||||
color: $colorPlotLabelFg;
|
color: $colorPlotLabelFg;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
// text-transform: uppercase;
|
|
||||||
|
|
||||||
&.gl-plot-x-label,
|
&.gl-plot-x-label,
|
||||||
&.l-plot-x-label {
|
&.l-plot-x-label {
|
||||||
@ -117,20 +112,26 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.gl-plot-y-options {
|
.gl-plot-x-options,
|
||||||
|
.gl-plot-y-options {
|
||||||
$h: 32px;
|
$h: 32px;
|
||||||
// @include test();
|
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 50%;
|
|
||||||
right: auto;
|
|
||||||
bottom: auto;
|
|
||||||
left: $yLabelW + $interiorMargin;
|
|
||||||
margin-top: $h / -2;
|
|
||||||
height: auto;
|
height: auto;
|
||||||
min-height: $h;
|
min-height: $h;
|
||||||
width: $h;
|
z-index: 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.gl-plot-x-options {
|
||||||
|
top: $interiorMargin;
|
||||||
|
}
|
||||||
|
|
||||||
|
.gl-plot-y-options {
|
||||||
|
@include transform(translateY(-50%));
|
||||||
|
min-width: 150px; // Need this due to enclosure of .select
|
||||||
|
top: 50%;
|
||||||
|
left: $yLabelW + $interiorMargin * 2;
|
||||||
|
}
|
||||||
|
|
||||||
.gl-plot-hash {
|
.gl-plot-hash {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
border: 0 $colorPlotHash $stylePlotHash;
|
border: 0 $colorPlotHash $stylePlotHash;
|
||||||
@ -214,21 +215,13 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
display: inline-block;
|
display: inline-block;
|
||||||
height: $swatchD;
|
height: $swatchD;
|
||||||
width: $swatchD;
|
width: $swatchD;
|
||||||
//margin-right: $interiorMarginSm;
|
|
||||||
}
|
|
||||||
&[class*='s-limit'] {
|
|
||||||
.title-label {
|
|
||||||
//color: #fff;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.gl-plot-legend {
|
.gl-plot-legend {
|
||||||
.plot-legend-item {
|
.plot-legend-item {
|
||||||
//@include test();
|
|
||||||
@include border-radius($smallCr);
|
@include border-radius($smallCr);
|
||||||
//color: #fff;
|
|
||||||
line-height: 1.5em;
|
line-height: 1.5em;
|
||||||
padding: 0px $itemPadLR;
|
padding: 0px $itemPadLR;
|
||||||
.plot-color-swatch {
|
.plot-color-swatch {
|
||||||
@ -250,7 +243,6 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
|
|
||||||
.gl-plot-tick,
|
.gl-plot-tick,
|
||||||
.tick-label {
|
.tick-label {
|
||||||
// @include test(red);
|
|
||||||
font-size: 0.7rem;
|
font-size: 0.7rem;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
@ -277,7 +269,6 @@ $plotDisplayArea: ($legendH + $interiorMargin, 0, $xBarH + $interiorMargin, $yBa
|
|||||||
}
|
}
|
||||||
|
|
||||||
.gl-plot-tick {
|
.gl-plot-tick {
|
||||||
// @include test(red);
|
|
||||||
&.gl-plot-x-tick-label {
|
&.gl-plot-x-tick-label {
|
||||||
top: $interiorMargin;
|
top: $interiorMargin;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
@mixin containerSubtle($bg: $colorBodyBg, $fg: $colorBodyFg) {
|
@mixin containerSubtle($bg: $colorBodyBg, $fg: $colorBodyFg, $hover: false) {
|
||||||
@include containerBase($bg, $fg);
|
@include containerBase($bg, $fg);
|
||||||
@include boxShdw($shdwBtns);
|
@include boxShdw($shdwBtns);
|
||||||
}
|
}
|
||||||
|
@ -72,8 +72,7 @@
|
|||||||
"persistenceService",
|
"persistenceService",
|
||||||
"$q",
|
"$q",
|
||||||
"now",
|
"now",
|
||||||
"PERSISTENCE_SPACE",
|
"PERSISTENCE_SPACE"
|
||||||
"ADDITIONAL_PERSISTENCE_SPACES"
|
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -115,6 +114,12 @@
|
|||||||
"type": "provider",
|
"type": "provider",
|
||||||
"implementation": "views/ViewProvider.js",
|
"implementation": "views/ViewProvider.js",
|
||||||
"depends": [ "views[]", "$log" ]
|
"depends": [ "views[]", "$log" ]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"provides": "identifierService",
|
||||||
|
"type": "provider",
|
||||||
|
"implementation": "identifiers/IdentifierProvider.js",
|
||||||
|
"depends": [ "PERSISTENCE_SPACE" ]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"types": [
|
"types": [
|
||||||
@ -183,7 +188,7 @@
|
|||||||
{
|
{
|
||||||
"key": "persistence",
|
"key": "persistence",
|
||||||
"implementation": "capabilities/PersistenceCapability.js",
|
"implementation": "capabilities/PersistenceCapability.js",
|
||||||
"depends": [ "persistenceService", "PERSISTENCE_SPACE" ]
|
"depends": [ "persistenceService", "identifierService" ]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "metadata",
|
"key": "metadata",
|
||||||
@ -202,7 +207,7 @@
|
|||||||
{
|
{
|
||||||
"key": "instantiation",
|
"key": "instantiation",
|
||||||
"implementation": "capabilities/InstantiationCapability.js",
|
"implementation": "capabilities/InstantiationCapability.js",
|
||||||
"depends": [ "$injector" ]
|
"depends": [ "$injector", "identifierService" ]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"services": [
|
"services": [
|
||||||
@ -245,11 +250,6 @@
|
|||||||
{
|
{
|
||||||
"key": "PERSISTENCE_SPACE",
|
"key": "PERSISTENCE_SPACE",
|
||||||
"value": "mct"
|
"value": "mct"
|
||||||
},
|
|
||||||
{
|
|
||||||
"key": "ADDITIONAL_PERSISTENCE_SPACES",
|
|
||||||
"value": [],
|
|
||||||
"description": "An array of additional persistence spaces to load models from."
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"licenses": [
|
"licenses": [
|
||||||
|
@ -22,8 +22,8 @@
|
|||||||
/*global define,Promise*/
|
/*global define,Promise*/
|
||||||
|
|
||||||
define(
|
define(
|
||||||
['../objects/DomainObjectImpl', 'uuid'],
|
['../objects/DomainObjectImpl'],
|
||||||
function (DomainObjectImpl, uuid) {
|
function (DomainObjectImpl) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -33,9 +33,12 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @memberof platform/core
|
* @memberof platform/core
|
||||||
* @param $injector Angular's `$injector`
|
* @param $injector Angular's `$injector`
|
||||||
|
* @implements {Capability}
|
||||||
*/
|
*/
|
||||||
function InstantiationCapability($injector) {
|
function InstantiationCapability($injector, identifierService, domainObject) {
|
||||||
this.$injector = $injector;
|
this.$injector = $injector;
|
||||||
|
this.identifierService = identifierService;
|
||||||
|
this.domainObject = domainObject;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -45,19 +48,26 @@ define(
|
|||||||
* have been persisted, nor will it have been added to the
|
* have been persisted, nor will it have been added to the
|
||||||
* composition of the object which exposed this capability.
|
* composition of the object which exposed this capability.
|
||||||
*
|
*
|
||||||
|
* @param {object} the model for the new domain object
|
||||||
* @returns {DomainObject} the new domain object
|
* @returns {DomainObject} the new domain object
|
||||||
*/
|
*/
|
||||||
InstantiationCapability.prototype.instantiate = function (model) {
|
InstantiationCapability.prototype.instantiate = function (model) {
|
||||||
|
var parsedId =
|
||||||
|
this.identifierService.parse(this.domainObject.getId()),
|
||||||
|
space = parsedId.getDefinedSpace(),
|
||||||
|
id = this.identifierService.generate(space);
|
||||||
|
|
||||||
// Lazily initialize; instantiate depends on capabilityService,
|
// Lazily initialize; instantiate depends on capabilityService,
|
||||||
// which depends on all capabilities, including this one.
|
// which depends on all capabilities, including this one.
|
||||||
this.instantiateFn = this.instantiateFn ||
|
this.instantiateFn = this.instantiateFn ||
|
||||||
this.$injector.get("instantiate");
|
this.$injector.get("instantiate");
|
||||||
return this.instantiateFn(model);
|
|
||||||
|
return this.instantiateFn(model, id);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Alias of `create`.
|
* Alias of `instantiate`.
|
||||||
* @see {platform/core.CreationCapability#create}
|
* @see {platform/core.CreationCapability#instantiate}
|
||||||
*/
|
*/
|
||||||
InstantiationCapability.prototype.invoke =
|
InstantiationCapability.prototype.invoke =
|
||||||
InstantiationCapability.prototype.instantiate;
|
InstantiationCapability.prototype.instantiate;
|
||||||
|
@ -44,12 +44,16 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @implements {Capability}
|
* @implements {Capability}
|
||||||
*/
|
*/
|
||||||
function PersistenceCapability(persistenceService, space, domainObject) {
|
function PersistenceCapability(
|
||||||
|
persistenceService,
|
||||||
|
identifierService,
|
||||||
|
domainObject
|
||||||
|
) {
|
||||||
// Cache modified timestamp
|
// Cache modified timestamp
|
||||||
this.modified = domainObject.getModel().modified;
|
this.modified = domainObject.getModel().modified;
|
||||||
|
|
||||||
this.domainObject = domainObject;
|
this.domainObject = domainObject;
|
||||||
this.space = space;
|
this.identifierService = identifierService;
|
||||||
this.persistenceService = persistenceService;
|
this.persistenceService = persistenceService;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -63,6 +67,11 @@ define(
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getKey(id) {
|
||||||
|
var parts = id.split(":");
|
||||||
|
return parts.length > 1 ? parts.slice(1).join(":") : id;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Persist any changes which have been made to this
|
* Persist any changes which have been made to this
|
||||||
* domain object's model.
|
* domain object's model.
|
||||||
@ -87,7 +96,7 @@ define(
|
|||||||
// ...and persist
|
// ...and persist
|
||||||
return persistenceFn.apply(persistenceService, [
|
return persistenceFn.apply(persistenceService, [
|
||||||
this.getSpace(),
|
this.getSpace(),
|
||||||
domainObject.getId(),
|
getKey(domainObject.getId()),
|
||||||
domainObject.getModel()
|
domainObject.getModel()
|
||||||
]);
|
]);
|
||||||
};
|
};
|
||||||
@ -130,7 +139,8 @@ define(
|
|||||||
* be used to persist this object
|
* be used to persist this object
|
||||||
*/
|
*/
|
||||||
PersistenceCapability.prototype.getSpace = function () {
|
PersistenceCapability.prototype.getSpace = function () {
|
||||||
return this.space;
|
var id = this.domainObject.getId();
|
||||||
|
return this.identifierService.parse(id).getSpace();
|
||||||
};
|
};
|
||||||
|
|
||||||
return PersistenceCapability;
|
return PersistenceCapability;
|
||||||
|
86
platform/core/src/identifiers/Identifier.js
Normal file
86
platform/core/src/identifiers/Identifier.js
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var SEPARATOR = ":";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides an interface for interpreting domain object identifiers;
|
||||||
|
* in particular, parses out persistence space/key pairs associated
|
||||||
|
* with the domain object.
|
||||||
|
*
|
||||||
|
* @memberof platform/core
|
||||||
|
* @constructor
|
||||||
|
* @param {string} id the domain object identifier
|
||||||
|
* @param {string} defaultSpace the persistence space to use if
|
||||||
|
* one is not encoded in the identifier
|
||||||
|
*/
|
||||||
|
function Identifier(id, defaultSpace) {
|
||||||
|
var separatorIndex = id.indexOf(SEPARATOR);
|
||||||
|
|
||||||
|
if (separatorIndex > -1) {
|
||||||
|
this.key = id.substring(separatorIndex + 1);
|
||||||
|
this.space = id.substring(0, separatorIndex);
|
||||||
|
this.definedSpace = this.space;
|
||||||
|
} else {
|
||||||
|
this.key = id;
|
||||||
|
this.space = defaultSpace;
|
||||||
|
this.definedSpace = undefined;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the key under which the identified domain object's model
|
||||||
|
* should be persisted, within its persistence space.
|
||||||
|
* @returns {string} the key within its persistence space
|
||||||
|
*/
|
||||||
|
Identifier.prototype.getKey = function () {
|
||||||
|
return this.key;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the space in which the identified domain object's model should
|
||||||
|
* be persisted.
|
||||||
|
* @returns {string} the persistence space
|
||||||
|
*/
|
||||||
|
Identifier.prototype.getSpace = function () {
|
||||||
|
return this.space;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the persistence space, if any, which has been explicitly
|
||||||
|
* encoded in this domain object's identifier. Returns undefined
|
||||||
|
* if no such space has been specified.
|
||||||
|
* @returns {string} the persistence space, or undefined
|
||||||
|
*/
|
||||||
|
Identifier.prototype.getDefinedSpace = function () {
|
||||||
|
return this.definedSpace;
|
||||||
|
};
|
||||||
|
|
||||||
|
return Identifier;
|
||||||
|
}
|
||||||
|
);
|
66
platform/core/src/identifiers/IdentifierProvider.js
Normal file
66
platform/core/src/identifiers/IdentifierProvider.js
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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", "./Identifier"],
|
||||||
|
function (uuid, Identifier) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses and generates domain object identifiers.
|
||||||
|
* @param {string} defaultSpace the default persistence space
|
||||||
|
* @constructor
|
||||||
|
* @memberof {platform/core}
|
||||||
|
*/
|
||||||
|
function IdentifierProvider(defaultSpace) {
|
||||||
|
this.defaultSpace = defaultSpace;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a new domain object identifier. A persistence space
|
||||||
|
* may optionally be included; if not specified, no space will
|
||||||
|
* be encoded into the identifier.
|
||||||
|
* @param {string} [space] the persistence space to encode
|
||||||
|
* in this identifier
|
||||||
|
* @returns {string} a new domain object identifier
|
||||||
|
*/
|
||||||
|
IdentifierProvider.prototype.generate = function (space) {
|
||||||
|
var id = uuid();
|
||||||
|
if (space !== undefined) {
|
||||||
|
id = space + ":" + id;
|
||||||
|
}
|
||||||
|
return id;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse a domain object identifier to examine its component
|
||||||
|
* parts (e.g. its persistence space.)
|
||||||
|
* @returns {platform/core.Identifier} the parsed identifier
|
||||||
|
*/
|
||||||
|
IdentifierProvider.prototype.parse = function (id) {
|
||||||
|
return new Identifier(id, this.defaultSpace);
|
||||||
|
};
|
||||||
|
|
||||||
|
return IdentifierProvider;
|
||||||
|
}
|
||||||
|
);
|
@ -33,6 +33,15 @@ define(
|
|||||||
* A model service which reads domain object models from an external
|
* A model service which reads domain object models from an external
|
||||||
* persistence service.
|
* persistence service.
|
||||||
*
|
*
|
||||||
|
* Identifiers will be interpreted as follows:
|
||||||
|
* * If no colon is present, the model will be read from the default
|
||||||
|
* persistence space.
|
||||||
|
* * If a colon is present, everything before the first colon will be
|
||||||
|
* taken to refer to the persistence space, and everything after
|
||||||
|
* will be taken to be that model's key within this space. (If
|
||||||
|
* no such space exists within the `persistenceService`, that
|
||||||
|
* identifier will simply be ignored.)
|
||||||
|
*
|
||||||
* @memberof platform/core
|
* @memberof platform/core
|
||||||
* @constructor
|
* @constructor
|
||||||
* @implements {ModelService}
|
* @implements {ModelService}
|
||||||
@ -41,39 +50,26 @@ define(
|
|||||||
* @param $q Angular's $q service, for working with promises
|
* @param $q Angular's $q service, for working with promises
|
||||||
* @param {function} now a function which provides the current time
|
* @param {function} now a function which provides the current time
|
||||||
* @param {string} space the name of the persistence space(s)
|
* @param {string} space the name of the persistence space(s)
|
||||||
* from which models should be retrieved.
|
* from which models should be retrieved by default
|
||||||
* @param {string} spaces additional persistence spaces to use
|
|
||||||
*/
|
*/
|
||||||
function PersistedModelProvider(persistenceService, $q, now, space, spaces) {
|
function PersistedModelProvider(persistenceService, $q, now, space) {
|
||||||
this.persistenceService = persistenceService;
|
this.persistenceService = persistenceService;
|
||||||
this.$q = $q;
|
this.$q = $q;
|
||||||
this.spaces = [space].concat(spaces || []);
|
|
||||||
this.now = now;
|
this.now = now;
|
||||||
}
|
this.defaultSpace = space;
|
||||||
|
|
||||||
// Take the most recently modified model, for cases where
|
|
||||||
// multiple persistence spaces return models.
|
|
||||||
function takeMostRecent(modelA, modelB) {
|
|
||||||
return (!modelB || modelB.modified === undefined) ? modelA :
|
|
||||||
(!modelA || modelA.modified === undefined) ? modelB :
|
|
||||||
modelB.modified > modelA.modified ? modelB :
|
|
||||||
modelA;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PersistedModelProvider.prototype.getModels = function (ids) {
|
PersistedModelProvider.prototype.getModels = function (ids) {
|
||||||
var persistenceService = this.persistenceService,
|
var persistenceService = this.persistenceService,
|
||||||
$q = this.$q,
|
$q = this.$q,
|
||||||
spaces = this.spaces,
|
now = this.now,
|
||||||
space = this.space,
|
defaultSpace = this.defaultSpace,
|
||||||
now = this.now;
|
parsedIds;
|
||||||
|
|
||||||
// Load a single object model from any persistence spaces
|
// Load a single object model from any persistence spaces
|
||||||
function loadModel(id) {
|
function loadModel(parsedId) {
|
||||||
return $q.all(spaces.map(function (space) {
|
return persistenceService
|
||||||
return persistenceService.readObject(space, id);
|
.readObject(parsedId.space, parsedId.key);
|
||||||
})).then(function (models) {
|
|
||||||
return models.reduce(takeMostRecent);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure that models read from persistence have some
|
// Ensure that models read from persistence have some
|
||||||
@ -88,24 +84,43 @@ define(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Package the result as id->model
|
// Package the result as id->model
|
||||||
function packageResult(models) {
|
function packageResult(parsedIds, models) {
|
||||||
var result = {};
|
var result = {};
|
||||||
ids.forEach(function (id, index) {
|
parsedIds.forEach(function (parsedId, index) {
|
||||||
|
var id = parsedId.id;
|
||||||
if (models[index]) {
|
if (models[index]) {
|
||||||
result[id] = addPersistedTimestamp(models[index]);
|
result[id] = models[index];
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Filter out "namespaced" identifiers; these are
|
function loadModels(parsedIds) {
|
||||||
// not expected to be found in database. See WTD-659.
|
return $q.all(parsedIds.map(loadModel))
|
||||||
ids = ids.filter(function (id) {
|
.then(function (models) {
|
||||||
return id.indexOf(":") === -1;
|
return packageResult(
|
||||||
|
parsedIds,
|
||||||
|
models.map(addPersistedTimestamp)
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function restrictToSpaces(spaces) {
|
||||||
|
return parsedIds.filter(function (parsedId) {
|
||||||
|
return spaces.indexOf(parsedId.space) !== -1;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
parsedIds = ids.map(function (id) {
|
||||||
|
var parts = id.split(":");
|
||||||
|
return (parts.length > 1) ?
|
||||||
|
{ id: id, space: parts[0], key: parts.slice(1).join(":") } :
|
||||||
|
{ id: id, space: defaultSpace, key: id };
|
||||||
});
|
});
|
||||||
|
|
||||||
// Give a promise for all persistence lookups...
|
return persistenceService.listSpaces()
|
||||||
return $q.all(ids.map(loadModel)).then(packageResult);
|
.then(restrictToSpaces)
|
||||||
|
.then(loadModels);
|
||||||
};
|
};
|
||||||
|
|
||||||
return PersistedModelProvider;
|
return PersistedModelProvider;
|
||||||
|
@ -22,8 +22,8 @@
|
|||||||
/*global define,Promise*/
|
/*global define,Promise*/
|
||||||
|
|
||||||
define(
|
define(
|
||||||
['../objects/DomainObjectImpl', 'uuid'],
|
['../objects/DomainObjectImpl'],
|
||||||
function (DomainObjectImpl, uuid) {
|
function (DomainObjectImpl) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -39,12 +39,15 @@ define(
|
|||||||
*
|
*
|
||||||
* @constructor
|
* @constructor
|
||||||
* @memberof platform/core
|
* @memberof platform/core
|
||||||
* @param $injector Angular's `$injector`
|
* @param {CapabilityService} capabilityService the service which will
|
||||||
|
* provide instantiated domain objects with their capabilities
|
||||||
|
* @param {IdentifierService} identifierService service to generate
|
||||||
|
* new identifiers
|
||||||
*/
|
*/
|
||||||
function Instantiate(capabilityService) {
|
function Instantiate(capabilityService, identifierService) {
|
||||||
return function (model, id) {
|
return function (model, id) {
|
||||||
var capabilities = capabilityService.getCapabilities(model);
|
var capabilities = capabilityService.getCapabilities(model);
|
||||||
id = id || uuid();
|
id = id || identifierService.generate();
|
||||||
return new DomainObjectImpl(id, model, capabilities);
|
return new DomainObjectImpl(id, model, capabilities);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -28,19 +28,40 @@ define(
|
|||||||
|
|
||||||
describe("The 'instantiation' capability", function () {
|
describe("The 'instantiation' capability", function () {
|
||||||
var mockInjector,
|
var mockInjector,
|
||||||
|
mockIdentifierService,
|
||||||
mockInstantiate,
|
mockInstantiate,
|
||||||
|
mockIdentifier,
|
||||||
|
mockDomainObject,
|
||||||
instantiation;
|
instantiation;
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
mockInjector = jasmine.createSpyObj("$injector", ["get"]);
|
mockInjector = jasmine.createSpyObj("$injector", ["get"]);
|
||||||
mockInstantiate = jasmine.createSpy("instantiate");
|
mockInstantiate = jasmine.createSpy("instantiate");
|
||||||
|
mockIdentifierService = jasmine.createSpyObj(
|
||||||
|
'identifierService',
|
||||||
|
[ 'parse', 'generate' ]
|
||||||
|
);
|
||||||
|
mockIdentifier = jasmine.createSpyObj(
|
||||||
|
'identifier',
|
||||||
|
[ 'getSpace', 'getKey', 'getDefinedSpace' ]
|
||||||
|
);
|
||||||
|
mockDomainObject = jasmine.createSpyObj(
|
||||||
|
'domainObject',
|
||||||
|
[ 'getId', 'getCapability', 'getModel' ]
|
||||||
|
);
|
||||||
|
|
||||||
mockInjector.get.andCallFake(function (key) {
|
mockInjector.get.andCallFake(function (key) {
|
||||||
return key === 'instantiate' ?
|
return key === 'instantiate' ?
|
||||||
mockInstantiate : undefined;
|
mockInstantiate : undefined;
|
||||||
});
|
});
|
||||||
|
mockIdentifierService.parse.andReturn(mockIdentifier);
|
||||||
|
mockIdentifierService.generate.andReturn("some-id");
|
||||||
|
|
||||||
instantiation = new InstantiationCapability(mockInjector);
|
instantiation = new InstantiationCapability(
|
||||||
|
mockInjector,
|
||||||
|
mockIdentifierService,
|
||||||
|
mockDomainObject
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
@ -59,7 +80,8 @@ define(
|
|||||||
mockInstantiate.andReturn(mockDomainObject);
|
mockInstantiate.andReturn(mockDomainObject);
|
||||||
expect(instantiation.instantiate(testModel))
|
expect(instantiation.instantiate(testModel))
|
||||||
.toBe(mockDomainObject);
|
.toBe(mockDomainObject);
|
||||||
expect(mockInstantiate).toHaveBeenCalledWith(testModel);
|
expect(mockInstantiate)
|
||||||
|
.toHaveBeenCalledWith(testModel, jasmine.any(String));
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -31,7 +31,9 @@ define(
|
|||||||
|
|
||||||
describe("The persistence capability", function () {
|
describe("The persistence capability", function () {
|
||||||
var mockPersistenceService,
|
var mockPersistenceService,
|
||||||
|
mockIdentifierService,
|
||||||
mockDomainObject,
|
mockDomainObject,
|
||||||
|
mockIdentifier,
|
||||||
id = "object id",
|
id = "object id",
|
||||||
model = { someKey: "some value"},
|
model = { someKey: "some value"},
|
||||||
SPACE = "some space",
|
SPACE = "some space",
|
||||||
@ -50,6 +52,14 @@ define(
|
|||||||
"persistenceService",
|
"persistenceService",
|
||||||
[ "updateObject", "readObject", "createObject", "deleteObject" ]
|
[ "updateObject", "readObject", "createObject", "deleteObject" ]
|
||||||
);
|
);
|
||||||
|
mockIdentifierService = jasmine.createSpyObj(
|
||||||
|
'identifierService',
|
||||||
|
[ 'parse', 'generate' ]
|
||||||
|
);
|
||||||
|
mockIdentifier = jasmine.createSpyObj(
|
||||||
|
'identifier',
|
||||||
|
[ 'getSpace', 'getKey', 'getDefinedSpace' ]
|
||||||
|
);
|
||||||
mockDomainObject = {
|
mockDomainObject = {
|
||||||
getId: function () { return id; },
|
getId: function () { return id; },
|
||||||
getModel: function () { return model; },
|
getModel: function () { return model; },
|
||||||
@ -61,9 +71,11 @@ define(
|
|||||||
model = mutator(model) || model;
|
model = mutator(model) || model;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
mockIdentifierService.parse.andReturn(mockIdentifier);
|
||||||
|
mockIdentifier.getSpace.andReturn(SPACE);
|
||||||
persistence = new PersistenceCapability(
|
persistence = new PersistenceCapability(
|
||||||
mockPersistenceService,
|
mockPersistenceService,
|
||||||
SPACE,
|
mockIdentifierService,
|
||||||
mockDomainObject
|
mockDomainObject
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
58
platform/core/test/identifiers/IdentifierProviderSpec.js
Normal file
58
platform/core/test/identifiers/IdentifierProviderSpec.js
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
["../../src/identifiers/IdentifierProvider"],
|
||||||
|
function (IdentifierProvider) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe("IdentifierProvider", function () {
|
||||||
|
var defaultSpace,
|
||||||
|
provider;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
defaultSpace = "some-default-space";
|
||||||
|
provider = new IdentifierProvider(defaultSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("generates unique identifiers", function () {
|
||||||
|
expect(provider.generate())
|
||||||
|
.not.toEqual(provider.generate());
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows spaces to be specified for generated identifiers", function () {
|
||||||
|
var specificSpace = "some-specific-space",
|
||||||
|
id = provider.generate(specificSpace);
|
||||||
|
expect(id).toEqual(jasmine.any(String));
|
||||||
|
expect(provider.parse(id).getDefinedSpace())
|
||||||
|
.toEqual(specificSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("parses identifiers using the default space", function () {
|
||||||
|
expect(provider.parse("some-unprefixed-id").getSpace())
|
||||||
|
.toEqual(defaultSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
82
platform/core/test/identifiers/IdentifierSpec.js
Normal file
82
platform/core/test/identifiers/IdentifierSpec.js
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
["../../src/identifiers/Identifier"],
|
||||||
|
function (Identifier) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe("A parsed domain object identifier", function () {
|
||||||
|
var id,
|
||||||
|
defaultSpace,
|
||||||
|
identifier;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
defaultSpace = "someDefaultSpace";
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("when space is encoded", function () {
|
||||||
|
var idSpace, idKey, spacedId;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
idSpace = "a-specific-space";
|
||||||
|
idKey = "a-specific-key";
|
||||||
|
id = idSpace + ":" + idKey;
|
||||||
|
identifier = new Identifier(id, defaultSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides the encoded space", function () {
|
||||||
|
expect(identifier.getSpace()).toEqual(idSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides the key within that space", function () {
|
||||||
|
expect(identifier.getKey()).toEqual(idKey);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides the defined space", function () {
|
||||||
|
expect(identifier.getDefinedSpace()).toEqual(idSpace);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("when space is not encoded", function () {
|
||||||
|
beforeEach(function () {
|
||||||
|
id = "a-generic-id";
|
||||||
|
identifier = new Identifier(id, defaultSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides the default space", function () {
|
||||||
|
expect(identifier.getSpace()).toEqual(defaultSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides the id as the key", function () {
|
||||||
|
expect(identifier.getKey()).toEqual(id);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides no defined space", function () {
|
||||||
|
expect(identifier.getDefinedSpace()).toEqual(undefined);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -33,13 +33,12 @@ define(
|
|||||||
var mockQ,
|
var mockQ,
|
||||||
mockPersistenceService,
|
mockPersistenceService,
|
||||||
SPACE = "space0",
|
SPACE = "space0",
|
||||||
spaces = [ "space1" ],
|
|
||||||
modTimes,
|
modTimes,
|
||||||
mockNow,
|
mockNow,
|
||||||
provider;
|
provider;
|
||||||
|
|
||||||
function mockPromise(value) {
|
function mockPromise(value) {
|
||||||
return {
|
return (value || {}).then ? value : {
|
||||||
then: function (callback) {
|
then: function (callback) {
|
||||||
return mockPromise(callback(value));
|
return mockPromise(callback(value));
|
||||||
},
|
},
|
||||||
@ -78,13 +77,14 @@ define(
|
|||||||
persisted: 0
|
persisted: 0
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
mockPersistenceService.listSpaces
|
||||||
|
.andReturn(mockPromise([SPACE]));
|
||||||
|
|
||||||
provider = new PersistedModelProvider(
|
provider = new PersistedModelProvider(
|
||||||
mockPersistenceService,
|
mockPersistenceService,
|
||||||
mockQ,
|
mockQ,
|
||||||
mockNow,
|
mockNow,
|
||||||
SPACE,
|
SPACE
|
||||||
spaces
|
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -103,25 +103,6 @@ define(
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it("reads object models from multiple spaces", function () {
|
|
||||||
var models;
|
|
||||||
|
|
||||||
modTimes.space1 = {
|
|
||||||
'x': 12321
|
|
||||||
};
|
|
||||||
|
|
||||||
provider.getModels(["a", "x", "zz"]).then(function (m) {
|
|
||||||
models = m;
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(models).toEqual({
|
|
||||||
a: { space: SPACE, id: "a", persisted: 0 },
|
|
||||||
x: { space: 'space1', id: "x", modified: 12321, persisted: 0 },
|
|
||||||
zz: { space: SPACE, id: "zz", persisted: 0 }
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
it("ensures that persisted timestamps are present", function () {
|
it("ensures that persisted timestamps are present", function () {
|
||||||
var mockCallback = jasmine.createSpy("callback"),
|
var mockCallback = jasmine.createSpy("callback"),
|
||||||
testModels = {
|
testModels = {
|
||||||
|
@ -29,18 +29,27 @@ define(
|
|||||||
describe("The 'instantiate' service", function () {
|
describe("The 'instantiate' service", function () {
|
||||||
|
|
||||||
var mockCapabilityService,
|
var mockCapabilityService,
|
||||||
|
mockIdentifierService,
|
||||||
mockCapabilityConstructor,
|
mockCapabilityConstructor,
|
||||||
mockCapabilityInstance,
|
mockCapabilityInstance,
|
||||||
mockCapabilities,
|
mockCapabilities,
|
||||||
|
mockIdentifier,
|
||||||
|
idCounter,
|
||||||
testModel,
|
testModel,
|
||||||
instantiate,
|
instantiate,
|
||||||
domainObject;
|
domainObject;
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
idCounter = 0;
|
||||||
|
|
||||||
mockCapabilityService = jasmine.createSpyObj(
|
mockCapabilityService = jasmine.createSpyObj(
|
||||||
'capabilityService',
|
'capabilityService',
|
||||||
['getCapabilities']
|
['getCapabilities']
|
||||||
);
|
);
|
||||||
|
mockIdentifierService = jasmine.createSpyObj(
|
||||||
|
'identifierService',
|
||||||
|
[ 'parse', 'generate' ]
|
||||||
|
);
|
||||||
mockCapabilityConstructor = jasmine.createSpy('capability');
|
mockCapabilityConstructor = jasmine.createSpy('capability');
|
||||||
mockCapabilityInstance = {};
|
mockCapabilityInstance = {};
|
||||||
mockCapabilityService.getCapabilities.andReturn({
|
mockCapabilityService.getCapabilities.andReturn({
|
||||||
@ -48,9 +57,17 @@ define(
|
|||||||
});
|
});
|
||||||
mockCapabilityConstructor.andReturn(mockCapabilityInstance);
|
mockCapabilityConstructor.andReturn(mockCapabilityInstance);
|
||||||
|
|
||||||
|
mockIdentifierService.generate.andCallFake(function (space) {
|
||||||
|
return (space ? (space + ":") : "") +
|
||||||
|
"some-id-" + (idCounter += 1);
|
||||||
|
});
|
||||||
|
|
||||||
testModel = { someKey: "some value" };
|
testModel = { someKey: "some value" };
|
||||||
|
|
||||||
instantiate = new Instantiate(mockCapabilityService);
|
instantiate = new Instantiate(
|
||||||
|
mockCapabilityService,
|
||||||
|
mockIdentifierService
|
||||||
|
);
|
||||||
domainObject = instantiate(testModel);
|
domainObject = instantiate(testModel);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -15,6 +15,9 @@
|
|||||||
"capabilities/PersistenceCapability",
|
"capabilities/PersistenceCapability",
|
||||||
"capabilities/RelationshipCapability",
|
"capabilities/RelationshipCapability",
|
||||||
|
|
||||||
|
"identifiers/Identifier",
|
||||||
|
"identifiers/IdentifierProvider",
|
||||||
|
|
||||||
"models/ModelAggregator",
|
"models/ModelAggregator",
|
||||||
"models/MissingModelDecorator",
|
"models/MissingModelDecorator",
|
||||||
"models/PersistedModelProvider",
|
"models/PersistedModelProvider",
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
"glyph": "f",
|
"glyph": "f",
|
||||||
"category": "contextual",
|
"category": "contextual",
|
||||||
"implementation": "actions/MoveAction.js",
|
"implementation": "actions/MoveAction.js",
|
||||||
"depends": ["locationService", "moveService"]
|
"depends": ["policyService", "locationService", "moveService"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "copy",
|
"key": "copy",
|
||||||
@ -20,7 +20,7 @@
|
|||||||
"glyph": "+",
|
"glyph": "+",
|
||||||
"category": "contextual",
|
"category": "contextual",
|
||||||
"implementation": "actions/CopyAction.js",
|
"implementation": "actions/CopyAction.js",
|
||||||
"depends": ["$log", "locationService", "copyService",
|
"depends": ["$log", "policyService", "locationService", "copyService",
|
||||||
"dialogService", "notificationService"]
|
"dialogService", "notificationService"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -30,7 +30,7 @@
|
|||||||
"glyph": "\u00E8",
|
"glyph": "\u00E8",
|
||||||
"category": "contextual",
|
"category": "contextual",
|
||||||
"implementation": "actions/LinkAction.js",
|
"implementation": "actions/LinkAction.js",
|
||||||
"depends": ["locationService", "linkService"]
|
"depends": ["policyService", "locationService", "linkService"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "follow",
|
"key": "follow",
|
||||||
@ -54,7 +54,11 @@
|
|||||||
"depends": ["contextualize", "$q", "$log"]
|
"depends": ["contextualize", "$q", "$log"]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"controllers": [
|
"policies": [
|
||||||
|
{
|
||||||
|
"category": "action",
|
||||||
|
"implementation": "policies/CrossSpacePolicy.js"
|
||||||
|
}
|
||||||
],
|
],
|
||||||
"capabilities": [
|
"capabilities": [
|
||||||
{
|
{
|
||||||
|
@ -62,6 +62,8 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @private
|
* @private
|
||||||
* @memberof platform/entanglement
|
* @memberof platform/entanglement
|
||||||
|
* @param {PolicyService} policyService the policy service to use to
|
||||||
|
* verify that variants of this action are allowed
|
||||||
* @param {platform/entanglement.LocationService} locationService a
|
* @param {platform/entanglement.LocationService} locationService a
|
||||||
* service to request destinations from the user
|
* service to request destinations from the user
|
||||||
* @param {platform/entanglement.AbstractComposeService} composeService
|
* @param {platform/entanglement.AbstractComposeService} composeService
|
||||||
@ -71,7 +73,14 @@ define(
|
|||||||
* @param {string} [suffix] a string to display in the dialog title;
|
* @param {string} [suffix] a string to display in the dialog title;
|
||||||
* default is "to a new location"
|
* default is "to a new location"
|
||||||
*/
|
*/
|
||||||
function AbstractComposeAction(locationService, composeService, context, verb, suffix) {
|
function AbstractComposeAction(
|
||||||
|
policyService,
|
||||||
|
locationService,
|
||||||
|
composeService,
|
||||||
|
context,
|
||||||
|
verb,
|
||||||
|
suffix
|
||||||
|
) {
|
||||||
if (context.selectedObject) {
|
if (context.selectedObject) {
|
||||||
this.newParent = context.domainObject;
|
this.newParent = context.domainObject;
|
||||||
this.object = context.selectedObject;
|
this.object = context.selectedObject;
|
||||||
@ -83,16 +92,27 @@ define(
|
|||||||
.getCapability('context')
|
.getCapability('context')
|
||||||
.getParent();
|
.getParent();
|
||||||
|
|
||||||
|
this.context = context;
|
||||||
|
this.policyService = policyService;
|
||||||
this.locationService = locationService;
|
this.locationService = locationService;
|
||||||
this.composeService = composeService;
|
this.composeService = composeService;
|
||||||
this.verb = verb || "Compose";
|
this.verb = verb || "Compose";
|
||||||
this.suffix = suffix || "to a new location";
|
this.suffix = suffix || "to a new location";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AbstractComposeAction.prototype.cloneContext = function () {
|
||||||
|
var clone = {}, original = this.context;
|
||||||
|
Object.keys(original).forEach(function (k) {
|
||||||
|
clone[k] = original[k];
|
||||||
|
});
|
||||||
|
return clone;
|
||||||
|
};
|
||||||
|
|
||||||
AbstractComposeAction.prototype.perform = function () {
|
AbstractComposeAction.prototype.perform = function () {
|
||||||
var dialogTitle,
|
var dialogTitle,
|
||||||
label,
|
label,
|
||||||
validateLocation,
|
validateLocation,
|
||||||
|
self = this,
|
||||||
locationService = this.locationService,
|
locationService = this.locationService,
|
||||||
composeService = this.composeService,
|
composeService = this.composeService,
|
||||||
currentParent = this.currentParent,
|
currentParent = this.currentParent,
|
||||||
@ -109,7 +129,11 @@ define(
|
|||||||
label = this.verb + " To";
|
label = this.verb + " To";
|
||||||
|
|
||||||
validateLocation = function (newParent) {
|
validateLocation = function (newParent) {
|
||||||
return composeService.validate(object, newParent);
|
var newContext = self.cloneContext();
|
||||||
|
newContext.selectedObject = object;
|
||||||
|
newContext.domainObject = newParent;
|
||||||
|
return composeService.validate(object, newParent) &&
|
||||||
|
self.policyService.allow("action", self, newContext);
|
||||||
};
|
};
|
||||||
|
|
||||||
return locationService.getLocationFromUser(
|
return locationService.getLocationFromUser(
|
||||||
|
@ -34,18 +34,34 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @memberof platform/entanglement
|
* @memberof platform/entanglement
|
||||||
*/
|
*/
|
||||||
function CopyAction($log, locationService, copyService, dialogService,
|
function CopyAction(
|
||||||
notificationService, context) {
|
$log,
|
||||||
|
policyService,
|
||||||
|
locationService,
|
||||||
|
copyService,
|
||||||
|
dialogService,
|
||||||
|
notificationService,
|
||||||
|
context
|
||||||
|
) {
|
||||||
this.dialog = undefined;
|
this.dialog = undefined;
|
||||||
this.notification = undefined;
|
this.notification = undefined;
|
||||||
this.dialogService = dialogService;
|
this.dialogService = dialogService;
|
||||||
this.notificationService = notificationService;
|
this.notificationService = notificationService;
|
||||||
this.$log = $log;
|
this.$log = $log;
|
||||||
//Extend the behaviour of the Abstract Compose Action
|
//Extend the behaviour of the Abstract Compose Action
|
||||||
AbstractComposeAction.call(this, locationService, copyService,
|
AbstractComposeAction.call(
|
||||||
context, "Duplicate", "to a location");
|
this,
|
||||||
|
policyService,
|
||||||
|
locationService,
|
||||||
|
copyService,
|
||||||
|
context,
|
||||||
|
"Duplicate",
|
||||||
|
"to a location"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CopyAction.prototype = Object.create(AbstractComposeAction.prototype);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates user about progress of copy. Should not be invoked by
|
* Updates user about progress of copy. Should not be invoked by
|
||||||
* client code under any circumstances.
|
* client code under any circumstances.
|
||||||
|
@ -34,10 +34,10 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @memberof platform/entanglement
|
* @memberof platform/entanglement
|
||||||
*/
|
*/
|
||||||
function LinkAction(locationService, linkService, context) {
|
function LinkAction(policyService, locationService, linkService, context) {
|
||||||
AbstractComposeAction.apply(
|
AbstractComposeAction.apply(
|
||||||
this,
|
this,
|
||||||
[locationService, linkService, context, "Link"]
|
[policyService, locationService, linkService, context, "Link"]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,12 +34,11 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
* @memberof platform/entanglement
|
* @memberof platform/entanglement
|
||||||
*/
|
*/
|
||||||
function MoveAction(locationService, moveService, context) {
|
function MoveAction(policyService, locationService, moveService, context) {
|
||||||
AbstractComposeAction.apply(
|
AbstractComposeAction.apply(
|
||||||
this,
|
this,
|
||||||
[locationService, moveService, context, "Move"]
|
[policyService, locationService, moveService, context, "Move"]
|
||||||
);
|
);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MoveAction.prototype = Object.create(AbstractComposeAction.prototype);
|
MoveAction.prototype = Object.create(AbstractComposeAction.prototype);
|
||||||
|
75
platform/entanglement/src/policies/CrossSpacePolicy.js
Normal file
75
platform/entanglement/src/policies/CrossSpacePolicy.js
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var DISALLOWED_ACTIONS = [
|
||||||
|
"move",
|
||||||
|
"copy",
|
||||||
|
"link",
|
||||||
|
"compose"
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This policy prevents performing move/copy/link actions across
|
||||||
|
* different persistence spaces (e.g. linking to an object in
|
||||||
|
* a private space from an object in a public space.)
|
||||||
|
* @memberof {platform/entanglement}
|
||||||
|
* @constructor
|
||||||
|
* @implements {Policy}
|
||||||
|
*/
|
||||||
|
function CrossSpacePolicy() {
|
||||||
|
}
|
||||||
|
|
||||||
|
function lookupSpace(domainObject) {
|
||||||
|
var persistence = domainObject &&
|
||||||
|
domainObject.getCapability("persistence");
|
||||||
|
return persistence && persistence.getSpace();
|
||||||
|
}
|
||||||
|
|
||||||
|
function isCrossSpace(context) {
|
||||||
|
var domainObject = context.domainObject,
|
||||||
|
selectedObject = context.selectedObject,
|
||||||
|
spaces = [ domainObject, selectedObject ].map(lookupSpace);
|
||||||
|
return selectedObject !== undefined &&
|
||||||
|
domainObject !== undefined &&
|
||||||
|
lookupSpace(domainObject) !== lookupSpace(selectedObject);
|
||||||
|
}
|
||||||
|
|
||||||
|
CrossSpacePolicy.prototype.allow = function (action, context) {
|
||||||
|
var key = action.getMetadata().key;
|
||||||
|
|
||||||
|
if (DISALLOWED_ACTIONS.indexOf(key) !== -1) {
|
||||||
|
return !isCrossSpace(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
return CrossSpacePolicy;
|
||||||
|
|
||||||
|
}
|
||||||
|
);
|
@ -34,6 +34,7 @@ define(
|
|||||||
describe("Move/copy/link Actions", function () {
|
describe("Move/copy/link Actions", function () {
|
||||||
|
|
||||||
var action,
|
var action,
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
locationServicePromise,
|
locationServicePromise,
|
||||||
composeService,
|
composeService,
|
||||||
@ -44,6 +45,11 @@ define(
|
|||||||
newParent;
|
newParent;
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
policyService = jasmine.createSpyObj(
|
||||||
|
'policyService',
|
||||||
|
[ 'allow' ]
|
||||||
|
);
|
||||||
|
|
||||||
selectedObjectContextCapability = jasmine.createSpyObj(
|
selectedObjectContextCapability = jasmine.createSpyObj(
|
||||||
'selectedObjectContextCapability',
|
'selectedObjectContextCapability',
|
||||||
[
|
[
|
||||||
@ -87,6 +93,8 @@ define(
|
|||||||
]
|
]
|
||||||
);
|
);
|
||||||
|
|
||||||
|
policyService.allow.andReturn(true);
|
||||||
|
|
||||||
locationService
|
locationService
|
||||||
.getLocationFromUser
|
.getLocationFromUser
|
||||||
.andReturn(locationServicePromise);
|
.andReturn(locationServicePromise);
|
||||||
@ -124,6 +132,7 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
action = new AbstractComposeAction(
|
action = new AbstractComposeAction(
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
composeService,
|
composeService,
|
||||||
context,
|
context,
|
||||||
@ -164,6 +173,30 @@ define(
|
|||||||
expect(composeService.perform)
|
expect(composeService.perform)
|
||||||
.toHaveBeenCalledWith(selectedObject, newParent);
|
.toHaveBeenCalledWith(selectedObject, newParent);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe("provides a validator which", function () {
|
||||||
|
var validator;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
validator = locationService.getLocationFromUser
|
||||||
|
.mostRecentCall.args[2];
|
||||||
|
composeService.validate.andReturn(true);
|
||||||
|
policyService.allow.andReturn(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("is sensitive to policy", function () {
|
||||||
|
expect(validator()).toBe(true);
|
||||||
|
policyService.allow.andReturn(false);
|
||||||
|
expect(validator()).toBe(false);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("is sensitive to service-specific validation", function () {
|
||||||
|
expect(validator()).toBe(true);
|
||||||
|
composeService.validate.andReturn(false);
|
||||||
|
expect(validator()).toBe(false);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -175,6 +208,7 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
action = new AbstractComposeAction(
|
action = new AbstractComposeAction(
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
composeService,
|
composeService,
|
||||||
context,
|
context,
|
||||||
|
@ -34,6 +34,7 @@ define(
|
|||||||
describe("Copy Action", function () {
|
describe("Copy Action", function () {
|
||||||
|
|
||||||
var copyAction,
|
var copyAction,
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
locationServicePromise,
|
locationServicePromise,
|
||||||
copyService,
|
copyService,
|
||||||
@ -50,6 +51,12 @@ define(
|
|||||||
progress = {phase: "copying", totalObjects: 10, processed: 1};
|
progress = {phase: "copying", totalObjects: 10, processed: 1};
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
policyService = jasmine.createSpyObj(
|
||||||
|
'policyService',
|
||||||
|
[ 'allow' ]
|
||||||
|
);
|
||||||
|
policyService.allow.andReturn(true);
|
||||||
|
|
||||||
selectedObjectContextCapability = jasmine.createSpyObj(
|
selectedObjectContextCapability = jasmine.createSpyObj(
|
||||||
'selectedObjectContextCapability',
|
'selectedObjectContextCapability',
|
||||||
[
|
[
|
||||||
@ -142,6 +149,7 @@ define(
|
|||||||
|
|
||||||
copyAction = new CopyAction(
|
copyAction = new CopyAction(
|
||||||
mockLog,
|
mockLog,
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
copyService,
|
copyService,
|
||||||
dialogService,
|
dialogService,
|
||||||
@ -201,6 +209,7 @@ define(
|
|||||||
|
|
||||||
copyAction = new CopyAction(
|
copyAction = new CopyAction(
|
||||||
mockLog,
|
mockLog,
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
copyService,
|
copyService,
|
||||||
dialogService,
|
dialogService,
|
||||||
|
@ -34,6 +34,7 @@ define(
|
|||||||
describe("Link Action", function () {
|
describe("Link Action", function () {
|
||||||
|
|
||||||
var linkAction,
|
var linkAction,
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
locationServicePromise,
|
locationServicePromise,
|
||||||
linkService,
|
linkService,
|
||||||
@ -44,6 +45,12 @@ define(
|
|||||||
newParent;
|
newParent;
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
policyService = jasmine.createSpyObj(
|
||||||
|
'policyService',
|
||||||
|
[ 'allow' ]
|
||||||
|
);
|
||||||
|
policyService.allow.andReturn(true);
|
||||||
|
|
||||||
selectedObjectContextCapability = jasmine.createSpyObj(
|
selectedObjectContextCapability = jasmine.createSpyObj(
|
||||||
'selectedObjectContextCapability',
|
'selectedObjectContextCapability',
|
||||||
[
|
[
|
||||||
@ -102,6 +109,7 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
linkAction = new LinkAction(
|
linkAction = new LinkAction(
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
linkService,
|
linkService,
|
||||||
context
|
context
|
||||||
@ -152,6 +160,7 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
linkAction = new LinkAction(
|
linkAction = new LinkAction(
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
linkService,
|
linkService,
|
||||||
context
|
context
|
||||||
|
@ -34,6 +34,7 @@ define(
|
|||||||
describe("Move Action", function () {
|
describe("Move Action", function () {
|
||||||
|
|
||||||
var moveAction,
|
var moveAction,
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
locationServicePromise,
|
locationServicePromise,
|
||||||
moveService,
|
moveService,
|
||||||
@ -44,6 +45,12 @@ define(
|
|||||||
newParent;
|
newParent;
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
policyService = jasmine.createSpyObj(
|
||||||
|
'policyService',
|
||||||
|
[ 'allow' ]
|
||||||
|
);
|
||||||
|
policyService.allow.andReturn(true);
|
||||||
|
|
||||||
selectedObjectContextCapability = jasmine.createSpyObj(
|
selectedObjectContextCapability = jasmine.createSpyObj(
|
||||||
'selectedObjectContextCapability',
|
'selectedObjectContextCapability',
|
||||||
[
|
[
|
||||||
@ -102,6 +109,7 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
moveAction = new MoveAction(
|
moveAction = new MoveAction(
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
moveService,
|
moveService,
|
||||||
context
|
context
|
||||||
@ -152,6 +160,7 @@ define(
|
|||||||
};
|
};
|
||||||
|
|
||||||
moveAction = new MoveAction(
|
moveAction = new MoveAction(
|
||||||
|
policyService,
|
||||||
locationService,
|
locationService,
|
||||||
moveService,
|
moveService,
|
||||||
context
|
context
|
||||||
|
120
platform/entanglement/test/policies/CrossSpacePolicySpec.js
Normal file
120
platform/entanglement/test/policies/CrossSpacePolicySpec.js
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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,spyOn */
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'../../src/policies/CrossSpacePolicy',
|
||||||
|
'../DomainObjectFactory'
|
||||||
|
],
|
||||||
|
function (CrossSpacePolicy, domainObjectFactory) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
describe("CrossSpacePolicy", function () {
|
||||||
|
var mockAction,
|
||||||
|
testActionMetadata,
|
||||||
|
sameSpaceContext,
|
||||||
|
crossSpaceContext,
|
||||||
|
policy;
|
||||||
|
|
||||||
|
function makeObject(space) {
|
||||||
|
var mockPersistence = jasmine.createSpyObj(
|
||||||
|
'persistence',
|
||||||
|
['getSpace']
|
||||||
|
);
|
||||||
|
mockPersistence.getSpace.andReturn(space);
|
||||||
|
return domainObjectFactory({
|
||||||
|
id: space + ":foo",
|
||||||
|
model: {},
|
||||||
|
capabilities: { persistence: mockPersistence }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testActionMetadata = {};
|
||||||
|
|
||||||
|
// Policy should only call passive methods, so
|
||||||
|
// only define those in mocks.
|
||||||
|
mockAction = jasmine.createSpyObj(
|
||||||
|
'action',
|
||||||
|
[ 'getMetadata' ]
|
||||||
|
);
|
||||||
|
mockAction.getMetadata.andReturn(testActionMetadata);
|
||||||
|
|
||||||
|
sameSpaceContext = {
|
||||||
|
domainObject: makeObject('a'),
|
||||||
|
selectedObject: makeObject('a')
|
||||||
|
};
|
||||||
|
crossSpaceContext = {
|
||||||
|
domainObject: makeObject('a'),
|
||||||
|
selectedObject: makeObject('b')
|
||||||
|
};
|
||||||
|
|
||||||
|
policy = new CrossSpacePolicy();
|
||||||
|
});
|
||||||
|
|
||||||
|
['move', 'copy', 'link', 'compose'].forEach(function (key) {
|
||||||
|
describe("for " + key + " actions", function () {
|
||||||
|
beforeEach(function () {
|
||||||
|
testActionMetadata.key = key;
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows same-space changes", function () {
|
||||||
|
expect(policy.allow(mockAction, sameSpaceContext))
|
||||||
|
.toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("disallows cross-space changes", function () {
|
||||||
|
expect(policy.allow(mockAction, crossSpaceContext))
|
||||||
|
.toBe(false);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows actions with no selectedObject", function () {
|
||||||
|
expect(policy.allow(mockAction, {
|
||||||
|
domainObject: makeObject('a')
|
||||||
|
})).toBe(true);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("for other actions", function () {
|
||||||
|
beforeEach(function () {
|
||||||
|
testActionMetadata.key = "some-other-action";
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows same-space and cross-space changes", function () {
|
||||||
|
expect(policy.allow(mockAction, crossSpaceContext))
|
||||||
|
.toBe(true);
|
||||||
|
expect(policy.allow(mockAction, sameSpaceContext))
|
||||||
|
.toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("allows actions with no selectedObject", function () {
|
||||||
|
expect(policy.allow(mockAction, {
|
||||||
|
domainObject: makeObject('a')
|
||||||
|
})).toBe(true);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -4,6 +4,7 @@
|
|||||||
"actions/GoToOriginalAction",
|
"actions/GoToOriginalAction",
|
||||||
"actions/LinkAction",
|
"actions/LinkAction",
|
||||||
"actions/MoveAction",
|
"actions/MoveAction",
|
||||||
|
"policies/CrossSpacePolicy",
|
||||||
"services/CopyService",
|
"services/CopyService",
|
||||||
"services/LinkService",
|
"services/LinkService",
|
||||||
"services/MoveService",
|
"services/MoveService",
|
||||||
|
@ -38,7 +38,8 @@ define(
|
|||||||
* @constructor
|
* @constructor
|
||||||
*/
|
*/
|
||||||
function WorkerService($window, workers) {
|
function WorkerService($window, workers) {
|
||||||
var workerUrls = {};
|
var workerUrls = {},
|
||||||
|
sharedWorkers = {};
|
||||||
|
|
||||||
function addWorker(worker) {
|
function addWorker(worker) {
|
||||||
var key = worker.key;
|
var key = worker.key;
|
||||||
@ -48,12 +49,15 @@ define(
|
|||||||
worker.bundle.sources,
|
worker.bundle.sources,
|
||||||
worker.scriptUrl
|
worker.scriptUrl
|
||||||
].join("/");
|
].join("/");
|
||||||
|
sharedWorkers[key] = worker.shared;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
(workers || []).forEach(addWorker);
|
(workers || []).forEach(addWorker);
|
||||||
this.workerUrls = workerUrls;
|
this.workerUrls = workerUrls;
|
||||||
|
this.sharedWorkers = sharedWorkers;
|
||||||
this.Worker = $window.Worker;
|
this.Worker = $window.Worker;
|
||||||
|
this.SharedWorker = $window.SharedWorker;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -61,12 +65,17 @@ define(
|
|||||||
* that has been registered under the `workers` category
|
* that has been registered under the `workers` category
|
||||||
* of extension.
|
* of extension.
|
||||||
*
|
*
|
||||||
|
* This will return either a Worker or a SharedWorker,
|
||||||
|
* depending on whether a `shared` flag has been specified
|
||||||
|
* on the the extension definition for the referenced worker.
|
||||||
|
*
|
||||||
* @param {string} key symbolic identifier for the worker
|
* @param {string} key symbolic identifier for the worker
|
||||||
* @returns {Worker} the running Worker
|
* @returns {Worker | SharedWorker} the running Worker
|
||||||
*/
|
*/
|
||||||
WorkerService.prototype.run = function (key) {
|
WorkerService.prototype.run = function (key) {
|
||||||
var scriptUrl = this.workerUrls[key],
|
var scriptUrl = this.workerUrls[key],
|
||||||
Worker = this.Worker;
|
Worker = this.sharedWorkers[key] ?
|
||||||
|
this.SharedWorker : this.Worker;
|
||||||
return scriptUrl && Worker && new Worker(scriptUrl);
|
return scriptUrl && Worker && new Worker(scriptUrl);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -30,10 +30,14 @@ define(
|
|||||||
var mockWindow,
|
var mockWindow,
|
||||||
testWorkers,
|
testWorkers,
|
||||||
mockWorker,
|
mockWorker,
|
||||||
|
mockSharedWorker,
|
||||||
service;
|
service;
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
mockWindow = jasmine.createSpyObj('$window', ['Worker']);
|
mockWindow = jasmine.createSpyObj(
|
||||||
|
'$window',
|
||||||
|
['Worker', 'SharedWorker']
|
||||||
|
);
|
||||||
testWorkers = [
|
testWorkers = [
|
||||||
{
|
{
|
||||||
key: 'abc',
|
key: 'abc',
|
||||||
@ -49,11 +53,19 @@ define(
|
|||||||
key: 'xyz',
|
key: 'xyz',
|
||||||
scriptUrl: 'bad.js',
|
scriptUrl: 'bad.js',
|
||||||
bundle: { path: 'bad', sources: 'bad' }
|
bundle: { path: 'bad', sources: 'bad' }
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'a-shared-worker',
|
||||||
|
shared: true,
|
||||||
|
scriptUrl: 'c.js',
|
||||||
|
bundle: { path: 'a', sources: 'b' }
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
mockWorker = {};
|
mockWorker = {};
|
||||||
|
mockSharedWorker = {};
|
||||||
|
|
||||||
mockWindow.Worker.andReturn(mockWorker);
|
mockWindow.Worker.andReturn(mockWorker);
|
||||||
|
mockWindow.SharedWorker.andReturn(mockSharedWorker);
|
||||||
|
|
||||||
service = new WorkerService(mockWindow, testWorkers);
|
service = new WorkerService(mockWindow, testWorkers);
|
||||||
});
|
});
|
||||||
@ -68,6 +80,12 @@ define(
|
|||||||
expect(mockWindow.Worker).toHaveBeenCalledWith('x/y/z.js');
|
expect(mockWindow.Worker).toHaveBeenCalledWith('x/y/z.js');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("allows workers to be shared", function () {
|
||||||
|
expect(service.run('a-shared-worker')).toBe(mockSharedWorker);
|
||||||
|
expect(mockWindow.SharedWorker)
|
||||||
|
.toHaveBeenCalledWith('a/b/c.js');
|
||||||
|
});
|
||||||
|
|
||||||
it("returns undefined for unknown workers", function () {
|
it("returns undefined for unknown workers", function () {
|
||||||
expect(service.run('def')).toBeUndefined();
|
expect(service.run('def')).toBeUndefined();
|
||||||
});
|
});
|
||||||
|
@ -20,15 +20,15 @@
|
|||||||
at runtime from the About dialog for additional information.
|
at runtime from the About dialog for additional information.
|
||||||
-->
|
-->
|
||||||
<div class="l-time-display l-digital l-timer s-timer" ng-controller="TimerController as timer">
|
<div class="l-time-display l-digital l-timer s-timer" ng-controller="TimerController as timer">
|
||||||
<div class="l-elem-wrapper">
|
<div class="l-elem-wrapper l-flex-row">
|
||||||
<a
|
<a
|
||||||
ng-click="timer.clickButton()"
|
ng-click="timer.clickButton()"
|
||||||
title="{{timer.buttonText()}}"
|
title="{{timer.buttonText()}}"
|
||||||
class="l-elem l-btn s-btn s-icon-btn s-very-subtle vsm control"
|
class="flex-elem s-icon-btn control"
|
||||||
>
|
>
|
||||||
<span class="ui-symbol icon">{{timer.buttonGlyph()}}</span>
|
{{timer.buttonGlyph()}}
|
||||||
</a>
|
</a>
|
||||||
<span class="l-elem l-value">
|
<span class="flex-elem l-value">
|
||||||
<span class="ui-symbol direction">{{timer.sign()}}</span>
|
<span class="ui-symbol direction">{{timer.sign()}}</span>
|
||||||
<span
|
<span
|
||||||
class="value"
|
class="value"
|
||||||
@ -36,7 +36,6 @@
|
|||||||
>{{timer.text() || "--:--:--"}}
|
>{{timer.text() || "--:--:--"}}
|
||||||
</span>
|
</span>
|
||||||
</span>
|
</span>
|
||||||
<span ng-controller="RefreshingController">
|
<span ng-controller="RefreshingController"></span>
|
||||||
</span>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
@ -63,7 +63,7 @@
|
|||||||
ng-show="representation.showControls"
|
ng-show="representation.showControls"
|
||||||
ng-if="axes[1].options.length > 0">
|
ng-if="axes[1].options.length > 0">
|
||||||
<div class='form-control shell select'>
|
<div class='form-control shell select'>
|
||||||
<select class="form-control input shell select"
|
<select class="form-control input shell"
|
||||||
ng-model="axes[1].active"
|
ng-model="axes[1].active"
|
||||||
ng-options="option.name for option in axes[1].options">
|
ng-options="option.name for option in axes[1].options">
|
||||||
</select>
|
</select>
|
||||||
@ -161,12 +161,11 @@
|
|||||||
{{axes[0].active.name}}
|
{{axes[0].active.name}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class="gl-plot-x-options gl-plot-local-controls"
|
<div class="gl-plot-x-options gl-plot-local-controls"
|
||||||
ng-show="representation.showControls"
|
ng-show="representation.showControls"
|
||||||
ng-if="axes[0].options.length > 0">
|
ng-if="axes[0].options.length > 0">
|
||||||
<div class='form-control shell select'>
|
<div class='form-control shell select'>
|
||||||
<select class="form-control input shell select"
|
<select class="form-control input shell"
|
||||||
ng-model="axes[0].active"
|
ng-model="axes[0].active"
|
||||||
ng-options="option.name for option in axes[0].options">
|
ng-options="option.name for option in axes[0].options">
|
||||||
</select>
|
</select>
|
||||||
|
@ -57,7 +57,7 @@
|
|||||||
"properties": [
|
"properties": [
|
||||||
{
|
{
|
||||||
"name": "Start date/time",
|
"name": "Start date/time",
|
||||||
"control": "datetime",
|
"control": "timeline-datetime",
|
||||||
"required": true,
|
"required": true,
|
||||||
"property": [ "start" ],
|
"property": [ "start" ],
|
||||||
"options": [ "SET" ]
|
"options": [ "SET" ]
|
||||||
@ -83,7 +83,7 @@
|
|||||||
"properties": [
|
"properties": [
|
||||||
{
|
{
|
||||||
"name": "Start date/time",
|
"name": "Start date/time",
|
||||||
"control": "datetime",
|
"control": "timeline-datetime",
|
||||||
"required": true,
|
"required": true,
|
||||||
"property": [ "start" ],
|
"property": [ "start" ],
|
||||||
"options": [ "SET" ]
|
"options": [ "SET" ]
|
||||||
@ -217,6 +217,19 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"stylesheets": [
|
||||||
|
{
|
||||||
|
"stylesheetUrl": "css/timeline.css"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"stylesheetUrl": "css/timeline-espresso.css",
|
||||||
|
"theme": "espresso"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"stylesheetUrl": "css/timeline-snow.css",
|
||||||
|
"theme": "snow"
|
||||||
|
}
|
||||||
|
],
|
||||||
"representations": [
|
"representations": [
|
||||||
{
|
{
|
||||||
"key": "gantt",
|
"key": "gantt",
|
||||||
@ -258,7 +271,7 @@
|
|||||||
],
|
],
|
||||||
"controls": [
|
"controls": [
|
||||||
{
|
{
|
||||||
"key": "datetime",
|
"key": "timeline-datetime",
|
||||||
"templateUrl": "templates/controls/datetime.html"
|
"templateUrl": "templates/controls/datetime.html"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
26
platform/features/timeline/res/config.rb
Executable file
26
platform/features/timeline/res/config.rb
Executable file
@ -0,0 +1,26 @@
|
|||||||
|
# Require any additional compass plugins here.
|
||||||
|
# require "compass-growl"
|
||||||
|
|
||||||
|
# Set this to the root of your project when deployed:
|
||||||
|
http_path = "/"
|
||||||
|
css_dir = "css"
|
||||||
|
sass_dir = "sass"
|
||||||
|
images_dir = "images"
|
||||||
|
javascripts_dir = "js"
|
||||||
|
|
||||||
|
# You can select your preferred output style here (can be overridden via the command line):
|
||||||
|
# :expanded, :compressed, :nested
|
||||||
|
output_style = :nested
|
||||||
|
|
||||||
|
# To enable relative paths to assets via compass helper functions. Uncomment:
|
||||||
|
relative_assets = true
|
||||||
|
|
||||||
|
# To disable debugging comments that display the original location of your selectors. Uncomment:
|
||||||
|
# line_comments = false
|
||||||
|
|
||||||
|
|
||||||
|
# If you prefer the indented syntax, you might want to regenerate this
|
||||||
|
# project again passing --syntax sass, or you can uncomment this:
|
||||||
|
# preferred_syntax = :sass
|
||||||
|
# and then run:
|
||||||
|
# sass-convert -R --from scss --to sass vfn_platform/static/sass scss && rm -rf sass && mv scss sass
|
291
platform/features/timeline/res/css/timeline-espresso.css
Normal file
291
platform/features/timeline/res/css/timeline-espresso.css
Normal file
@ -0,0 +1,291 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/************************** FEATURES */
|
||||||
|
/************************** VERY INFLUENTIAL GLOBAL DIMENSIONS */
|
||||||
|
/************************** RATIOS */
|
||||||
|
/************************** LAYOUT */
|
||||||
|
/************************** CONTROLS */
|
||||||
|
/************************** PATHS */
|
||||||
|
/************************** TIMINGS */
|
||||||
|
/************************** LIMITS */
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*********************************************** CONTROLS, FORM ELEMENTS */
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/* line 26, ../sass/_timeline-thematic.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend .l-legend-items {
|
||||||
|
color: #999; }
|
||||||
|
|
||||||
|
/* line 36, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar {
|
||||||
|
color: #fff;
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #7777bb), color-stop(100%, #5555aa));
|
||||||
|
background-image: -moz-linear-gradient(#7777bb, #5555aa);
|
||||||
|
background-image: -webkit-linear-gradient(#7777bb, #5555aa);
|
||||||
|
background-image: linear-gradient(#7777bb, #5555aa);
|
||||||
|
-moz-border-radius: 3px;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
-moz-box-shadow: rgba(0, 0, 0, 0.4) 0 1px 3px;
|
||||||
|
-webkit-box-shadow: rgba(0, 0, 0, 0.4) 0 1px 3px;
|
||||||
|
box-shadow: rgba(0, 0, 0, 0.4) 0 1px 3px; }
|
||||||
|
/* line 41, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar.expanded {
|
||||||
|
-moz-border-radius-topleft: 3px;
|
||||||
|
-webkit-border-top-left-radius: 3px;
|
||||||
|
border-top-left-radius: 3px;
|
||||||
|
-moz-border-radius-topright: 3px;
|
||||||
|
-webkit-border-top-right-radius: 3px;
|
||||||
|
border-top-right-radius: 3px;
|
||||||
|
-moz-border-radius-bottomleft: 0;
|
||||||
|
-webkit-border-bottom-left-radius: 0;
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
-moz-border-radius-bottomright: 0;
|
||||||
|
-webkit-border-bottom-right-radius: 0;
|
||||||
|
border-bottom-right-radius: 0; }
|
||||||
|
/* line 45, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar.leaf {
|
||||||
|
-moz-border-radius-topleft: 0;
|
||||||
|
-webkit-border-top-left-radius: 0;
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
-moz-border-radius-topright: 0;
|
||||||
|
-webkit-border-top-right-radius: 0;
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
-moz-border-radius-bottomleft: 3px;
|
||||||
|
-webkit-border-bottom-left-radius: 3px;
|
||||||
|
border-bottom-left-radius: 3px;
|
||||||
|
-moz-border-radius-bottomright: 3px;
|
||||||
|
-webkit-border-bottom-right-radius: 3px;
|
||||||
|
border-bottom-right-radius: 3px; }
|
||||||
|
/* line 49, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar .s-toggle {
|
||||||
|
color: #0099cc; }
|
||||||
|
|
||||||
|
/* line 57, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-tabular .l-header .l-cols .l-col {
|
||||||
|
border-left: 1px solid #666666; }
|
||||||
|
/* line 65, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-tabular .l-pane-l .l-cols .s-label .ui-symbol.icon {
|
||||||
|
color: #8594ff; }
|
||||||
|
|
||||||
|
/* line 74, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-timeline-gantt .bar:hover {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #9999cc), color-stop(100%, #7777bb));
|
||||||
|
background-image: -moz-linear-gradient(#9999cc, #7777bb);
|
||||||
|
background-image: -webkit-linear-gradient(#9999cc, #7777bb);
|
||||||
|
background-image: linear-gradient(#9999cc, #7777bb); }
|
||||||
|
|
||||||
|
/* line 81, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline {
|
||||||
|
font-size: 0.75rem; }
|
||||||
|
/* line 83, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-header {
|
||||||
|
background-color: #404040; }
|
||||||
|
/* line 86, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane {
|
||||||
|
border-bottom: 1px solid #4d4d4d;
|
||||||
|
line-height: 20px; }
|
||||||
|
/* line 89, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.exceeded {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -moz-linear-gradient(135deg, rgba(255, 255, 255, 0.05) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.05) 50%, rgba(255, 255, 255, 0.05) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: -webkit-linear-gradient(135deg, rgba(255, 255, 255, 0.05) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.05) 50%, rgba(255, 255, 255, 0.05) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.05) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.05) 50%, rgba(255, 255, 255, 0.05) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-repeat: repeat;
|
||||||
|
background-size: 22px 22px; }
|
||||||
|
/* line 93, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.selected {
|
||||||
|
background-color: #222;
|
||||||
|
color: #ccc; }
|
||||||
|
/* line 97, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.selected .s-timeline-gantt .bar {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #e6e6e6), color-stop(100%, #cccccc));
|
||||||
|
background-image: -moz-linear-gradient(#e6e6e6, #cccccc);
|
||||||
|
background-image: -webkit-linear-gradient(#e6e6e6, #cccccc);
|
||||||
|
background-image: linear-gradient(#e6e6e6, #cccccc);
|
||||||
|
color: #333; }
|
||||||
|
/* line 103, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.drop-into {
|
||||||
|
background-color: rgba(85, 85, 170, 0.7); }
|
||||||
|
/* line 105, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.drop-into .s-timeline-gantt {
|
||||||
|
opacity: 0.7; }
|
||||||
|
/* line 109, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.drop-after {
|
||||||
|
background-color: rgba(0, 0, 0, 0.2);
|
||||||
|
border-bottom-color: #5555aa; }
|
||||||
|
/* line 115, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-ticks {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -moz-linear-gradient(0deg, #595959 1px, rgba(0, 0, 0, 0) 1px, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: -webkit-linear-gradient(0deg, #595959 1px, rgba(0, 0, 0, 0) 1px, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: linear-gradient(90deg, #595959 1px, rgba(0, 0, 0, 0) 1px, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-repeat: repeat-x; }
|
||||||
|
/* line 118, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-hover-btns-holder {
|
||||||
|
-moz-user-select: -moz-none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -moz-linear-gradient(180deg, #404040, #404040 70%, rgba(64, 64, 64, 0) 100%);
|
||||||
|
background-image: -webkit-linear-gradient(180deg, #404040, #404040 70%, rgba(64, 64, 64, 0) 100%);
|
||||||
|
background-image: linear-gradient(-90deg, #404040, #404040 70%, rgba(64, 64, 64, 0) 100%); }
|
||||||
|
/* line 124, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-hover-btns-holder .s-btn {
|
||||||
|
height: 16px;
|
||||||
|
line-height: 16px; }
|
||||||
|
/* line 127, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-hover-btns-holder .s-btn .icon {
|
||||||
|
font-size: 0.7rem !important; }
|
||||||
|
/* line 134, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .l-timeline-resource-graph .l-graph {
|
||||||
|
background: rgba(0, 0, 0, 0.2); }
|
||||||
|
/* line 137, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .l-timeline-resource-graph .l-title {
|
||||||
|
color: #999; }
|
||||||
|
|
||||||
|
/* line 143, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-swimlane {
|
||||||
|
cursor: pointer; }
|
||||||
|
/* line 145, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-swimlane .t-object-label {
|
||||||
|
-moz-border-radius: 3px;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
cursor: move;
|
||||||
|
padding: 2px 5px; }
|
||||||
|
/* line 149, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-swimlane .t-object-label:hover {
|
||||||
|
background: rgba(153, 153, 153, 0.3);
|
||||||
|
color: #cccccc; }
|
291
platform/features/timeline/res/css/timeline-snow.css
Normal file
291
platform/features/timeline/res/css/timeline-snow.css
Normal file
@ -0,0 +1,291 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/************************** FEATURES */
|
||||||
|
/************************** VERY INFLUENTIAL GLOBAL DIMENSIONS */
|
||||||
|
/************************** RATIOS */
|
||||||
|
/************************** LAYOUT */
|
||||||
|
/************************** CONTROLS */
|
||||||
|
/************************** PATHS */
|
||||||
|
/************************** TIMINGS */
|
||||||
|
/************************** LIMITS */
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*********************************************** CONTROLS, FORM ELEMENTS */
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/* line 26, ../sass/_timeline-thematic.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend .l-legend-items {
|
||||||
|
color: #666; }
|
||||||
|
|
||||||
|
/* line 36, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar {
|
||||||
|
color: #fff;
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #7777bb), color-stop(100%, #5555aa));
|
||||||
|
background-image: -moz-linear-gradient(#7777bb, #5555aa);
|
||||||
|
background-image: -webkit-linear-gradient(#7777bb, #5555aa);
|
||||||
|
background-image: linear-gradient(#7777bb, #5555aa);
|
||||||
|
-moz-border-radius: 4px;
|
||||||
|
-webkit-border-radius: 4px;
|
||||||
|
border-radius: 4px;
|
||||||
|
-moz-box-shadow: rgba(0, 0, 0, 0.1) 0 1px 3px;
|
||||||
|
-webkit-box-shadow: rgba(0, 0, 0, 0.1) 0 1px 3px;
|
||||||
|
box-shadow: rgba(0, 0, 0, 0.1) 0 1px 3px; }
|
||||||
|
/* line 41, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar.expanded {
|
||||||
|
-moz-border-radius-topleft: 4px;
|
||||||
|
-webkit-border-top-left-radius: 4px;
|
||||||
|
border-top-left-radius: 4px;
|
||||||
|
-moz-border-radius-topright: 4px;
|
||||||
|
-webkit-border-top-right-radius: 4px;
|
||||||
|
border-top-right-radius: 4px;
|
||||||
|
-moz-border-radius-bottomleft: 0;
|
||||||
|
-webkit-border-bottom-left-radius: 0;
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
-moz-border-radius-bottomright: 0;
|
||||||
|
-webkit-border-bottom-right-radius: 0;
|
||||||
|
border-bottom-right-radius: 0; }
|
||||||
|
/* line 45, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar.leaf {
|
||||||
|
-moz-border-radius-topleft: 0;
|
||||||
|
-webkit-border-top-left-radius: 0;
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
-moz-border-radius-topright: 0;
|
||||||
|
-webkit-border-top-right-radius: 0;
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
-moz-border-radius-bottomleft: 4px;
|
||||||
|
-webkit-border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
-moz-border-radius-bottomright: 4px;
|
||||||
|
-webkit-border-bottom-right-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px; }
|
||||||
|
/* line 49, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-gantt .bar .s-toggle {
|
||||||
|
color: #0099cc; }
|
||||||
|
|
||||||
|
/* line 57, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-tabular .l-header .l-cols .l-col {
|
||||||
|
border-left: 1px solid #c9c9c9; }
|
||||||
|
/* line 65, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline-tabular .l-pane-l .l-cols .s-label .ui-symbol.icon {
|
||||||
|
color: #8594ff; }
|
||||||
|
|
||||||
|
/* line 74, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-timeline-gantt .bar:hover {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #9999cc), color-stop(100%, #7777bb));
|
||||||
|
background-image: -moz-linear-gradient(#9999cc, #7777bb);
|
||||||
|
background-image: -webkit-linear-gradient(#9999cc, #7777bb);
|
||||||
|
background-image: linear-gradient(#9999cc, #7777bb); }
|
||||||
|
|
||||||
|
/* line 81, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline {
|
||||||
|
font-size: 0.75rem; }
|
||||||
|
/* line 83, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-header {
|
||||||
|
background-color: #efefef; }
|
||||||
|
/* line 86, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane {
|
||||||
|
border-bottom: 1px solid #e3e3e3;
|
||||||
|
line-height: 20px; }
|
||||||
|
/* line 89, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.exceeded {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -moz-linear-gradient(135deg, rgba(255, 255, 255, 0.05) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.05) 50%, rgba(255, 255, 255, 0.05) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: -webkit-linear-gradient(135deg, rgba(255, 255, 255, 0.05) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.05) 50%, rgba(255, 255, 255, 0.05) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.05) 25%, rgba(0, 0, 0, 0) 25%, rgba(0, 0, 0, 0) 50%, rgba(255, 255, 255, 0.05) 50%, rgba(255, 255, 255, 0.05) 75%, rgba(0, 0, 0, 0) 75%, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-repeat: repeat;
|
||||||
|
background-size: 22px 22px; }
|
||||||
|
/* line 93, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.selected {
|
||||||
|
background-color: rgba(85, 85, 170, 0.25);
|
||||||
|
color: #4d4d4d; }
|
||||||
|
/* line 97, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.selected .s-timeline-gantt .bar {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #7777bb), color-stop(100%, #5555aa));
|
||||||
|
background-image: -moz-linear-gradient(#7777bb, #5555aa);
|
||||||
|
background-image: -webkit-linear-gradient(#7777bb, #5555aa);
|
||||||
|
background-image: linear-gradient(#7777bb, #5555aa);
|
||||||
|
color: #fff; }
|
||||||
|
/* line 103, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.drop-into {
|
||||||
|
background-color: rgba(85, 85, 170, 0.7); }
|
||||||
|
/* line 105, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.drop-into .s-timeline-gantt {
|
||||||
|
opacity: 0.7; }
|
||||||
|
/* line 109, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-swimlane.drop-after {
|
||||||
|
background-color: rgba(0, 0, 0, 0.2);
|
||||||
|
border-bottom-color: #5555aa; }
|
||||||
|
/* line 115, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-ticks {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -moz-linear-gradient(0deg, #d6d6d6 1px, rgba(0, 0, 0, 0) 1px, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: -webkit-linear-gradient(0deg, #d6d6d6 1px, rgba(0, 0, 0, 0) 1px, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-image: linear-gradient(90deg, #d6d6d6 1px, rgba(0, 0, 0, 0) 1px, rgba(0, 0, 0, 0) 100%);
|
||||||
|
background-repeat: repeat-x; }
|
||||||
|
/* line 118, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-hover-btns-holder {
|
||||||
|
-moz-user-select: -moz-none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 100%;
|
||||||
|
background-image: -moz-linear-gradient(180deg, #efefef, #efefef 70%, rgba(239, 239, 239, 0) 100%);
|
||||||
|
background-image: -webkit-linear-gradient(180deg, #efefef, #efefef 70%, rgba(239, 239, 239, 0) 100%);
|
||||||
|
background-image: linear-gradient(-90deg, #efefef, #efefef 70%, rgba(239, 239, 239, 0) 100%); }
|
||||||
|
/* line 124, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-hover-btns-holder .s-btn {
|
||||||
|
height: 16px;
|
||||||
|
line-height: 16px; }
|
||||||
|
/* line 127, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .s-hover-btns-holder .s-btn .icon {
|
||||||
|
font-size: 0.7rem !important; }
|
||||||
|
/* line 134, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .l-timeline-resource-graph .l-graph {
|
||||||
|
background: rgba(0, 0, 0, 0.05); }
|
||||||
|
/* line 137, ../sass/_timeline-thematic.scss */
|
||||||
|
.s-timeline .l-timeline-resource-graph .l-title {
|
||||||
|
color: #666; }
|
||||||
|
|
||||||
|
/* line 143, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-swimlane {
|
||||||
|
cursor: pointer; }
|
||||||
|
/* line 145, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-swimlane .t-object-label {
|
||||||
|
-moz-border-radius: 4px;
|
||||||
|
-webkit-border-radius: 4px;
|
||||||
|
border-radius: 4px;
|
||||||
|
cursor: move;
|
||||||
|
padding: 2px 5px; }
|
||||||
|
/* line 149, ../sass/_timeline-thematic.scss */
|
||||||
|
.edit-mode .s-swimlane .t-object-label:hover {
|
||||||
|
background: rgba(102, 102, 102, 0.3);
|
||||||
|
color: #333333; }
|
565
platform/features/timeline/res/css/timeline.css
Normal file
565
platform/features/timeline/res/css/timeline.css
Normal file
@ -0,0 +1,565 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/************************** FEATURES */
|
||||||
|
/************************** VERY INFLUENTIAL GLOBAL DIMENSIONS */
|
||||||
|
/************************** RATIOS */
|
||||||
|
/************************** LAYOUT */
|
||||||
|
/************************** CONTROLS */
|
||||||
|
/************************** PATHS */
|
||||||
|
/************************** TIMINGS */
|
||||||
|
/************************** LIMITS */
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*********************************************** CONTROLS, FORM ELEMENTS */
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/* line 1, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt {
|
||||||
|
position: absolute;
|
||||||
|
top: 2px;
|
||||||
|
bottom: 2px; }
|
||||||
|
/* line 5, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar {
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
height: 17px;
|
||||||
|
line-height: 19px;
|
||||||
|
padding: 0 5px; }
|
||||||
|
/* line 11, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span {
|
||||||
|
display: inline; }
|
||||||
|
/* line 15, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.s-activity-type.timeline:before {
|
||||||
|
content: "S"; }
|
||||||
|
/* line 20, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.s-activity-type.activity:before {
|
||||||
|
content: "A"; }
|
||||||
|
/* line 25, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.s-title {
|
||||||
|
text-shadow: rgba(0, 0, 0, 0.1) 0 1px 2px; }
|
||||||
|
/* line 28, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.duration {
|
||||||
|
left: auto;
|
||||||
|
opacity: 0.75;
|
||||||
|
right: 0;
|
||||||
|
text-align: right;
|
||||||
|
width: 60px; }
|
||||||
|
/* line 35, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.handle {
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
height: auto;
|
||||||
|
width: 15px; }
|
||||||
|
/* line 40, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.handle.left {
|
||||||
|
right: auto; }
|
||||||
|
/* line 43, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.handle.middle {
|
||||||
|
right: 15px;
|
||||||
|
left: 15px;
|
||||||
|
width: auto; }
|
||||||
|
/* line 48, ../sass/_activities.scss */
|
||||||
|
.l-timeline-gantt .bar span.handle.right {
|
||||||
|
right: 0;
|
||||||
|
left: auto; }
|
||||||
|
|
||||||
|
/* line 58, ../sass/_activities.scss */
|
||||||
|
.edit-mode .s-timeline-gantt .handle {
|
||||||
|
cursor: col-resize; }
|
||||||
|
/* line 60, ../sass/_activities.scss */
|
||||||
|
.edit-mode .s-timeline-gantt .handle.mid {
|
||||||
|
cursor: ew-resize; }
|
||||||
|
|
||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
/* line 23, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto; }
|
||||||
|
/* line 26, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto; }
|
||||||
|
/* line 29, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane .l-width-control {
|
||||||
|
position: relative; }
|
||||||
|
/* line 33, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane .l-swimlanes-holder {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
top: 31px; }
|
||||||
|
/* line 40, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.s-timeline-tabular .t-pane-v {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto; }
|
||||||
|
/* line 43, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.s-timeline-tabular .t-pane-v.l-tabular-l {
|
||||||
|
right: auto;
|
||||||
|
width: 266px; }
|
||||||
|
/* line 48, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.s-timeline-tabular .t-pane-v.l-tabular-r {
|
||||||
|
overflow-x: auto;
|
||||||
|
overflow-y: hidden;
|
||||||
|
left: 266px; }
|
||||||
|
/* line 52, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.s-timeline-tabular .t-pane-v.l-tabular-r .l-width {
|
||||||
|
overflow: visible;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
min-width: 590px;
|
||||||
|
width: 100%; }
|
||||||
|
/* line 60, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-gantt .l-swimlanes-holder {
|
||||||
|
overflow-x: hidden;
|
||||||
|
overflow-y: scroll; }
|
||||||
|
/* line 64, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend {
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
padding: 5px 0;
|
||||||
|
white-space: nowrap; }
|
||||||
|
/* line 69, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend .l-legend-items {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
overflow-x: hidden;
|
||||||
|
overflow-y: auto;
|
||||||
|
top: 25px; }
|
||||||
|
/* line 74, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend .legend-item {
|
||||||
|
display: block;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap; }
|
||||||
|
/* line 81, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend .legend-item .color-swatch {
|
||||||
|
vertical-align: baseline; }
|
||||||
|
/* line 84, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-legend .legend-item .title-label {
|
||||||
|
vertical-align: baseline; }
|
||||||
|
/* line 93, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graphs-holder {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
bottom: 10px; }
|
||||||
|
/* line 97, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graphs-holder .l-graphs {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
overflow-x: hidden;
|
||||||
|
overflow-y: scroll; }
|
||||||
|
/* line 102, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graphs-holder .l-graph-labels-holder {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
overflow: hidden;
|
||||||
|
right: auto;
|
||||||
|
width: 400px; }
|
||||||
|
/* line 110, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-scroll-control {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
overflow-x: scroll;
|
||||||
|
overflow-y: hidden;
|
||||||
|
top: auto;
|
||||||
|
right: 10px;
|
||||||
|
height: 10px; }
|
||||||
|
/* line 116, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-scroll-control .l-width-control {
|
||||||
|
height: 10px; }
|
||||||
|
/* line 121, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph,
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph-labels {
|
||||||
|
height: 80px;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
position: relative; }
|
||||||
|
/* line 128, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-title {
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
top: 5px;
|
||||||
|
left: 5px;
|
||||||
|
position: absolute; }
|
||||||
|
/* line 134, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph {
|
||||||
|
width: 100%; }
|
||||||
|
/* line 137, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph .l-graph-area canvas {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%; }
|
||||||
|
/* line 144, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph-labels {
|
||||||
|
z-index: 10; }
|
||||||
|
/* line 148, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph-area {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
top: 20px;
|
||||||
|
bottom: 5px; }
|
||||||
|
/* line 151, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph-area .l-labels-holder {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
left: 5px; }
|
||||||
|
/* line 154, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.t-pane-h.l-timeline-resource-graph .l-graph-area .l-labels-holder .tick-label.tick-label-y {
|
||||||
|
text-align: left; }
|
||||||
|
/* line 162, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.l-pane-l {
|
||||||
|
right: auto;
|
||||||
|
min-width: 50px;
|
||||||
|
max-width: 90%;
|
||||||
|
width: 30%; }
|
||||||
|
/* line 169, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.l-pane-r {
|
||||||
|
left: 0; }
|
||||||
|
/* line 172, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.l-pane-r:hover .l-hover-btns-holder {
|
||||||
|
-moz-transition-property: opacity, background-color, border-color, color;
|
||||||
|
-o-transition-property: opacity, background-color, border-color, color;
|
||||||
|
-webkit-transition-property: opacity, background-color, border-color, color;
|
||||||
|
transition-property: opacity, background-color, border-color, color;
|
||||||
|
-moz-transition-duration: 100ms;
|
||||||
|
-o-transition-duration: 100ms;
|
||||||
|
-webkit-transition-duration: 100ms;
|
||||||
|
transition-duration: 100ms;
|
||||||
|
-moz-transition-timing-function: ease-in-out;
|
||||||
|
-o-transition-timing-function: ease-in-out;
|
||||||
|
-webkit-transition-timing-function: ease-in-out;
|
||||||
|
transition-timing-function: ease-in-out;
|
||||||
|
-moz-transition-delay: 0;
|
||||||
|
-o-transition-delay: 0;
|
||||||
|
-webkit-transition-delay: 0;
|
||||||
|
transition-delay: 0;
|
||||||
|
opacity: 1; }
|
||||||
|
/* line 179, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.l-pane-top {
|
||||||
|
bottom: 30%; }
|
||||||
|
/* line 182, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-timeline-pane.l-pane-btm {
|
||||||
|
top: auto;
|
||||||
|
min-height: 20px;
|
||||||
|
max-height: 80%;
|
||||||
|
height: 30%; }
|
||||||
|
/* line 190, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-swimlane {
|
||||||
|
height: 21px;
|
||||||
|
position: relative; }
|
||||||
|
/* line 196, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .s-timeline-tabular .l-header,
|
||||||
|
.l-timeline-holder .s-timeline-gantt .l-header {
|
||||||
|
overflow: visible;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
bottom: auto;
|
||||||
|
height: 30px; }
|
||||||
|
/* line 201, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .s-timeline-tabular .l-header .l-header-elem,
|
||||||
|
.l-timeline-holder .s-timeline-gantt .l-header .l-header-elem {
|
||||||
|
overflow: visible;
|
||||||
|
position: absolute;
|
||||||
|
top: 5px;
|
||||||
|
right: 5px;
|
||||||
|
bottom: 5px;
|
||||||
|
left: 5px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
display: block; }
|
||||||
|
/* line 205, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .s-timeline-tabular .l-header .l-header-elem.l-labels .l-label,
|
||||||
|
.l-timeline-holder .s-timeline-gantt .l-header .l-header-elem.l-labels .l-label {
|
||||||
|
position: absolute;
|
||||||
|
width: 140px;
|
||||||
|
margin-left: -70px;
|
||||||
|
text-align: center; }
|
||||||
|
/* line 215, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-hover-btns-holder {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
-moz-transition-property: opacity, background-color, border-color, color;
|
||||||
|
-o-transition-property: opacity, background-color, border-color, color;
|
||||||
|
-webkit-transition-property: opacity, background-color, border-color, color;
|
||||||
|
transition-property: opacity, background-color, border-color, color;
|
||||||
|
-moz-transition-duration: 500ms;
|
||||||
|
-o-transition-duration: 500ms;
|
||||||
|
-webkit-transition-duration: 500ms;
|
||||||
|
transition-duration: 500ms;
|
||||||
|
-moz-transition-timing-function: ease-in-out;
|
||||||
|
-o-transition-timing-function: ease-in-out;
|
||||||
|
-webkit-transition-timing-function: ease-in-out;
|
||||||
|
transition-timing-function: ease-in-out;
|
||||||
|
-moz-transition-delay: 0;
|
||||||
|
-o-transition-delay: 0;
|
||||||
|
-webkit-transition-delay: 0;
|
||||||
|
transition-delay: 0;
|
||||||
|
opacity: 0;
|
||||||
|
height: 30px;
|
||||||
|
width: 100px;
|
||||||
|
left: auto;
|
||||||
|
padding: 5px;
|
||||||
|
text-align: right;
|
||||||
|
z-index: 10; }
|
||||||
|
/* line 228, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols {
|
||||||
|
overflow: visible;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
text-wrap: none;
|
||||||
|
white-space: nowrap; }
|
||||||
|
/* line 232, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col {
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
display: inline-block;
|
||||||
|
height: 100%;
|
||||||
|
padding: 0 5px;
|
||||||
|
position: relative;
|
||||||
|
text-wrap: none;
|
||||||
|
white-space: nowrap; }
|
||||||
|
/* line 242, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col.l-col-icon {
|
||||||
|
width: 16px;
|
||||||
|
text-align: center;
|
||||||
|
padding: 0; }
|
||||||
|
/* line 246, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col.l-col-icon .ui-symbol {
|
||||||
|
color: #0099cc; }
|
||||||
|
/* line 251, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col.l-plot-resource {
|
||||||
|
border-left: none !important;
|
||||||
|
cursor: pointer;
|
||||||
|
padding-left: 0; }
|
||||||
|
/* line 257, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col.l-title {
|
||||||
|
width: 250px; }
|
||||||
|
/* line 261, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col.l-start, .l-timeline-holder .l-cols .l-col.l-end, .l-timeline-holder .l-cols .l-col.l-duration {
|
||||||
|
width: 110px; }
|
||||||
|
/* line 267, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-cols .l-col.l-activity-modes {
|
||||||
|
display: none;
|
||||||
|
width: 250px; }
|
||||||
|
/* line 275, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .s-timeline-tabular .l-header .l-cols {
|
||||||
|
top: 5px;
|
||||||
|
bottom: 5px; }
|
||||||
|
/* line 281, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .s-timeline-tabular .l-pane-l .l-cols {
|
||||||
|
left: 5px; }
|
||||||
|
/* line 287, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .splitter {
|
||||||
|
top: 0; }
|
||||||
|
/* line 293, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-ticks,
|
||||||
|
.l-timeline-holder .l-subticks {
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
|
right: 0px;
|
||||||
|
bottom: 0px;
|
||||||
|
left: 0px;
|
||||||
|
width: auto;
|
||||||
|
height: auto;
|
||||||
|
top: auto;
|
||||||
|
bottom: 3px; }
|
||||||
|
/* line 299, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-ticks {
|
||||||
|
height: 10px; }
|
||||||
|
/* line 303, ../sass/_timelines.scss */
|
||||||
|
.l-timeline-holder .l-subticks {
|
||||||
|
height: 5px; }
|
4
platform/features/timeline/res/sass-compile.sh
Normal file
4
platform/features/timeline/res/sass-compile.sh
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
date
|
||||||
|
|
||||||
|
echo "*** Compiling sass"
|
||||||
|
compass compile --force
|
64
platform/features/timeline/res/sass/_activities.scss
Normal file
64
platform/features/timeline/res/sass/_activities.scss
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
.l-timeline-gantt {
|
||||||
|
position: absolute;
|
||||||
|
top: $timelineSwimlaneGanttVM; bottom: $timelineSwimlaneGanttVM;
|
||||||
|
|
||||||
|
.bar {
|
||||||
|
@include ellipsize();
|
||||||
|
height: $activityBarH;
|
||||||
|
line-height: $activityBarH + 2;
|
||||||
|
padding: 0 $interiorMargin;
|
||||||
|
|
||||||
|
span {
|
||||||
|
display: inline;
|
||||||
|
&.s-activity-type {
|
||||||
|
&.timeline {
|
||||||
|
&:before {
|
||||||
|
content:"S";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&.activity {
|
||||||
|
&:before {
|
||||||
|
content:"A";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&.s-title {
|
||||||
|
@include text-shadow(rgba(black, 0.1) 0 1px 2px);
|
||||||
|
}
|
||||||
|
&.duration {
|
||||||
|
left: auto;
|
||||||
|
opacity: 0.75;
|
||||||
|
right: 0;
|
||||||
|
text-align: right;
|
||||||
|
width: 60px;
|
||||||
|
}
|
||||||
|
&.handle {
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
height: auto;
|
||||||
|
width: 15px;
|
||||||
|
&.left {
|
||||||
|
right: auto;
|
||||||
|
}
|
||||||
|
&.middle {
|
||||||
|
right: 15px;
|
||||||
|
left: 15px;
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
&.right {
|
||||||
|
right: 0;
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.edit-mode .s-timeline-gantt {
|
||||||
|
.handle {
|
||||||
|
cursor: col-resize;
|
||||||
|
&.mid {
|
||||||
|
cursor: ew-resize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
42
platform/features/timeline/res/sass/_constants-espresso.scss
Normal file
42
platform/features/timeline/res/sass/_constants-espresso.scss
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
// General
|
||||||
|
$timelineHeaderColorBg: pullForward($colorBodyBg, 5%);
|
||||||
|
$timelineColorAlt1: pullForward($timelineHeaderColorBg, 10%);
|
||||||
|
$colorGanttBarBg: #5555aa;
|
||||||
|
$colorGanttBarFg: #fff;
|
||||||
|
$colorGanttBarSelectedBg: #ccc;
|
||||||
|
$colorGanttBarSelectedFg: #333;
|
||||||
|
$colorGanttBarTabularFgIcon: #8594ff;
|
||||||
|
|
||||||
|
// Swimlane colors
|
||||||
|
$colorDropTarg: rgba($colorGanttBarBg, 0.4);
|
||||||
|
$colorSwimlaneSelectedBg: #222;
|
||||||
|
$colorSwimlaneSelectedFg: #ccc;
|
||||||
|
$colorGanttToggle: $colorKey;
|
||||||
|
$shdwGanttBar: rgba(black, 0.4) 0 1px 3px;
|
||||||
|
|
||||||
|
// Resource graphs
|
||||||
|
$timelineResourceGraphBg: rgba(black, 0.2);
|
||||||
|
$timelineResourceGraphFg: $colorBodyFg;
|
||||||
|
$timelineResourceGraphLegendFg: $colorBodyFg;
|
42
platform/features/timeline/res/sass/_constants-snow.scss
Normal file
42
platform/features/timeline/res/sass/_constants-snow.scss
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
// General
|
||||||
|
$timelineHeaderColorBg: pullForward($colorBodyBg, 5%);
|
||||||
|
$timelineColorAlt1: pullForward($timelineHeaderColorBg, 10%);
|
||||||
|
$colorGanttBarBg: #5555aa;
|
||||||
|
$colorGanttBarFg: #fff;
|
||||||
|
$colorGanttBarSelectedBg: $colorGanttBarBg;
|
||||||
|
$colorGanttBarSelectedFg: $colorGanttBarFg;
|
||||||
|
$colorGanttBarTabularFgIcon: #8594ff;
|
||||||
|
|
||||||
|
// Swimlane colors
|
||||||
|
$colorDropTarg: rgba($colorGanttBarBg, 0.4);
|
||||||
|
$colorSwimlaneSelectedBg: rgba($colorGanttBarBg, 0.25);
|
||||||
|
$colorSwimlaneSelectedFg: pullForward($colorBodyFg, 10%);
|
||||||
|
$colorGanttToggle: $colorKey;
|
||||||
|
$shdwGanttBar: rgba(black, 0.1) 0 1px 3px;
|
||||||
|
|
||||||
|
// Resource graphs
|
||||||
|
$timelineResourceGraphBg: $colorPlotBg;
|
||||||
|
$timelineResourceGraphFg: $colorBodyFg;
|
||||||
|
$timelineResourceGraphLegendFg: $colorBodyFg;
|
63
platform/features/timeline/res/sass/_constants.scss
Normal file
63
platform/features/timeline/res/sass/_constants.scss
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
@mixin activityBg($bg, $gamma: 10) {
|
||||||
|
@include background-image(linear-gradient(lighten($bg, $gamma), $bg));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Timeline constants
|
||||||
|
$activityBarH: 17px;
|
||||||
|
$timelinePaneLeftW: 30%;
|
||||||
|
$timelinePaneBtmH: 30%;
|
||||||
|
$timelineResourceGraphYLabelsMargin: 70px;
|
||||||
|
$timelineTopPaneHeaderH: 30px;
|
||||||
|
|
||||||
|
$timelineSwimlaneGanttVM: 2px; // The vertical space above and below the gantt bars
|
||||||
|
$timelineSwimlaneH: $activityBarH + ($timelineSwimlaneGanttVM * 2);
|
||||||
|
$timelineTopPaneHeaderElemMargin: $interiorMargin;
|
||||||
|
|
||||||
|
// Timeline Tabular constants
|
||||||
|
$timelineColIconW: 16px;
|
||||||
|
$timelineColResourcePlotW: $timelineColIconW;
|
||||||
|
$timelineColTitleW: 250px;
|
||||||
|
$timelineColDatetimeW: 110px;
|
||||||
|
$timelineColDurationW: 70px;
|
||||||
|
$timelineColActivityModesW: $timelineColTitleW;
|
||||||
|
$timelineColPadR: 50px;
|
||||||
|
$timelineTabularTitleW: $timelineColResourcePlotW + $timelineColTitleW;
|
||||||
|
$timelineTabularDataW: ($timelineColDatetimeW * 2) + $timelineColDurationW + $timelineColActivityModesW + $timelineColPadR;
|
||||||
|
|
||||||
|
|
||||||
|
// // Ported from legacy timelines SASS
|
||||||
|
$activitiesHolderM: 30px;
|
||||||
|
$scenarioTopPad: 25px;
|
||||||
|
$swimlaneVM: 2px;
|
||||||
|
$timelineVM: 10px;
|
||||||
|
$timelineBPad: $interiorMargin * 2;
|
||||||
|
$graphResourceSummaryH: 200px;
|
||||||
|
$graphResourceSummaryLegendH: 20px;
|
||||||
|
$scenarioTimelineSummaryH: 20px;
|
||||||
|
$scenarioTimelineSummaryHExpanded: $graphResourceSummaryH + 30px;
|
||||||
|
$scenarioPanZoomSliderH: 16px;
|
||||||
|
$scenarioTicksH: 7px;
|
||||||
|
$scenarioTickLabelsH: 10px;
|
||||||
|
|
||||||
|
|
154
platform/features/timeline/res/sass/_timeline-thematic.scss
Normal file
154
platform/features/timeline/res/sass/_timeline-thematic.scss
Normal file
@ -0,0 +1,154 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
.l-timeline-holder {
|
||||||
|
.l-timeline-pane {
|
||||||
|
&.t-pane-h {
|
||||||
|
&.l-timeline-resource-legend {
|
||||||
|
.l-legend-items {
|
||||||
|
color: $timelineResourceGraphLegendFg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.s-timeline-gantt {
|
||||||
|
$br: $controlCr;
|
||||||
|
.bar {
|
||||||
|
color: $colorGanttBarFg;
|
||||||
|
@include activityBg($colorGanttBarBg);
|
||||||
|
@include border-radius($br);
|
||||||
|
@include box-shadow($shdwGanttBar);
|
||||||
|
&.expanded {
|
||||||
|
@include border-top-radius($br);
|
||||||
|
@include border-bottom-radius(0);
|
||||||
|
}
|
||||||
|
&.leaf {
|
||||||
|
@include border-top-radius(0);
|
||||||
|
@include border-bottom-radius($br);
|
||||||
|
}
|
||||||
|
.s-toggle {
|
||||||
|
color: $colorGanttToggle;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.s-timeline-tabular {
|
||||||
|
.l-header .l-cols {
|
||||||
|
.l-col {
|
||||||
|
border-left: 1px solid pullForward($timelineHeaderColorBg, 15%);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-pane-l {
|
||||||
|
// Left pane of the tabular area
|
||||||
|
.l-cols {
|
||||||
|
.s-label .ui-symbol.icon {
|
||||||
|
color: $colorGanttBarTabularFgIcon;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.edit-mode .s-timeline-gantt {
|
||||||
|
.bar {
|
||||||
|
&:hover {
|
||||||
|
@include background-image(linear-gradient(lighten($colorGanttBarBg, 20), lighten($colorGanttBarBg, 10)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//*************************************************************** STYLING
|
||||||
|
.s-timeline {
|
||||||
|
font-size: 0.75rem;
|
||||||
|
.s-header {
|
||||||
|
background-color: $timelineHeaderColorBg;
|
||||||
|
}
|
||||||
|
.s-swimlane {
|
||||||
|
border-bottom: 1px solid pullForward($colorBodyBg, 10%);
|
||||||
|
line-height: $activityBarH + 2 + 1;
|
||||||
|
&.exceeded {
|
||||||
|
@include bgDiagonalStripes(#fff, 0.05, $timelineSwimlaneH + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.selected {
|
||||||
|
background-color: $colorSwimlaneSelectedBg;
|
||||||
|
color: $colorSwimlaneSelectedFg;
|
||||||
|
|
||||||
|
.s-timeline-gantt .bar {
|
||||||
|
@include activityBg($colorGanttBarSelectedBg, 10);
|
||||||
|
color: $colorGanttBarSelectedFg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.drop-into {
|
||||||
|
background-color: rgba($colorDropTarg, 0.7);
|
||||||
|
.s-timeline-gantt {
|
||||||
|
opacity: 0.7;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&.drop-after {
|
||||||
|
background-color: rgba(#000, 0.2);
|
||||||
|
border-bottom-color: rgba($colorDropTarg, 1.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.s-ticks {
|
||||||
|
@include bgTicks($timelineColorAlt1);
|
||||||
|
}
|
||||||
|
.s-hover-btns-holder {
|
||||||
|
$bg: $timelineHeaderColorBg;
|
||||||
|
$bga: 1;
|
||||||
|
$l: 5%;
|
||||||
|
@include user-select(none);
|
||||||
|
@include background-image(linear-gradient(-90deg, rgba($bg, $bga), rgba($bg, $bga) 70%, rgba($bg, 0) 100%));
|
||||||
|
.s-btn {
|
||||||
|
height: 16px;
|
||||||
|
line-height: 16px;
|
||||||
|
.icon {
|
||||||
|
font-size: 0.7rem !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-timeline-resource-graph {
|
||||||
|
.l-graph {
|
||||||
|
background: $timelineResourceGraphBg;
|
||||||
|
}
|
||||||
|
.l-title {
|
||||||
|
color: $timelineResourceGraphFg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.edit-mode .s-swimlane {
|
||||||
|
cursor: pointer;
|
||||||
|
.t-object-label {
|
||||||
|
@include border-radius($controlCr);
|
||||||
|
cursor: move;
|
||||||
|
padding: 2px 5px;
|
||||||
|
&:hover {
|
||||||
|
background: rgba($colorBodyFg, 0.3);
|
||||||
|
color: pullForward($colorBodyFg, 20%);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
306
platform/features/timeline/res/sass/_timelines.scss
Normal file
306
platform/features/timeline/res/sass/_timelines.scss
Normal file
@ -0,0 +1,306 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
//*************************************************************** LAYOUT
|
||||||
|
.l-timeline-holder {
|
||||||
|
@include absPosDefault();
|
||||||
|
|
||||||
|
.l-timeline-pane {
|
||||||
|
@include absPosDefault();
|
||||||
|
|
||||||
|
.l-width-control {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-swimlanes-holder {
|
||||||
|
@include absPosDefault();
|
||||||
|
top: $timelineTopPaneHeaderH + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Overall layout
|
||||||
|
&.t-pane-h {
|
||||||
|
&.s-timeline-tabular .t-pane-v {
|
||||||
|
// Vertical panes within tabular area
|
||||||
|
@include absPosDefault();
|
||||||
|
&.l-tabular-l {
|
||||||
|
// Tree area with item title
|
||||||
|
right: auto; // Set this to auto and uncomment width below when additional tabular columns are added
|
||||||
|
width: $timelineTabularTitleW;
|
||||||
|
}
|
||||||
|
&.l-tabular-r {
|
||||||
|
// Start, end, duration, activity modes columns
|
||||||
|
@include scrollH();
|
||||||
|
left: $timelineTabularTitleW;
|
||||||
|
.l-width {
|
||||||
|
@include absPosDefault(0, visible);
|
||||||
|
min-width: $timelineTabularDataW;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&.l-timeline-gantt {
|
||||||
|
.l-swimlanes-holder {
|
||||||
|
@include scrollV(scroll);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&.l-timeline-resource-legend {
|
||||||
|
@include box-sizing(border-box);
|
||||||
|
padding: $interiorMargin 0;
|
||||||
|
white-space: nowrap;
|
||||||
|
|
||||||
|
.l-legend-items {
|
||||||
|
@include absPosDefault();
|
||||||
|
@include scrollV();
|
||||||
|
top: 25px;
|
||||||
|
}
|
||||||
|
.legend-item {
|
||||||
|
// Inherits from /platform/commonUI/general/res/sass/plots/_plots-main.scss
|
||||||
|
display: block;
|
||||||
|
margin-bottom: $interiorMarginSm;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
.color-swatch {
|
||||||
|
vertical-align: baseline;
|
||||||
|
}
|
||||||
|
.title-label {
|
||||||
|
vertical-align: baseline;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-timeline-resource-graph {
|
||||||
|
$m: $interiorMargin;
|
||||||
|
|
||||||
|
.l-graphs-holder {
|
||||||
|
@include absPosDefault();
|
||||||
|
bottom: $scrollbarTrackSize;
|
||||||
|
|
||||||
|
.l-graphs {
|
||||||
|
@include absPosDefault();
|
||||||
|
@include scrollV(scroll);
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-graph-labels-holder {
|
||||||
|
@include absPosDefault();
|
||||||
|
overflow: hidden;
|
||||||
|
right: auto;
|
||||||
|
width: 400px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-scroll-control {
|
||||||
|
@include absPosDefault();
|
||||||
|
overflow-x: scroll;
|
||||||
|
overflow-y: hidden;
|
||||||
|
top: auto; right: $scrollbarTrackSize;
|
||||||
|
height: $scrollbarTrackSize;
|
||||||
|
.l-width-control {
|
||||||
|
height: 10px; // Need to add height to force scrollbar to appear
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-graph,
|
||||||
|
.l-graph-labels {
|
||||||
|
height: 80px;
|
||||||
|
margin-bottom: $interiorMarginSm;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-title {
|
||||||
|
@include ellipsize();
|
||||||
|
top: $m; left: $m;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-graph {
|
||||||
|
width: 100%;
|
||||||
|
.l-graph-area {
|
||||||
|
canvas {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-graph-labels {
|
||||||
|
z-index: 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-graph-area {
|
||||||
|
@include absPosDefault();
|
||||||
|
top: 20px; bottom: 5px;
|
||||||
|
.l-labels-holder {
|
||||||
|
@include absPosDefault();
|
||||||
|
left: $m;
|
||||||
|
.tick-label.tick-label-y {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-pane-l {
|
||||||
|
right: auto;
|
||||||
|
min-width: 50px;
|
||||||
|
max-width: 90%;
|
||||||
|
width: $timelinePaneLeftW;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-pane-r {
|
||||||
|
left: 0;
|
||||||
|
&:hover {
|
||||||
|
.l-hover-btns-holder {
|
||||||
|
@include trans-prop-nice-fade(100ms);
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-pane-top {
|
||||||
|
bottom: $timelinePaneBtmH;
|
||||||
|
}
|
||||||
|
&.l-pane-btm {
|
||||||
|
top: auto;
|
||||||
|
min-height: 20px;
|
||||||
|
max-height: 80%;
|
||||||
|
height: $timelinePaneBtmH;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-swimlane {
|
||||||
|
height: $timelineSwimlaneH;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Header
|
||||||
|
.s-timeline-tabular .l-header,
|
||||||
|
.s-timeline-gantt .l-header {
|
||||||
|
@include absPosDefault(0, visible);
|
||||||
|
bottom: auto; height: $timelineTopPaneHeaderH;
|
||||||
|
|
||||||
|
.l-header-elem {
|
||||||
|
@include absPosDefault($timelineTopPaneHeaderElemMargin, visible);
|
||||||
|
display: block;
|
||||||
|
&.l-labels {
|
||||||
|
.l-label {
|
||||||
|
position: absolute;
|
||||||
|
width: 140px;
|
||||||
|
margin-left: -70px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-hover-btns-holder {
|
||||||
|
@include absPosDefault();
|
||||||
|
@include box-sizing(border-box);
|
||||||
|
@include trans-prop-nice-fade(500ms);
|
||||||
|
opacity: 0;
|
||||||
|
height: $timelineTopPaneHeaderH;
|
||||||
|
width: 100px; left: auto;
|
||||||
|
padding: $interiorMargin;
|
||||||
|
text-align: right;
|
||||||
|
z-index: 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Tabular Columns
|
||||||
|
.l-cols {
|
||||||
|
@include absPosDefault(0, visible);
|
||||||
|
text-wrap: none;
|
||||||
|
white-space: nowrap;
|
||||||
|
.l-col {
|
||||||
|
@include box-sizing(border-box);
|
||||||
|
@include ellipsize();
|
||||||
|
display: inline-block;
|
||||||
|
height: 100%;
|
||||||
|
padding: 0 $interiorMargin;
|
||||||
|
position: relative;
|
||||||
|
text-wrap: none;
|
||||||
|
white-space: nowrap;
|
||||||
|
|
||||||
|
&.l-col-icon {
|
||||||
|
width: $timelineColIconW;
|
||||||
|
text-align: center;
|
||||||
|
padding: 0;
|
||||||
|
.ui-symbol {
|
||||||
|
color: $colorKey;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-plot-resource {
|
||||||
|
border-left: none !important;
|
||||||
|
cursor: pointer;
|
||||||
|
padding-left: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-title {
|
||||||
|
width: $timelineColTitleW;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-start,
|
||||||
|
&.l-end,
|
||||||
|
&.l-duration {
|
||||||
|
width: $timelineColDatetimeW;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.l-activity-modes {
|
||||||
|
display: none; // Temp, until modes can be displayed
|
||||||
|
width: $timelineColActivityModesW;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.s-timeline-tabular {
|
||||||
|
.l-header .l-cols {
|
||||||
|
top: $timelineTopPaneHeaderElemMargin; bottom: $timelineTopPaneHeaderElemMargin;
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-pane-l {
|
||||||
|
// Left pane of the tabular area
|
||||||
|
.l-cols {
|
||||||
|
left: $timelineTopPaneHeaderElemMargin;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.splitter {
|
||||||
|
// Top of splitter within Timelines should be 0
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ticks
|
||||||
|
.l-ticks,
|
||||||
|
.l-subticks {
|
||||||
|
@include absPosDefault();
|
||||||
|
top: auto; bottom: $interiorMarginSm;
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-ticks {
|
||||||
|
height: 10px
|
||||||
|
}
|
||||||
|
|
||||||
|
.l-subticks {
|
||||||
|
height: 5px
|
||||||
|
}
|
||||||
|
}
|
33
platform/features/timeline/res/sass/timeline-espresso.scss
Normal file
33
platform/features/timeline/res/sass/timeline-espresso.scss
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
@import "compass";
|
||||||
|
@import "compass/css3";
|
||||||
|
@import "compass/utilities";
|
||||||
|
|
||||||
|
@import "../../../../commonUI/general/res/sass/constants";
|
||||||
|
@import "../../../../commonUI/general/res/sass/mixins";
|
||||||
|
@import "../../../../commonUI/themes/espresso/res/sass/constants";
|
||||||
|
@import "../../../../commonUI/themes/espresso/res/sass/mixins";
|
||||||
|
@import "constants";
|
||||||
|
@import "constants-espresso";
|
||||||
|
@import "timeline-thematic";
|
||||||
|
|
32
platform/features/timeline/res/sass/timeline-snow.scss
Normal file
32
platform/features/timeline/res/sass/timeline-snow.scss
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
@import "compass";
|
||||||
|
@import "compass/css3";
|
||||||
|
@import "compass/utilities";
|
||||||
|
|
||||||
|
@import "../../../../commonUI/general/res/sass/constants";
|
||||||
|
@import "../../../../commonUI/general/res/sass/mixins";
|
||||||
|
@import "../../../../commonUI/themes/snow/res/sass/constants";
|
||||||
|
@import "../../../../commonUI/themes/snow/res/sass/mixins";
|
||||||
|
@import "constants";
|
||||||
|
@import "constants-snow";
|
||||||
|
@import "timeline-thematic";
|
32
platform/features/timeline/res/sass/timeline.scss
Normal file
32
platform/features/timeline/res/sass/timeline.scss
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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.
|
||||||
|
*****************************************************************************/
|
||||||
|
@import "compass";
|
||||||
|
@import "compass/css3";
|
||||||
|
@import "compass/utilities";
|
||||||
|
|
||||||
|
@import "../../../../commonUI/general/res/sass/constants";
|
||||||
|
@import "../../../../commonUI/general/res/sass/mixins";
|
||||||
|
@import "../../../../commonUI/themes/espresso/res/sass/constants";
|
||||||
|
@import "../../../../commonUI/themes/espresso/res/sass/mixins";
|
||||||
|
@import "constants";
|
||||||
|
@import "activities";
|
||||||
|
@import "timelines";
|
@ -109,14 +109,14 @@
|
|||||||
<div class="split-pane-component l-timeline-pane t-pane-h l-pane-top t-timeline-gantt l-timeline-gantt s-timeline-gantt"
|
<div class="split-pane-component l-timeline-pane t-pane-h l-pane-top t-timeline-gantt l-timeline-gantt s-timeline-gantt"
|
||||||
>
|
>
|
||||||
<div class="l-hover-btns-holder s-hover-btns-holder t-btns-zoom">
|
<div class="l-hover-btns-holder s-hover-btns-holder t-btns-zoom">
|
||||||
<a class="t-btn l-btn s-btn s-icon-btn"
|
<a class="t-btn l-btn s-btn"
|
||||||
ng-click="zoomController.zoom(-1)"
|
ng-click="zoomController.zoom(-1)"
|
||||||
ng-show="true"
|
ng-show="true"
|
||||||
title="Zoom in">
|
title="Zoom in">
|
||||||
<span class="ui-symbol icon zoom-in">X</span>
|
<span class="ui-symbol icon zoom-in">X</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<a class="t-btn l-btn s-btn s-icon-btn"
|
<a class="t-btn l-btn s-btn"
|
||||||
ng-click="zoomController.zoom(1)"
|
ng-click="zoomController.zoom(1)"
|
||||||
ng-show="true"
|
ng-show="true"
|
||||||
title="Zoom out">
|
title="Zoom out">
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
at runtime from the About dialog for additional information.
|
at runtime from the About dialog for additional information.
|
||||||
-->
|
-->
|
||||||
<div
|
<div
|
||||||
class="t-btn l-btn s-btn s-icon-btn s-menu-btn menu-element t-color-palette"
|
class="t-btn l-btn s-btn s-menu-btn menu-element t-color-palette"
|
||||||
ng-controller="ClickAwayController as toggle"
|
ng-controller="ClickAwayController as toggle"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
12
platform/persistence/aggregator/bundle.json
Normal file
12
platform/persistence/aggregator/bundle.json
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"extensions": {
|
||||||
|
"components": [
|
||||||
|
{
|
||||||
|
"provides": "persistenceService",
|
||||||
|
"type": "aggregator",
|
||||||
|
"depends": [ "$q" ],
|
||||||
|
"implementation": "PersistenceAggregator.js"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
89
platform/persistence/aggregator/src/PersistenceAggregator.js
Normal file
89
platform/persistence/aggregator/src/PersistenceAggregator.js
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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,window*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
// Return values to use when a persistence space is unknown,
|
||||||
|
// and there is no appropriate provider to route to.
|
||||||
|
var METHOD_DEFAULTS = {
|
||||||
|
createObject: false,
|
||||||
|
readObject: undefined,
|
||||||
|
listObjects: [],
|
||||||
|
updateObject: false,
|
||||||
|
deleteObject: false
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Aggregates multiple persistence providers, such that they can be
|
||||||
|
* utilized as if they were a single object. This is achieved by
|
||||||
|
* routing persistence calls to an appropriate provider; the space
|
||||||
|
* specified at call time is matched with the first provider (per
|
||||||
|
* priority order) which reports that it provides persistence for
|
||||||
|
* this space.
|
||||||
|
*
|
||||||
|
* @memberof platform/persistence/aggregator
|
||||||
|
* @constructor
|
||||||
|
* @implements {PersistenceService}
|
||||||
|
* @param $q Angular's $q, for promises
|
||||||
|
* @param {PersistenceService[]} providers the providers to aggregate
|
||||||
|
*/
|
||||||
|
function PersistenceAggregator($q, providers) {
|
||||||
|
var providerMap = {};
|
||||||
|
|
||||||
|
function addToMap(provider) {
|
||||||
|
return provider.listSpaces().then(function (spaces) {
|
||||||
|
spaces.forEach(function (space) {
|
||||||
|
providerMap[space] = providerMap[space] || provider;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.providerMapPromise = $q.all(providers.map(addToMap))
|
||||||
|
.then(function () { return providerMap; });
|
||||||
|
}
|
||||||
|
|
||||||
|
PersistenceAggregator.prototype.listSpaces = function () {
|
||||||
|
return this.providerMapPromise.then(function (map) {
|
||||||
|
return Object.keys(map);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
Object.keys(METHOD_DEFAULTS).forEach(function (method) {
|
||||||
|
PersistenceAggregator.prototype[method] = function (space) {
|
||||||
|
var delegateArgs = Array.prototype.slice.apply(arguments, []);
|
||||||
|
return this.providerMapPromise.then(function (map) {
|
||||||
|
var provider = map[space];
|
||||||
|
return provider ?
|
||||||
|
provider[method].apply(provider, delegateArgs) :
|
||||||
|
METHOD_DEFAULTS[method];
|
||||||
|
});
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
return PersistenceAggregator;
|
||||||
|
}
|
||||||
|
);
|
@ -0,0 +1,103 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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,spyOn */
|
||||||
|
define(
|
||||||
|
['../src/PersistenceAggregator'],
|
||||||
|
function (PersistenceAggregator) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var PERSISTENCE_SERVICE_METHODS = [
|
||||||
|
'listSpaces',
|
||||||
|
'listObjects',
|
||||||
|
'createObject',
|
||||||
|
'readObject',
|
||||||
|
'updateObject',
|
||||||
|
'deleteObject'
|
||||||
|
],
|
||||||
|
WRAPPED_METHODS = PERSISTENCE_SERVICE_METHODS.filter(function (m) {
|
||||||
|
return m !== 'listSpaces';
|
||||||
|
});
|
||||||
|
|
||||||
|
function fakePromise(value) {
|
||||||
|
return (value || {}).then ? value : {
|
||||||
|
then: function (callback) {
|
||||||
|
return fakePromise(callback(value));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
describe("PersistenceAggregator", function () {
|
||||||
|
var mockQ,
|
||||||
|
mockProviders,
|
||||||
|
mockCallback,
|
||||||
|
testSpaces,
|
||||||
|
aggregator;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testSpaces = ['a', 'b', 'c'];
|
||||||
|
mockQ = jasmine.createSpyObj("$q", ['all']);
|
||||||
|
mockProviders = testSpaces.map(function (space) {
|
||||||
|
var mockProvider = jasmine.createSpyObj(
|
||||||
|
'provider-' + space,
|
||||||
|
PERSISTENCE_SERVICE_METHODS
|
||||||
|
);
|
||||||
|
PERSISTENCE_SERVICE_METHODS.forEach(function (m) {
|
||||||
|
mockProvider[m].andReturn(fakePromise(true));
|
||||||
|
});
|
||||||
|
mockProvider.listSpaces.andReturn(fakePromise([space]));
|
||||||
|
return mockProvider;
|
||||||
|
});
|
||||||
|
mockCallback = jasmine.createSpy();
|
||||||
|
|
||||||
|
mockQ.all.andCallFake(function (fakePromises) {
|
||||||
|
var result = [];
|
||||||
|
fakePromises.forEach(function (p) {
|
||||||
|
p.then(function (v) { result.push(v); });
|
||||||
|
});
|
||||||
|
return fakePromise(result);
|
||||||
|
});
|
||||||
|
|
||||||
|
aggregator = new PersistenceAggregator(mockQ, mockProviders);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("exposes spaces for all providers", function () {
|
||||||
|
aggregator.listSpaces().then(mockCallback);
|
||||||
|
expect(mockCallback).toHaveBeenCalledWith(testSpaces);
|
||||||
|
});
|
||||||
|
|
||||||
|
WRAPPED_METHODS.forEach(function (m) {
|
||||||
|
it("redirects " + m + " calls to an appropriate provider", function () {
|
||||||
|
testSpaces.forEach(function (space, index) {
|
||||||
|
var key = 'key-' + space,
|
||||||
|
value = 'val-' + space;
|
||||||
|
expect(aggregator[m](space, key, value))
|
||||||
|
.toEqual(mockProviders[index][m]());
|
||||||
|
expect(mockProviders[index][m])
|
||||||
|
.toHaveBeenCalledWith(space, key, value);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
3
platform/persistence/aggregator/test/suite.json
Normal file
3
platform/persistence/aggregator/test/suite.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[
|
||||||
|
"PersistenceAggregator"
|
||||||
|
]
|
Reference in New Issue
Block a user