mirror of
https://github.com/nasa/openmct.git
synced 2024-12-19 13:17:53 +00:00
[Frontend] Safety merge of master; minor fixes
open #90 IN-PROGRESS Merged in latest from github/master; Fixed margins when in edit mode; Fixed edit area not utilizing overflow: auto properly; TO-DO: verify mobile is Ok;
This commit is contained in:
parent
b5b6546710
commit
c913f173e3
@ -187,7 +187,7 @@ GLOBAL.window = GLOBAL.window || GLOBAL; // nomnoml expects window to be define
|
|||||||
destPath = path.dirname(destination),
|
destPath = path.dirname(destination),
|
||||||
streamOptions = {};
|
streamOptions = {};
|
||||||
if (file.match(/png$/)){
|
if (file.match(/png$/)){
|
||||||
streamOptions.encoding = 'binary';
|
streamOptions.encoding = null;
|
||||||
} else {
|
} else {
|
||||||
streamOptions.encoding = 'utf8';
|
streamOptions.encoding = 'utf8';
|
||||||
}
|
}
|
||||||
|
@ -42,22 +42,20 @@
|
|||||||
@include border-radius($splitterEndCr);
|
@include border-radius($splitterEndCr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
&:not(:active) {
|
|
||||||
&:after {
|
|
||||||
@include trans-prop-nice(background-color, 150ms);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
&:active {
|
&:active {
|
||||||
|
//@include test();
|
||||||
&:after {
|
&:after {
|
||||||
background-color: $colorSplitterActive !important;
|
background-color: $colorSplitterActive !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@if $colorSplitterHover != 'none' {
|
@if $colorSplitterHover != 'none' {
|
||||||
&:hover {
|
&:not(:active) {
|
||||||
&:after {
|
&:hover {
|
||||||
@include trans-prop-nice(background-color, 150ms);
|
&:after {
|
||||||
background-color: $colorSplitterHover;
|
background-color: $colorSplitterHover !important;
|
||||||
|
@include trans-prop-nice(background-color, 150ms);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -95,9 +95,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.user-environ {
|
.user-environ {
|
||||||
|
|
||||||
.browse-area,
|
.browse-area,
|
||||||
.edit-area,
|
|
||||||
.editor {
|
.editor {
|
||||||
top: 0; left: 0; right: 0; bottom: $ueFooterH;
|
top: 0; left: 0; right: 0; bottom: $ueFooterH;
|
||||||
}
|
}
|
||||||
@ -113,13 +111,17 @@
|
|||||||
.edit-area {
|
.edit-area {
|
||||||
$tbH: $btnToolbarH + $interiorMargin;
|
$tbH: $btnToolbarH + $interiorMargin;
|
||||||
top: $bodyMargin + $ueTopBarEditH + ($interiorMargin);
|
top: $bodyMargin + $ueTopBarEditH + ($interiorMargin);
|
||||||
|
left: $bodyMargin;
|
||||||
|
right: $bodyMargin;
|
||||||
|
bottom: $bodyMargin + $ueFooterH;
|
||||||
.tool-bar {
|
.tool-bar {
|
||||||
bottom: auto;
|
bottom: auto;
|
||||||
height: $tbH;
|
height: $tbH;
|
||||||
line-height: $btnToolbarH;
|
line-height: $btnToolbarH;
|
||||||
}
|
}
|
||||||
.work-area {
|
.object-holder.work-area {
|
||||||
top: $tbH + $interiorMargin * 2;
|
top: $tbH + $interiorMargin * 2;
|
||||||
|
overflow: auto;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,11 +55,6 @@ define(
|
|||||||
self.trackPosition(event);
|
self.trackPosition(event);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Also make sure we dismiss bubble if representation is destroyed
|
|
||||||
// before the mouse actually leaves it
|
|
||||||
this.scopeOff =
|
|
||||||
element.scope().$on('$destroy', this.hideBubbleCallback);
|
|
||||||
|
|
||||||
this.element = element;
|
this.element = element;
|
||||||
this.$timeout = $timeout;
|
this.$timeout = $timeout;
|
||||||
this.infoService = infoService;
|
this.infoService = infoService;
|
||||||
@ -143,7 +138,6 @@ define(
|
|||||||
this.hideBubble();
|
this.hideBubble();
|
||||||
// ...and detach listeners
|
// ...and detach listeners
|
||||||
this.element.off('mouseenter', this.showBubbleCallback);
|
this.element.off('mouseenter', this.showBubbleCallback);
|
||||||
this.scopeOff();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return InfoGesture;
|
return InfoGesture;
|
||||||
|
@ -958,8 +958,12 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before {
|
|||||||
height: auto;
|
height: auto;
|
||||||
background: #404040;
|
background: #404040;
|
||||||
display: block; }
|
display: block; }
|
||||||
/* line 46, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 47, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.splitter:not(:active):after {
|
.splitter:active:after {
|
||||||
|
background-color: #0099cc !important; }
|
||||||
|
/* line 55, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
|
.splitter:not(:active):hover:after {
|
||||||
|
background-color: #595959 !important;
|
||||||
-moz-transition-property: background-color;
|
-moz-transition-property: background-color;
|
||||||
-o-transition-property: background-color;
|
-o-transition-property: background-color;
|
||||||
-webkit-transition-property: background-color;
|
-webkit-transition-property: background-color;
|
||||||
@ -976,84 +980,62 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before {
|
|||||||
-o-transition-delay: 0;
|
-o-transition-delay: 0;
|
||||||
-webkit-transition-delay: 0;
|
-webkit-transition-delay: 0;
|
||||||
transition-delay: 0; }
|
transition-delay: 0; }
|
||||||
/* line 51, ../../../../general/res/sass/helpers/_splitter.scss */
|
|
||||||
.splitter:active:after {
|
|
||||||
background-color: #0099cc !important; }
|
|
||||||
/* line 58, ../../../../general/res/sass/helpers/_splitter.scss */
|
|
||||||
.splitter:hover:after {
|
|
||||||
-moz-transition-property: background-color;
|
|
||||||
-o-transition-property: background-color;
|
|
||||||
-webkit-transition-property: background-color;
|
|
||||||
transition-property: background-color;
|
|
||||||
-moz-transition-duration: 150ms;
|
|
||||||
-o-transition-duration: 150ms;
|
|
||||||
-webkit-transition-duration: 150ms;
|
|
||||||
transition-duration: 150ms;
|
|
||||||
-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;
|
|
||||||
background-color: #595959; }
|
|
||||||
|
|
||||||
/* line 68, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 66, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal {
|
.split-layout.horizontal {
|
||||||
overflow: hidden; }
|
overflow: hidden; }
|
||||||
/* line 71, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 69, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal .pane {
|
.split-layout.horizontal .pane {
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0; }
|
right: 0; }
|
||||||
/* line 74, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 72, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal .pane.top {
|
.split-layout.horizontal .pane.top {
|
||||||
bottom: auto; }
|
bottom: auto; }
|
||||||
/* line 77, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 75, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal .pane.bottom {
|
.split-layout.horizontal .pane.bottom {
|
||||||
top: auto; }
|
top: auto; }
|
||||||
/* line 81, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 79, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal > .splitter {
|
.split-layout.horizontal > .splitter {
|
||||||
cursor: row-resize;
|
cursor: row-resize;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
height: 25px; }
|
height: 25px; }
|
||||||
/* line 86, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 84, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal > .splitter:after {
|
.split-layout.horizontal > .splitter:after {
|
||||||
top: 12px;
|
top: 12px;
|
||||||
bottom: 12px; }
|
bottom: 12px; }
|
||||||
/* line 94, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 92, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical .pane {
|
.split-layout.vertical .pane {
|
||||||
top: 0;
|
top: 0;
|
||||||
bottom: 0; }
|
bottom: 0; }
|
||||||
/* line 97, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 95, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical .pane.left {
|
.split-layout.vertical .pane.left {
|
||||||
right: auto; }
|
right: auto; }
|
||||||
/* line 100, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 98, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical .pane.right {
|
.split-layout.vertical .pane.right {
|
||||||
left: auto; }
|
left: auto; }
|
||||||
/* line 104, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 102, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter {
|
.split-layout.vertical > .splitter {
|
||||||
cursor: col-resize;
|
cursor: col-resize;
|
||||||
top: 0;
|
top: 0;
|
||||||
bottom: 0; }
|
bottom: 0; }
|
||||||
/* line 108, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 106, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter:not(.flush-right) {
|
.split-layout.vertical > .splitter:not(.flush-right) {
|
||||||
width: 25px; }
|
width: 25px; }
|
||||||
/* line 110, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 108, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter:not(.flush-right):after {
|
.split-layout.vertical > .splitter:not(.flush-right):after {
|
||||||
left: 12px;
|
left: 12px;
|
||||||
right: 12px; }
|
right: 12px; }
|
||||||
/* line 114, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 112, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter.flush-right {
|
.split-layout.vertical > .splitter.flush-right {
|
||||||
width: 13px; }
|
width: 13px; }
|
||||||
/* line 116, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 114, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter.flush-right:after {
|
.split-layout.vertical > .splitter.flush-right:after {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
left: auto;
|
left: auto;
|
||||||
right: 0;
|
right: 0;
|
||||||
width: 1px; }
|
width: 1px; }
|
||||||
/* line 120, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 118, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter.flush-right.edge-shdw {
|
.split-layout.vertical > .splitter.flush-right.edge-shdw {
|
||||||
background-image: url('');
|
background-image: url('');
|
||||||
background-size: 100%;
|
background-size: 100%;
|
||||||
@ -3774,31 +3756,34 @@ span.req {
|
|||||||
.s-menu-btn span.bar.l-flex.l-click-area .right {
|
.s-menu-btn span.bar.l-flex.l-click-area .right {
|
||||||
width: auto; }
|
width: auto; }
|
||||||
|
|
||||||
/* line 99, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 98, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .browse-area,
|
.user-environ .browse-area,
|
||||||
.user-environ .edit-area,
|
|
||||||
.user-environ .editor {
|
.user-environ .editor {
|
||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 25px; }
|
bottom: 25px; }
|
||||||
/* line 107, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 105, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .browse-area > .contents,
|
.user-environ .browse-area > .contents,
|
||||||
.user-environ .edit-area > .contents {
|
.user-environ .edit-area > .contents {
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0; }
|
right: 0; }
|
||||||
/* line 113, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 111, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .edit-area {
|
.user-environ .edit-area {
|
||||||
top: 45px; }
|
top: 45px;
|
||||||
/* line 116, ../../../../general/res/sass/user-environ/_layout.scss */
|
left: 10px;
|
||||||
|
right: 10px;
|
||||||
|
bottom: 35px; }
|
||||||
|
/* line 117, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .edit-area .tool-bar {
|
.user-environ .edit-area .tool-bar {
|
||||||
bottom: auto;
|
bottom: auto;
|
||||||
height: 30px;
|
height: 30px;
|
||||||
line-height: 25px; }
|
line-height: 25px; }
|
||||||
/* line 121, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 122, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .edit-area .work-area {
|
.user-environ .edit-area .object-holder.work-area {
|
||||||
top: 40px; }
|
top: 40px;
|
||||||
/* line 126, ../../../../general/res/sass/user-environ/_layout.scss */
|
overflow: auto; }
|
||||||
|
/* line 128, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .ue-bottom-bar {
|
.user-environ .ue-bottom-bar {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -3810,20 +3795,20 @@ span.req {
|
|||||||
height: auto;
|
height: auto;
|
||||||
top: auto;
|
top: auto;
|
||||||
height: 25px; }
|
height: 25px; }
|
||||||
/* line 131, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 133, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .ue-bottom-bar .status-holder {
|
.user-environ .ue-bottom-bar .status-holder {
|
||||||
z-index: 1; }
|
z-index: 1; }
|
||||||
/* line 135, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 137, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .ue-bottom-bar .app-logo {
|
.user-environ .ue-bottom-bar .app-logo {
|
||||||
left: auto;
|
left: auto;
|
||||||
width: 105px;
|
width: 105px;
|
||||||
z-index: 2; }
|
z-index: 2; }
|
||||||
|
|
||||||
/* line 143, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 145, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols {
|
.cols {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
*zoom: 1; }
|
*zoom: 1; }
|
||||||
/* line 145, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 147, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols .col {
|
.cols .col {
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
-webkit-box-sizing: border-box;
|
-webkit-box-sizing: border-box;
|
||||||
@ -3834,93 +3819,93 @@ span.req {
|
|||||||
margin-left: 1.5%;
|
margin-left: 1.5%;
|
||||||
padding-left: 5px;
|
padding-left: 5px;
|
||||||
position: relative; }
|
position: relative; }
|
||||||
/* line 153, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 155, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols .col:first-child {
|
.cols .col:first-child {
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
padding-left: 0; }
|
padding-left: 0; }
|
||||||
/* line 160, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 162, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-2 .col-1 {
|
.cols.cols-2 .col-1 {
|
||||||
min-width: 250px;
|
min-width: 250px;
|
||||||
width: 48.5%; }
|
width: 48.5%; }
|
||||||
/* line 166, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 168, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-2-ff .col-100px {
|
.cols.cols-2-ff .col-100px {
|
||||||
width: 100px; }
|
width: 100px; }
|
||||||
/* line 173, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 175, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-6 .col-1 {
|
.cols.cols-6 .col-1 {
|
||||||
min-width: 83.33333px;
|
min-width: 83.33333px;
|
||||||
width: 15.16667%; }
|
width: 15.16667%; }
|
||||||
/* line 179, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 181, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-16 .col-1 {
|
.cols.cols-16 .col-1 {
|
||||||
min-width: 31.25px;
|
min-width: 31.25px;
|
||||||
width: 4.75%; }
|
width: 4.75%; }
|
||||||
/* line 182, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 184, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-16 .col-2 {
|
.cols.cols-16 .col-2 {
|
||||||
min-width: 62.5px;
|
min-width: 62.5px;
|
||||||
width: 11%; }
|
width: 11%; }
|
||||||
/* line 185, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 187, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-16 .col-7 {
|
.cols.cols-16 .col-7 {
|
||||||
min-width: 218.75px;
|
min-width: 218.75px;
|
||||||
width: 42.25%; }
|
width: 42.25%; }
|
||||||
/* line 191, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 193, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-32 .col-2 {
|
.cols.cols-32 .col-2 {
|
||||||
min-width: 31.25px;
|
min-width: 31.25px;
|
||||||
width: 4.75%; }
|
width: 4.75%; }
|
||||||
/* line 194, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 196, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-32 .col-15 {
|
.cols.cols-32 .col-15 {
|
||||||
min-width: 234.375px;
|
min-width: 234.375px;
|
||||||
width: 45.375%; }
|
width: 45.375%; }
|
||||||
/* line 198, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 200, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols .l-row {
|
.cols .l-row {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
*zoom: 1;
|
*zoom: 1;
|
||||||
padding: 5px 0; }
|
padding: 5px 0; }
|
||||||
|
|
||||||
/* line 208, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 210, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.browse-mode .split-layout .split-pane-component.pane.treeview.left {
|
.browse-mode .split-layout .split-pane-component.pane.treeview.left {
|
||||||
min-width: 150px;
|
min-width: 150px;
|
||||||
max-width: 800px;
|
max-width: 800px;
|
||||||
width: 25%; }
|
width: 25%; }
|
||||||
/* line 213, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 215, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.browse-mode .split-layout .split-pane-component.pane.t-inspect.right {
|
.browse-mode .split-layout .split-pane-component.pane.t-inspect.right {
|
||||||
min-width: 200px;
|
min-width: 200px;
|
||||||
max-width: 600px;
|
max-width: 600px;
|
||||||
width: 20%; }
|
width: 20%; }
|
||||||
|
|
||||||
/* line 225, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 227, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.edit-mode .split-layout .split-pane-component.pane.right {
|
.edit-mode .split-layout .split-pane-component.pane.right {
|
||||||
width: 15%; }
|
width: 15%; }
|
||||||
/* line 227, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 229, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.edit-mode .split-layout .split-pane-component.pane.right .pane.bottom {
|
.edit-mode .split-layout .split-pane-component.pane.right .pane.bottom {
|
||||||
min-height: 50px;
|
min-height: 50px;
|
||||||
height: 30%; }
|
height: 30%; }
|
||||||
|
|
||||||
/* line 235, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 237, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane {
|
.pane {
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
-webkit-box-sizing: border-box;
|
-webkit-box-sizing: border-box;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
position: absolute; }
|
position: absolute; }
|
||||||
/* line 239, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 241, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .pane-header {
|
.pane .pane-header {
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
height: 24px;
|
height: 24px;
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
margin-bottom: 5px; }
|
margin-bottom: 5px; }
|
||||||
/* line 246, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 248, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .primary-pane {
|
.pane .primary-pane {
|
||||||
z-index: 2; }
|
z-index: 2; }
|
||||||
/* line 264, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 266, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane.treeview.left .search-holder {
|
.pane.treeview.left .search-holder {
|
||||||
top: 34px; }
|
top: 34px; }
|
||||||
/* line 267, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 269, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane.treeview.left .tree-holder {
|
.pane.treeview.left .tree-holder {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
top: 64px; }
|
top: 64px; }
|
||||||
/* line 273, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 275, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane {
|
.pane .mini-tab-icon.toggle-pane {
|
||||||
z-index: 5; }
|
z-index: 5; }
|
||||||
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
||||||
/* line 273, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 275, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane {
|
.pane .mini-tab-icon.toggle-pane {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
height: 24px;
|
height: 24px;
|
||||||
@ -3930,33 +3915,33 @@ span.req {
|
|||||||
content:"M"
|
content:"M"
|
||||||
}
|
}
|
||||||
}*/ }
|
}*/ }
|
||||||
/* line 282, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 284, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane:after {
|
.pane .mini-tab-icon.toggle-pane:after {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
/* line 287, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 289, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.collapsed:before {
|
.pane .mini-tab-icon.toggle-pane.collapsed:before {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
/* line 290, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 292, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.collapsed:after {
|
.pane .mini-tab-icon.toggle-pane.collapsed:after {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
/* line 294, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 296, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left {
|
||||||
left: 0;
|
left: 0;
|
||||||
-moz-transform: translateX(-34px);
|
-moz-transform: translateX(-34px);
|
||||||
-ms-transform: translateX(-34px);
|
-ms-transform: translateX(-34px);
|
||||||
-webkit-transform: translateX(-34px);
|
-webkit-transform: translateX(-34px);
|
||||||
transform: translateX(-34px); }
|
transform: translateX(-34px); }
|
||||||
/* line 297, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 299, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:after {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:after {
|
||||||
content: '\6d'; }
|
content: '\6d'; }
|
||||||
/* line 300, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 302, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed {
|
||||||
left: 0;
|
left: 0;
|
||||||
-moz-transform: translateX(-15px);
|
-moz-transform: translateX(-15px);
|
||||||
-ms-transform: translateX(-15px);
|
-ms-transform: translateX(-15px);
|
||||||
-webkit-transform: translateX(-15px);
|
-webkit-transform: translateX(-15px);
|
||||||
transform: translateX(-15px); }
|
transform: translateX(-15px); }
|
||||||
/* line 304, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 306, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
-o-transition-property: opacity;
|
-o-transition-property: opacity;
|
||||||
@ -3974,16 +3959,16 @@ span.req {
|
|||||||
-o-transition-delay: 200ms;
|
-o-transition-delay: 200ms;
|
||||||
-webkit-transition-delay: 200ms;
|
-webkit-transition-delay: 200ms;
|
||||||
transition-delay: 200ms; }
|
transition-delay: 200ms; }
|
||||||
/* line 308, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 310, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right {
|
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right {
|
||||||
right: 10px; }
|
right: 10px; }
|
||||||
/* line 310, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 312, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right:after {
|
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right:after {
|
||||||
content: '\e608'; }
|
content: '\e608'; }
|
||||||
/* line 313, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 315, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right.collapsed {
|
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right.collapsed {
|
||||||
right: 5px; } }
|
right: 5px; } }
|
||||||
/* line 327, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 329, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane.items .object-browse-bar .left.abs, .pane.items .object-browse-bar .left.l-inspect, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.pager, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.pager,
|
.pane.items .object-browse-bar .left.abs, .pane.items .object-browse-bar .left.l-inspect, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.pager, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.pager,
|
||||||
.pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.val,
|
.pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.val,
|
||||||
.l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.val, .pane.items .object-browse-bar .s-menu-btn span.left.l-click-area, .s-menu-btn .pane.items .object-browse-bar span.left.l-click-area,
|
.l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.val, .pane.items .object-browse-bar .s-menu-btn span.left.l-click-area, .s-menu-btn .pane.items .object-browse-bar span.left.l-click-area,
|
||||||
@ -3997,7 +3982,7 @@ span.req {
|
|||||||
.s-menu-btn .pane.items .object-browse-bar span.right.l-click-area {
|
.s-menu-btn .pane.items .object-browse-bar span.right.l-click-area {
|
||||||
top: auto; }
|
top: auto; }
|
||||||
|
|
||||||
/* line 335, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 337, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout {
|
.split-layout {
|
||||||
/* &.vertical {
|
/* &.vertical {
|
||||||
// Slides left and right
|
// Slides left and right
|
||||||
@ -4012,40 +3997,40 @@ span.req {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}*/ }
|
}*/ }
|
||||||
/* line 338, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 340, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout.horizontal > .pane {
|
.split-layout.horizontal > .pane {
|
||||||
margin-top: 5px; }
|
margin-top: 5px; }
|
||||||
/* line 341, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 343, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout.horizontal > .pane:first-child {
|
.split-layout.horizontal > .pane:first-child {
|
||||||
margin-top: 0; }
|
margin-top: 0; }
|
||||||
/* line 361, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 363, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-create-and-search {
|
.split-layout .holder.holder-create-and-search {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 10px;
|
bottom: 10px;
|
||||||
left: 10px; }
|
left: 10px; }
|
||||||
/* line 368, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 370, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-object-and-inspector {
|
.split-layout .holder.holder-object-and-inspector {
|
||||||
top: 0;
|
top: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: 0; }
|
left: 0; }
|
||||||
/* line 373, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 375, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-object-and-inspector .holder-object {
|
.split-layout .holder.holder-object-and-inspector .holder-object {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
bottom: 10px; }
|
bottom: 10px; }
|
||||||
/* line 377, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 379, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-object-and-inspector .holder-inspector-elements {
|
.split-layout .holder.holder-object-and-inspector .holder-inspector-elements {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
bottom: 10px;
|
bottom: 10px;
|
||||||
left: 10px;
|
left: 10px;
|
||||||
right: 10px; }
|
right: 10px; }
|
||||||
|
|
||||||
/* line 387, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 389, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-holder {
|
.object-holder {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
top: 34px; }
|
top: 34px; }
|
||||||
/* line 390, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 392, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-holder > ng-include {
|
.object-holder > ng-include {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -4055,11 +4040,11 @@ span.req {
|
|||||||
left: 0;
|
left: 0;
|
||||||
width: auto;
|
width: auto;
|
||||||
height: auto; }
|
height: auto; }
|
||||||
/* line 394, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 396, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-holder.l-controls-visible.l-time-controller-visible {
|
.object-holder.l-controls-visible.l-time-controller-visible {
|
||||||
bottom: 88px; }
|
bottom: 88px; }
|
||||||
|
|
||||||
/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 402, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .s-btn, .object-browse-bar .s-menu-btn,
|
.object-browse-bar .s-btn, .object-browse-bar .s-menu-btn,
|
||||||
.top-bar .buttons-main .s-btn,
|
.top-bar .buttons-main .s-btn,
|
||||||
.top-bar .buttons-main .s-menu-btn,
|
.top-bar .buttons-main .s-menu-btn,
|
||||||
@ -4071,12 +4056,12 @@ span.req {
|
|||||||
line-height: 25px;
|
line-height: 25px;
|
||||||
vertical-align: top; }
|
vertical-align: top; }
|
||||||
|
|
||||||
/* line 413, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 415, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .view-switcher,
|
.object-browse-bar .view-switcher,
|
||||||
.top-bar .view-switcher {
|
.top-bar .view-switcher {
|
||||||
margin-right: 20px; }
|
margin-right: 20px; }
|
||||||
|
|
||||||
/* line 418, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 420, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar {
|
.object-browse-bar {
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -4092,28 +4077,28 @@ span.req {
|
|||||||
height: 24px;
|
height: 24px;
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
white-space: nowrap; }
|
white-space: nowrap; }
|
||||||
/* line 426, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 428, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .left {
|
.object-browse-bar .left {
|
||||||
padding-right: 20px; }
|
padding-right: 20px; }
|
||||||
/* line 428, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 430, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .left .l-back {
|
.object-browse-bar .left .l-back {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
float: left;
|
float: left;
|
||||||
margin-right: 10px; }
|
margin-right: 10px; }
|
||||||
|
|
||||||
/* line 436, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 438, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.l-flex {
|
.l-flex {
|
||||||
display: flex;
|
display: flex;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
flex-flow: row nowrap;
|
flex-flow: row nowrap;
|
||||||
-webkit-flex-flow: row nowrap; }
|
-webkit-flex-flow: row nowrap; }
|
||||||
/* line 439, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 441, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.l-flex .left {
|
.l-flex .left {
|
||||||
flex: 1 1 0;
|
flex: 1 1 0;
|
||||||
-webkit-flex: 1 1 0;
|
-webkit-flex: 1 1 0;
|
||||||
padding-right: 10px; }
|
padding-right: 10px; }
|
||||||
|
|
||||||
/* line 449, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 451, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-hidden {
|
.pane-tree-hidden {
|
||||||
/*.holder-create-and-search {
|
/*.holder-create-and-search {
|
||||||
@include trans-prop-nice((top, left), 250ms);
|
@include trans-prop-nice((top, left), 250ms);
|
||||||
@ -4134,13 +4119,13 @@ span.req {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}*/ }
|
}*/ }
|
||||||
/* line 452, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 454, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-hidden .tree-holder,
|
.pane-tree-hidden .tree-holder,
|
||||||
.pane-tree-hidden .splitter-treeview,
|
.pane-tree-hidden .splitter-treeview,
|
||||||
.pane-tree-hidden .holder-create-and-search {
|
.pane-tree-hidden .holder-create-and-search {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
/* line 481, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 483, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-showing .tree-holder,
|
.pane-tree-showing .tree-holder,
|
||||||
.pane-tree-showing .splitter-treeview {
|
.pane-tree-showing .splitter-treeview {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
@ -4160,7 +4145,7 @@ span.req {
|
|||||||
-webkit-transition-delay: 250ms;
|
-webkit-transition-delay: 250ms;
|
||||||
transition-delay: 250ms;
|
transition-delay: 250ms;
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
/* line 487, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 489, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-showing .holder-create-and-search {
|
.pane-tree-showing .holder-create-and-search {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
-o-transition-property: opacity;
|
-o-transition-property: opacity;
|
||||||
@ -4179,7 +4164,7 @@ span.req {
|
|||||||
-webkit-transition-delay: 200ms;
|
-webkit-transition-delay: 200ms;
|
||||||
transition-delay: 200ms; }
|
transition-delay: 200ms; }
|
||||||
|
|
||||||
/* line 494, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 496, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-inspect-showing .l-object-and-inspector .l-inspect,
|
.pane-inspect-showing .l-object-and-inspector .l-inspect,
|
||||||
.pane-inspect-showing .l-object-and-inspector .splitter-inspect {
|
.pane-inspect-showing .l-object-and-inspector .splitter-inspect {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
@ -4200,21 +4185,21 @@ span.req {
|
|||||||
transition-delay: 250ms;
|
transition-delay: 250ms;
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
/* line 503, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 505, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-inspect-hidden .l-object-and-inspector .l-inspect,
|
.pane-inspect-hidden .l-object-and-inspector .l-inspect,
|
||||||
.pane-inspect-hidden .l-object-and-inspector .splitter-inspect {
|
.pane-inspect-hidden .l-object-and-inspector .splitter-inspect {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
||||||
/* line 512, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 514, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-hidden .pane.right.primary-pane {
|
.pane-tree-hidden .pane.right.primary-pane {
|
||||||
left: 20px !important; }
|
left: 20px !important; }
|
||||||
|
|
||||||
/* line 515, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 517, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-inspect-hidden .l-object-and-inspector .pane.left {
|
.pane-inspect-hidden .l-object-and-inspector .pane.left {
|
||||||
right: 20px !important; }
|
right: 20px !important; }
|
||||||
|
|
||||||
/* line 518, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 520, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane:not(.resizing) {
|
.pane:not(.resizing) {
|
||||||
-moz-transition-property: width, left, right;
|
-moz-transition-property: width, left, right;
|
||||||
-o-transition-property: width, left, right;
|
-o-transition-property: width, left, right;
|
||||||
|
@ -958,83 +958,65 @@ tr[class*="s-limit"].s-limit-lwr td:first-child:before {
|
|||||||
height: auto;
|
height: auto;
|
||||||
background: #e3e3e3;
|
background: #e3e3e3;
|
||||||
display: block; }
|
display: block; }
|
||||||
/* line 46, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 47, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.splitter:not(:active):after {
|
|
||||||
-moz-transition-property: background-color;
|
|
||||||
-o-transition-property: background-color;
|
|
||||||
-webkit-transition-property: background-color;
|
|
||||||
transition-property: background-color;
|
|
||||||
-moz-transition-duration: 150ms;
|
|
||||||
-o-transition-duration: 150ms;
|
|
||||||
-webkit-transition-duration: 150ms;
|
|
||||||
transition-duration: 150ms;
|
|
||||||
-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; }
|
|
||||||
/* line 51, ../../../../general/res/sass/helpers/_splitter.scss */
|
|
||||||
.splitter:active:after {
|
.splitter:active:after {
|
||||||
background-color: #0099cc !important; }
|
background-color: #0099cc !important; }
|
||||||
|
|
||||||
/* line 68, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 66, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal {
|
.split-layout.horizontal {
|
||||||
overflow: hidden; }
|
overflow: hidden; }
|
||||||
/* line 71, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 69, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal .pane {
|
.split-layout.horizontal .pane {
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0; }
|
right: 0; }
|
||||||
/* line 74, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 72, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal .pane.top {
|
.split-layout.horizontal .pane.top {
|
||||||
bottom: auto; }
|
bottom: auto; }
|
||||||
/* line 77, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 75, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal .pane.bottom {
|
.split-layout.horizontal .pane.bottom {
|
||||||
top: auto; }
|
top: auto; }
|
||||||
/* line 81, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 79, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal > .splitter {
|
.split-layout.horizontal > .splitter {
|
||||||
cursor: row-resize;
|
cursor: row-resize;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
height: 24px; }
|
height: 24px; }
|
||||||
/* line 86, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 84, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.horizontal > .splitter:after {
|
.split-layout.horizontal > .splitter:after {
|
||||||
top: 11px;
|
top: 11px;
|
||||||
bottom: 11px; }
|
bottom: 11px; }
|
||||||
/* line 94, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 92, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical .pane {
|
.split-layout.vertical .pane {
|
||||||
top: 0;
|
top: 0;
|
||||||
bottom: 0; }
|
bottom: 0; }
|
||||||
/* line 97, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 95, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical .pane.left {
|
.split-layout.vertical .pane.left {
|
||||||
right: auto; }
|
right: auto; }
|
||||||
/* line 100, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 98, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical .pane.right {
|
.split-layout.vertical .pane.right {
|
||||||
left: auto; }
|
left: auto; }
|
||||||
/* line 104, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 102, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter {
|
.split-layout.vertical > .splitter {
|
||||||
cursor: col-resize;
|
cursor: col-resize;
|
||||||
top: 0;
|
top: 0;
|
||||||
bottom: 0; }
|
bottom: 0; }
|
||||||
/* line 108, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 106, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter:not(.flush-right) {
|
.split-layout.vertical > .splitter:not(.flush-right) {
|
||||||
width: 24px; }
|
width: 24px; }
|
||||||
/* line 110, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 108, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter:not(.flush-right):after {
|
.split-layout.vertical > .splitter:not(.flush-right):after {
|
||||||
left: 11px;
|
left: 11px;
|
||||||
right: 11px; }
|
right: 11px; }
|
||||||
/* line 114, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 112, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter.flush-right {
|
.split-layout.vertical > .splitter.flush-right {
|
||||||
width: 12px; }
|
width: 12px; }
|
||||||
/* line 116, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 114, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter.flush-right:after {
|
.split-layout.vertical > .splitter.flush-right:after {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
left: auto;
|
left: auto;
|
||||||
right: 0;
|
right: 0;
|
||||||
width: 2px; }
|
width: 2px; }
|
||||||
/* line 120, ../../../../general/res/sass/helpers/_splitter.scss */
|
/* line 118, ../../../../general/res/sass/helpers/_splitter.scss */
|
||||||
.split-layout.vertical > .splitter.flush-right.edge-shdw {
|
.split-layout.vertical > .splitter.flush-right.edge-shdw {
|
||||||
background-image: url('');
|
background-image: url('');
|
||||||
background-size: 100%;
|
background-size: 100%;
|
||||||
@ -3696,31 +3678,34 @@ span.req {
|
|||||||
.s-menu-btn span.bar.l-flex.l-click-area .right {
|
.s-menu-btn span.bar.l-flex.l-click-area .right {
|
||||||
width: auto; }
|
width: auto; }
|
||||||
|
|
||||||
/* line 99, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 98, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .browse-area,
|
.user-environ .browse-area,
|
||||||
.user-environ .edit-area,
|
|
||||||
.user-environ .editor {
|
.user-environ .editor {
|
||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 25px; }
|
bottom: 25px; }
|
||||||
/* line 107, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 105, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .browse-area > .contents,
|
.user-environ .browse-area > .contents,
|
||||||
.user-environ .edit-area > .contents {
|
.user-environ .edit-area > .contents {
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0; }
|
right: 0; }
|
||||||
/* line 113, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 111, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .edit-area {
|
.user-environ .edit-area {
|
||||||
top: 45px; }
|
top: 45px;
|
||||||
/* line 116, ../../../../general/res/sass/user-environ/_layout.scss */
|
left: 10px;
|
||||||
|
right: 10px;
|
||||||
|
bottom: 35px; }
|
||||||
|
/* line 117, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .edit-area .tool-bar {
|
.user-environ .edit-area .tool-bar {
|
||||||
bottom: auto;
|
bottom: auto;
|
||||||
height: 30px;
|
height: 30px;
|
||||||
line-height: 25px; }
|
line-height: 25px; }
|
||||||
/* line 121, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 122, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .edit-area .work-area {
|
.user-environ .edit-area .object-holder.work-area {
|
||||||
top: 40px; }
|
top: 40px;
|
||||||
/* line 126, ../../../../general/res/sass/user-environ/_layout.scss */
|
overflow: auto; }
|
||||||
|
/* line 128, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .ue-bottom-bar {
|
.user-environ .ue-bottom-bar {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -3732,20 +3717,20 @@ span.req {
|
|||||||
height: auto;
|
height: auto;
|
||||||
top: auto;
|
top: auto;
|
||||||
height: 25px; }
|
height: 25px; }
|
||||||
/* line 131, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 133, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .ue-bottom-bar .status-holder {
|
.user-environ .ue-bottom-bar .status-holder {
|
||||||
z-index: 1; }
|
z-index: 1; }
|
||||||
/* line 135, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 137, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.user-environ .ue-bottom-bar .app-logo {
|
.user-environ .ue-bottom-bar .app-logo {
|
||||||
left: auto;
|
left: auto;
|
||||||
width: 105px;
|
width: 105px;
|
||||||
z-index: 2; }
|
z-index: 2; }
|
||||||
|
|
||||||
/* line 143, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 145, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols {
|
.cols {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
*zoom: 1; }
|
*zoom: 1; }
|
||||||
/* line 145, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 147, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols .col {
|
.cols .col {
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
-webkit-box-sizing: border-box;
|
-webkit-box-sizing: border-box;
|
||||||
@ -3756,93 +3741,93 @@ span.req {
|
|||||||
margin-left: 1.5%;
|
margin-left: 1.5%;
|
||||||
padding-left: 5px;
|
padding-left: 5px;
|
||||||
position: relative; }
|
position: relative; }
|
||||||
/* line 153, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 155, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols .col:first-child {
|
.cols .col:first-child {
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
padding-left: 0; }
|
padding-left: 0; }
|
||||||
/* line 160, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 162, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-2 .col-1 {
|
.cols.cols-2 .col-1 {
|
||||||
min-width: 250px;
|
min-width: 250px;
|
||||||
width: 48.5%; }
|
width: 48.5%; }
|
||||||
/* line 166, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 168, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-2-ff .col-100px {
|
.cols.cols-2-ff .col-100px {
|
||||||
width: 100px; }
|
width: 100px; }
|
||||||
/* line 173, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 175, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-6 .col-1 {
|
.cols.cols-6 .col-1 {
|
||||||
min-width: 83.33333px;
|
min-width: 83.33333px;
|
||||||
width: 15.16667%; }
|
width: 15.16667%; }
|
||||||
/* line 179, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 181, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-16 .col-1 {
|
.cols.cols-16 .col-1 {
|
||||||
min-width: 31.25px;
|
min-width: 31.25px;
|
||||||
width: 4.75%; }
|
width: 4.75%; }
|
||||||
/* line 182, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 184, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-16 .col-2 {
|
.cols.cols-16 .col-2 {
|
||||||
min-width: 62.5px;
|
min-width: 62.5px;
|
||||||
width: 11%; }
|
width: 11%; }
|
||||||
/* line 185, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 187, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-16 .col-7 {
|
.cols.cols-16 .col-7 {
|
||||||
min-width: 218.75px;
|
min-width: 218.75px;
|
||||||
width: 42.25%; }
|
width: 42.25%; }
|
||||||
/* line 191, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 193, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-32 .col-2 {
|
.cols.cols-32 .col-2 {
|
||||||
min-width: 31.25px;
|
min-width: 31.25px;
|
||||||
width: 4.75%; }
|
width: 4.75%; }
|
||||||
/* line 194, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 196, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols.cols-32 .col-15 {
|
.cols.cols-32 .col-15 {
|
||||||
min-width: 234.375px;
|
min-width: 234.375px;
|
||||||
width: 45.375%; }
|
width: 45.375%; }
|
||||||
/* line 198, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 200, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.cols .l-row {
|
.cols .l-row {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
*zoom: 1;
|
*zoom: 1;
|
||||||
padding: 5px 0; }
|
padding: 5px 0; }
|
||||||
|
|
||||||
/* line 208, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 210, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.browse-mode .split-layout .split-pane-component.pane.treeview.left {
|
.browse-mode .split-layout .split-pane-component.pane.treeview.left {
|
||||||
min-width: 150px;
|
min-width: 150px;
|
||||||
max-width: 800px;
|
max-width: 800px;
|
||||||
width: 25%; }
|
width: 25%; }
|
||||||
/* line 213, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 215, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.browse-mode .split-layout .split-pane-component.pane.t-inspect.right {
|
.browse-mode .split-layout .split-pane-component.pane.t-inspect.right {
|
||||||
min-width: 200px;
|
min-width: 200px;
|
||||||
max-width: 600px;
|
max-width: 600px;
|
||||||
width: 20%; }
|
width: 20%; }
|
||||||
|
|
||||||
/* line 225, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 227, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.edit-mode .split-layout .split-pane-component.pane.right {
|
.edit-mode .split-layout .split-pane-component.pane.right {
|
||||||
width: 15%; }
|
width: 15%; }
|
||||||
/* line 227, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 229, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.edit-mode .split-layout .split-pane-component.pane.right .pane.bottom {
|
.edit-mode .split-layout .split-pane-component.pane.right .pane.bottom {
|
||||||
min-height: 50px;
|
min-height: 50px;
|
||||||
height: 30%; }
|
height: 30%; }
|
||||||
|
|
||||||
/* line 235, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 237, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane {
|
.pane {
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
-webkit-box-sizing: border-box;
|
-webkit-box-sizing: border-box;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
position: absolute; }
|
position: absolute; }
|
||||||
/* line 239, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 241, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .pane-header {
|
.pane .pane-header {
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
height: 24px;
|
height: 24px;
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
margin-bottom: 5px; }
|
margin-bottom: 5px; }
|
||||||
/* line 246, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 248, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .primary-pane {
|
.pane .primary-pane {
|
||||||
z-index: 2; }
|
z-index: 2; }
|
||||||
/* line 264, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 266, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane.treeview.left .search-holder {
|
.pane.treeview.left .search-holder {
|
||||||
top: 34px; }
|
top: 34px; }
|
||||||
/* line 267, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 269, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane.treeview.left .tree-holder {
|
.pane.treeview.left .tree-holder {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
top: 64px; }
|
top: 64px; }
|
||||||
/* line 273, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 275, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane {
|
.pane .mini-tab-icon.toggle-pane {
|
||||||
z-index: 5; }
|
z-index: 5; }
|
||||||
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
||||||
/* line 273, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 275, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane {
|
.pane .mini-tab-icon.toggle-pane {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
height: 24px;
|
height: 24px;
|
||||||
@ -3852,33 +3837,33 @@ span.req {
|
|||||||
content:"M"
|
content:"M"
|
||||||
}
|
}
|
||||||
}*/ }
|
}*/ }
|
||||||
/* line 282, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 284, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane:after {
|
.pane .mini-tab-icon.toggle-pane:after {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
/* line 287, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 289, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.collapsed:before {
|
.pane .mini-tab-icon.toggle-pane.collapsed:before {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
/* line 290, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 292, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.collapsed:after {
|
.pane .mini-tab-icon.toggle-pane.collapsed:after {
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
/* line 294, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 296, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left {
|
||||||
left: 0;
|
left: 0;
|
||||||
-moz-transform: translateX(-33px);
|
-moz-transform: translateX(-33px);
|
||||||
-ms-transform: translateX(-33px);
|
-ms-transform: translateX(-33px);
|
||||||
-webkit-transform: translateX(-33px);
|
-webkit-transform: translateX(-33px);
|
||||||
transform: translateX(-33px); }
|
transform: translateX(-33px); }
|
||||||
/* line 297, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 299, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:after {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:after {
|
||||||
content: '\6d'; }
|
content: '\6d'; }
|
||||||
/* line 300, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 302, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left.collapsed {
|
||||||
left: 0;
|
left: 0;
|
||||||
-moz-transform: translateX(-15px);
|
-moz-transform: translateX(-15px);
|
||||||
-ms-transform: translateX(-15px);
|
-ms-transform: translateX(-15px);
|
||||||
-webkit-transform: translateX(-15px);
|
-webkit-transform: translateX(-15px);
|
||||||
transform: translateX(-15px); }
|
transform: translateX(-15px); }
|
||||||
/* line 304, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 306, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before {
|
.pane .mini-tab-icon.toggle-pane.toggle-tree.anchor-left:not(.collapsed):before {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
-o-transition-property: opacity;
|
-o-transition-property: opacity;
|
||||||
@ -3896,16 +3881,16 @@ span.req {
|
|||||||
-o-transition-delay: 200ms;
|
-o-transition-delay: 200ms;
|
||||||
-webkit-transition-delay: 200ms;
|
-webkit-transition-delay: 200ms;
|
||||||
transition-delay: 200ms; }
|
transition-delay: 200ms; }
|
||||||
/* line 308, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 310, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right {
|
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right {
|
||||||
right: 10px; }
|
right: 10px; }
|
||||||
/* line 310, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 312, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right:after {
|
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right:after {
|
||||||
content: '\e608'; }
|
content: '\e608'; }
|
||||||
/* line 313, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 315, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right.collapsed {
|
.pane .mini-tab-icon.toggle-pane.toggle-inspect.anchor-right.collapsed {
|
||||||
right: 5px; } }
|
right: 5px; } }
|
||||||
/* line 327, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 329, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane.items .object-browse-bar .left.abs, .pane.items .object-browse-bar .left.l-inspect, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.pager, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.pager,
|
.pane.items .object-browse-bar .left.abs, .pane.items .object-browse-bar .left.l-inspect, .pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.pager, .l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.pager,
|
||||||
.pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.val,
|
.pane.items .object-browse-bar .l-datetime-picker .l-month-year-pager .left.val,
|
||||||
.l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.val, .pane.items .object-browse-bar .s-menu-btn span.left.l-click-area, .s-menu-btn .pane.items .object-browse-bar span.left.l-click-area,
|
.l-datetime-picker .l-month-year-pager .pane.items .object-browse-bar .left.val, .pane.items .object-browse-bar .s-menu-btn span.left.l-click-area, .s-menu-btn .pane.items .object-browse-bar span.left.l-click-area,
|
||||||
@ -3919,7 +3904,7 @@ span.req {
|
|||||||
.s-menu-btn .pane.items .object-browse-bar span.right.l-click-area {
|
.s-menu-btn .pane.items .object-browse-bar span.right.l-click-area {
|
||||||
top: auto; }
|
top: auto; }
|
||||||
|
|
||||||
/* line 335, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 337, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout {
|
.split-layout {
|
||||||
/* &.vertical {
|
/* &.vertical {
|
||||||
// Slides left and right
|
// Slides left and right
|
||||||
@ -3934,40 +3919,40 @@ span.req {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}*/ }
|
}*/ }
|
||||||
/* line 338, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 340, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout.horizontal > .pane {
|
.split-layout.horizontal > .pane {
|
||||||
margin-top: 5px; }
|
margin-top: 5px; }
|
||||||
/* line 341, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 343, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout.horizontal > .pane:first-child {
|
.split-layout.horizontal > .pane:first-child {
|
||||||
margin-top: 0; }
|
margin-top: 0; }
|
||||||
/* line 361, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 363, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-create-and-search {
|
.split-layout .holder.holder-create-and-search {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 10px;
|
bottom: 10px;
|
||||||
left: 10px; }
|
left: 10px; }
|
||||||
/* line 368, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 370, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-object-and-inspector {
|
.split-layout .holder.holder-object-and-inspector {
|
||||||
top: 0;
|
top: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: 0; }
|
left: 0; }
|
||||||
/* line 373, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 375, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-object-and-inspector .holder-object {
|
.split-layout .holder.holder-object-and-inspector .holder-object {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
bottom: 10px; }
|
bottom: 10px; }
|
||||||
/* line 377, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 379, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.split-layout .holder.holder-object-and-inspector .holder-inspector-elements {
|
.split-layout .holder.holder-object-and-inspector .holder-inspector-elements {
|
||||||
top: 10px;
|
top: 10px;
|
||||||
bottom: 10px;
|
bottom: 10px;
|
||||||
left: 10px;
|
left: 10px;
|
||||||
right: 10px; }
|
right: 10px; }
|
||||||
|
|
||||||
/* line 387, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 389, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-holder {
|
.object-holder {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
top: 34px; }
|
top: 34px; }
|
||||||
/* line 390, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 392, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-holder > ng-include {
|
.object-holder > ng-include {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -3977,11 +3962,11 @@ span.req {
|
|||||||
left: 0;
|
left: 0;
|
||||||
width: auto;
|
width: auto;
|
||||||
height: auto; }
|
height: auto; }
|
||||||
/* line 394, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 396, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-holder.l-controls-visible.l-time-controller-visible {
|
.object-holder.l-controls-visible.l-time-controller-visible {
|
||||||
bottom: 88px; }
|
bottom: 88px; }
|
||||||
|
|
||||||
/* line 400, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 402, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .s-btn, .object-browse-bar .s-menu-btn,
|
.object-browse-bar .s-btn, .object-browse-bar .s-menu-btn,
|
||||||
.top-bar .buttons-main .s-btn,
|
.top-bar .buttons-main .s-btn,
|
||||||
.top-bar .buttons-main .s-menu-btn,
|
.top-bar .buttons-main .s-menu-btn,
|
||||||
@ -3993,12 +3978,12 @@ span.req {
|
|||||||
line-height: 25px;
|
line-height: 25px;
|
||||||
vertical-align: top; }
|
vertical-align: top; }
|
||||||
|
|
||||||
/* line 413, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 415, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .view-switcher,
|
.object-browse-bar .view-switcher,
|
||||||
.top-bar .view-switcher {
|
.top-bar .view-switcher {
|
||||||
margin-right: 20px; }
|
margin-right: 20px; }
|
||||||
|
|
||||||
/* line 418, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 420, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar {
|
.object-browse-bar {
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -4014,28 +3999,28 @@ span.req {
|
|||||||
height: 24px;
|
height: 24px;
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
white-space: nowrap; }
|
white-space: nowrap; }
|
||||||
/* line 426, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 428, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .left {
|
.object-browse-bar .left {
|
||||||
padding-right: 20px; }
|
padding-right: 20px; }
|
||||||
/* line 428, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 430, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.object-browse-bar .left .l-back {
|
.object-browse-bar .left .l-back {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
float: left;
|
float: left;
|
||||||
margin-right: 10px; }
|
margin-right: 10px; }
|
||||||
|
|
||||||
/* line 436, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 438, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.l-flex {
|
.l-flex {
|
||||||
display: flex;
|
display: flex;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
flex-flow: row nowrap;
|
flex-flow: row nowrap;
|
||||||
-webkit-flex-flow: row nowrap; }
|
-webkit-flex-flow: row nowrap; }
|
||||||
/* line 439, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 441, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.l-flex .left {
|
.l-flex .left {
|
||||||
flex: 1 1 0;
|
flex: 1 1 0;
|
||||||
-webkit-flex: 1 1 0;
|
-webkit-flex: 1 1 0;
|
||||||
padding-right: 10px; }
|
padding-right: 10px; }
|
||||||
|
|
||||||
/* line 449, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 451, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-hidden {
|
.pane-tree-hidden {
|
||||||
/*.holder-create-and-search {
|
/*.holder-create-and-search {
|
||||||
@include trans-prop-nice((top, left), 250ms);
|
@include trans-prop-nice((top, left), 250ms);
|
||||||
@ -4056,13 +4041,13 @@ span.req {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}*/ }
|
}*/ }
|
||||||
/* line 452, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 454, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-hidden .tree-holder,
|
.pane-tree-hidden .tree-holder,
|
||||||
.pane-tree-hidden .splitter-treeview,
|
.pane-tree-hidden .splitter-treeview,
|
||||||
.pane-tree-hidden .holder-create-and-search {
|
.pane-tree-hidden .holder-create-and-search {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
/* line 481, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 483, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-showing .tree-holder,
|
.pane-tree-showing .tree-holder,
|
||||||
.pane-tree-showing .splitter-treeview {
|
.pane-tree-showing .splitter-treeview {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
@ -4082,7 +4067,7 @@ span.req {
|
|||||||
-webkit-transition-delay: 250ms;
|
-webkit-transition-delay: 250ms;
|
||||||
transition-delay: 250ms;
|
transition-delay: 250ms;
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
/* line 487, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 489, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-showing .holder-create-and-search {
|
.pane-tree-showing .holder-create-and-search {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
-o-transition-property: opacity;
|
-o-transition-property: opacity;
|
||||||
@ -4101,7 +4086,7 @@ span.req {
|
|||||||
-webkit-transition-delay: 200ms;
|
-webkit-transition-delay: 200ms;
|
||||||
transition-delay: 200ms; }
|
transition-delay: 200ms; }
|
||||||
|
|
||||||
/* line 494, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 496, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-inspect-showing .l-object-and-inspector .l-inspect,
|
.pane-inspect-showing .l-object-and-inspector .l-inspect,
|
||||||
.pane-inspect-showing .l-object-and-inspector .splitter-inspect {
|
.pane-inspect-showing .l-object-and-inspector .splitter-inspect {
|
||||||
-moz-transition-property: opacity;
|
-moz-transition-property: opacity;
|
||||||
@ -4122,21 +4107,21 @@ span.req {
|
|||||||
transition-delay: 250ms;
|
transition-delay: 250ms;
|
||||||
opacity: 1; }
|
opacity: 1; }
|
||||||
|
|
||||||
/* line 503, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 505, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-inspect-hidden .l-object-and-inspector .l-inspect,
|
.pane-inspect-hidden .l-object-and-inspector .l-inspect,
|
||||||
.pane-inspect-hidden .l-object-and-inspector .splitter-inspect {
|
.pane-inspect-hidden .l-object-and-inspector .splitter-inspect {
|
||||||
opacity: 0; }
|
opacity: 0; }
|
||||||
|
|
||||||
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
@media screen and (min-device-width: 800px) and (min-device-height: 1025px), screen and (min-device-width: 1025px) and (min-device-height: 800px) {
|
||||||
/* line 512, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 514, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-tree-hidden .pane.right.primary-pane {
|
.pane-tree-hidden .pane.right.primary-pane {
|
||||||
left: 20px !important; }
|
left: 20px !important; }
|
||||||
|
|
||||||
/* line 515, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 517, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane-inspect-hidden .l-object-and-inspector .pane.left {
|
.pane-inspect-hidden .l-object-and-inspector .pane.left {
|
||||||
right: 20px !important; }
|
right: 20px !important; }
|
||||||
|
|
||||||
/* line 518, ../../../../general/res/sass/user-environ/_layout.scss */
|
/* line 520, ../../../../general/res/sass/user-environ/_layout.scss */
|
||||||
.pane:not(.resizing) {
|
.pane:not(.resizing) {
|
||||||
-moz-transition-property: width, left, right;
|
-moz-transition-property: width, left, right;
|
||||||
-o-transition-property: width, left, right;
|
-o-transition-property: width, left, right;
|
||||||
|
@ -4,12 +4,12 @@
|
|||||||
{
|
{
|
||||||
"key": "mctInclude",
|
"key": "mctInclude",
|
||||||
"implementation": "MCTInclude.js",
|
"implementation": "MCTInclude.js",
|
||||||
"depends": [ "templates[]", "$sce" ]
|
"depends": [ "templates[]", "templateLinker" ]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "mctRepresentation",
|
"key": "mctRepresentation",
|
||||||
"implementation": "MCTRepresentation.js",
|
"implementation": "MCTRepresentation.js",
|
||||||
"depends": [ "representations[]", "views[]", "representers[]", "$q", "$sce", "$log" ]
|
"depends": [ "representations[]", "views[]", "representers[]", "$q", "templateLinker", "$log" ]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"gestures": [
|
"gestures": [
|
||||||
@ -48,6 +48,12 @@
|
|||||||
"key": "dndService",
|
"key": "dndService",
|
||||||
"implementation": "services/DndService.js",
|
"implementation": "services/DndService.js",
|
||||||
"depends": [ "$log" ]
|
"depends": [ "$log" ]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "templateLinker",
|
||||||
|
"implementation": "TemplateLinker.js",
|
||||||
|
"depends": [ "$templateRequest", "$sce", "$compile", "$log" ],
|
||||||
|
"comment": "For internal use by mct-include and mct-representation."
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"actions": [
|
"actions": [
|
||||||
|
@ -54,36 +54,38 @@ define(
|
|||||||
* @param {TemplateDefinition[]} templates an array of
|
* @param {TemplateDefinition[]} templates an array of
|
||||||
* template extensions
|
* template extensions
|
||||||
*/
|
*/
|
||||||
function MCTInclude(templates, $sce) {
|
function MCTInclude(templates, templateLinker) {
|
||||||
var templateMap = {};
|
var templateMap = {};
|
||||||
|
|
||||||
|
function link(scope, element) {
|
||||||
|
var changeTemplate = templateLinker.link(
|
||||||
|
scope,
|
||||||
|
element,
|
||||||
|
scope.key && templateMap[scope.key]
|
||||||
|
);
|
||||||
|
|
||||||
|
scope.$watch('key', function (key) {
|
||||||
|
changeTemplate(key && templateMap[key]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Prepopulate templateMap for easy look up by key
|
// Prepopulate templateMap for easy look up by key
|
||||||
templates.forEach(function (template) {
|
templates.forEach(function (template) {
|
||||||
var key = template.key,
|
var key = template.key;
|
||||||
path = $sce.trustAsResourceUrl([
|
|
||||||
template.bundle.path,
|
|
||||||
template.bundle.resources,
|
|
||||||
template.templateUrl
|
|
||||||
].join("/"));
|
|
||||||
// First found should win (priority ordering)
|
// First found should win (priority ordering)
|
||||||
templateMap[key] = templateMap[key] || path;
|
templateMap[key] =
|
||||||
|
templateMap[key] || templateLinker.getPath(template);
|
||||||
});
|
});
|
||||||
|
|
||||||
function controller($scope) {
|
|
||||||
// Pass the template URL to ng-include via scope.
|
|
||||||
$scope.inclusion = templateMap[$scope.key];
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
// Only show at the element level
|
// Only show at the element level
|
||||||
restrict: "E",
|
restrict: "E",
|
||||||
|
|
||||||
// Use the included controller to populate scope
|
// Use the included controller to populate scope
|
||||||
controller: controller,
|
link: link,
|
||||||
|
|
||||||
// Use ng-include as a template; "inclusion" will be the real
|
// May hide the element, so let other directives act first
|
||||||
// template path
|
priority: -1000,
|
||||||
template: '<ng-include src="inclusion"></ng-include>',
|
|
||||||
|
|
||||||
// Two-way bind key, ngModel, and parameters
|
// Two-way bind key, ngModel, and parameters
|
||||||
scope: { key: "=", ngModel: "=", parameters: "=" }
|
scope: { key: "=", ngModel: "=", parameters: "=" }
|
||||||
|
@ -55,7 +55,7 @@ define(
|
|||||||
* representation extensions
|
* representation extensions
|
||||||
* @param {ViewDefinition[]} views an array of view extensions
|
* @param {ViewDefinition[]} views an array of view extensions
|
||||||
*/
|
*/
|
||||||
function MCTRepresentation(representations, views, representers, $q, $sce, $log) {
|
function MCTRepresentation(representations, views, representers, $q, templateLinker, $log) {
|
||||||
var representationMap = {},
|
var representationMap = {},
|
||||||
gestureMap = {};
|
gestureMap = {};
|
||||||
|
|
||||||
@ -72,11 +72,7 @@ define(
|
|||||||
|
|
||||||
// Get a path to a representation
|
// Get a path to a representation
|
||||||
function getPath(representation) {
|
function getPath(representation) {
|
||||||
return $sce.trustAsResourceUrl([
|
return templateLinker.getPath(representation);
|
||||||
representation.bundle.path,
|
|
||||||
representation.bundle.resources,
|
|
||||||
representation.templateUrl
|
|
||||||
].join("/"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Look up a matching representation for this domain object
|
// Look up a matching representation for this domain object
|
||||||
@ -94,12 +90,13 @@ define(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function link($scope, element, attrs) {
|
function link($scope, element, attrs, ctrl, transclude) {
|
||||||
var activeRepresenters = representers.map(function (Representer) {
|
var activeRepresenters = representers.map(function (Representer) {
|
||||||
return new Representer($scope, element, attrs);
|
return new Representer($scope, element, attrs);
|
||||||
}),
|
}),
|
||||||
toClear = [], // Properties to clear out of scope on change
|
toClear = [], // Properties to clear out of scope on change
|
||||||
counter = 0;
|
counter = 0,
|
||||||
|
changeTemplate = templateLinker.link($scope, element);
|
||||||
|
|
||||||
// Populate scope with any capabilities indicated by the
|
// Populate scope with any capabilities indicated by the
|
||||||
// representation's extension definition
|
// representation's extension definition
|
||||||
@ -150,15 +147,17 @@ define(
|
|||||||
function refresh() {
|
function refresh() {
|
||||||
var domainObject = $scope.domainObject,
|
var domainObject = $scope.domainObject,
|
||||||
representation = lookup($scope.key, domainObject),
|
representation = lookup($scope.key, domainObject),
|
||||||
uses = ((representation || {}).uses || []);
|
path = representation && getPath(representation),
|
||||||
|
uses = ((representation || {}).uses || []),
|
||||||
|
canRepresent = !!(path && domainObject);
|
||||||
|
|
||||||
// Create an empty object named "representation", for this
|
// Create an empty object named "representation", for this
|
||||||
// representation to store local variables into.
|
// representation to store local variables into.
|
||||||
$scope.representation = {};
|
$scope.representation = {};
|
||||||
|
|
||||||
// Look up the actual template path, pass it to ng-include
|
// Change templates (passing in undefined to clear
|
||||||
// via the "inclusion" field
|
// if we don't have enough info to show a template.)
|
||||||
$scope.inclusion = representation && getPath(representation);
|
changeTemplate(canRepresent ? path : undefined);
|
||||||
|
|
||||||
// Any existing representers are no longer valid; release them.
|
// Any existing representers are no longer valid; release them.
|
||||||
destroyRepresenters();
|
destroyRepresenters();
|
||||||
@ -176,7 +175,7 @@ define(
|
|||||||
|
|
||||||
// Populate scope with fields associated with the current
|
// Populate scope with fields associated with the current
|
||||||
// domain object (if one has been passed in)
|
// domain object (if one has been passed in)
|
||||||
if (domainObject) {
|
if (canRepresent) {
|
||||||
// Track how many representations we've made in this scope,
|
// Track how many representations we've made in this scope,
|
||||||
// to ensure that the correct representations are matched to
|
// to ensure that the correct representations are matched to
|
||||||
// the correct object/key pairs.
|
// the correct object/key pairs.
|
||||||
@ -233,9 +232,8 @@ define(
|
|||||||
// Handle Angular's linking step
|
// Handle Angular's linking step
|
||||||
link: link,
|
link: link,
|
||||||
|
|
||||||
// Use ng-include as a template; "inclusion" will be the real
|
// May hide the element, so let other directives act first
|
||||||
// template path
|
priority: -1000,
|
||||||
template: '<ng-include src="inclusion"></ng-include>',
|
|
||||||
|
|
||||||
// Two-way bind key and parameters, get the represented domain
|
// Two-way bind key and parameters, get the represented domain
|
||||||
// object as "mct-object"
|
// object as "mct-object"
|
||||||
|
153
platform/representation/src/TemplateLinker.js
Normal file
153
platform/representation/src/TemplateLinker.js
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* Open MCT Web, Copyright (c) 2014-2015, United States Government
|
||||||
|
* as represented by the Administrator of the National Aeronautics and Space
|
||||||
|
* Administration. All rights reserved.
|
||||||
|
*
|
||||||
|
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
* License for the specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*
|
||||||
|
* Open MCT Web includes source code licensed under additional open source
|
||||||
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
||||||
|
* this source code distribution or the Licensing information page available
|
||||||
|
* at runtime from the About dialog for additional information.
|
||||||
|
*****************************************************************************/
|
||||||
|
/*global define,Promise*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The `templateLinker` service is intended for internal use by
|
||||||
|
* the `mct-include` and `mct-representation` directives. It is
|
||||||
|
* used to support common behavior of directives; specifically,
|
||||||
|
* loading templates and inserting them into a specified element,
|
||||||
|
* and/or removing that element from the DOM when there is no
|
||||||
|
* template to populate it with.
|
||||||
|
*
|
||||||
|
* @param {Function} $templateRequest Angular's `$templateRequest`
|
||||||
|
* service
|
||||||
|
* @param $sce Angular's `$sce` service
|
||||||
|
* @param {Function} $compile Angular's `$compile` service
|
||||||
|
* @param $log Angular's `$log` service
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
function TemplateLinker($templateRequest, $sce, $compile, $log) {
|
||||||
|
this.$templateRequest = $templateRequest;
|
||||||
|
this.$sce = $sce;
|
||||||
|
this.$compile = $compile;
|
||||||
|
this.$log = $log;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load a template from the given URL. This request will be handled
|
||||||
|
* via `$templateRequest` to ensure caching et cetera.
|
||||||
|
* @param {string} the URL for the template
|
||||||
|
* @returns {Promise.<string>} a promise for the HTML content of
|
||||||
|
* the template
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
TemplateLinker.prototype.load = function (templateUrl) {
|
||||||
|
return this.$templateRequest(
|
||||||
|
this.$sce.trustAsResourceUrl(templateUrl),
|
||||||
|
false
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a path to a template from an extension definition fo
|
||||||
|
* a template, representation, or view.
|
||||||
|
* @param {TemplateDefinition} extensionDefinition the definition
|
||||||
|
* of the template/representation/view to resolve
|
||||||
|
*/
|
||||||
|
TemplateLinker.prototype.getPath = function (extensionDefinition) {
|
||||||
|
return [
|
||||||
|
extensionDefinition.bundle.path,
|
||||||
|
extensionDefinition.bundle.resources,
|
||||||
|
extensionDefinition.templateUrl
|
||||||
|
].join('/');
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Populate the given element with templates, within the given scope;
|
||||||
|
* intended to support the `link` function of the supported directives.
|
||||||
|
*
|
||||||
|
* @param {Scope} scope the Angular scope to use when rendering
|
||||||
|
* templates
|
||||||
|
* @param element the jqLite-wrapped element into which templates
|
||||||
|
* should be inserted
|
||||||
|
* @returns {Function} a function which can be called with a template
|
||||||
|
* URL to switch templates, or `undefined` to remove.
|
||||||
|
*/
|
||||||
|
TemplateLinker.prototype.link = function (scope, element, templateUrl) {
|
||||||
|
var activeElement = element,
|
||||||
|
activeTemplateUrl,
|
||||||
|
comment = this.$compile('<!-- hidden mct element -->')(scope),
|
||||||
|
self = this;
|
||||||
|
|
||||||
|
function removeElement() {
|
||||||
|
if (activeElement !== comment) {
|
||||||
|
activeElement.replaceWith(comment);
|
||||||
|
activeElement = comment;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function addElement() {
|
||||||
|
if (activeElement !== element) {
|
||||||
|
activeElement.replaceWith(element);
|
||||||
|
activeElement = element;
|
||||||
|
activeElement.empty();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function populateElement(template) {
|
||||||
|
element.empty();
|
||||||
|
element.append(self.$compile(template)(scope));
|
||||||
|
}
|
||||||
|
|
||||||
|
function badTemplate(templateUrl) {
|
||||||
|
self.$log.warn("Couldn't load template at " + templateUrl);
|
||||||
|
removeElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
function changeTemplate(templateUrl) {
|
||||||
|
if (templateUrl !== activeTemplateUrl) {
|
||||||
|
if (templateUrl) {
|
||||||
|
addElement();
|
||||||
|
self.load(templateUrl).then(function (template) {
|
||||||
|
// Avoid race conditions
|
||||||
|
if (templateUrl === activeTemplateUrl) {
|
||||||
|
populateElement(template);
|
||||||
|
}
|
||||||
|
}, function () {
|
||||||
|
badTemplate(templateUrl);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
removeElement();
|
||||||
|
}
|
||||||
|
activeTemplateUrl = templateUrl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (templateUrl) {
|
||||||
|
changeTemplate(templateUrl);
|
||||||
|
} else {
|
||||||
|
removeElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
return changeTemplate;
|
||||||
|
};
|
||||||
|
|
||||||
|
return TemplateLinker;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
@ -31,9 +31,21 @@ define(
|
|||||||
|
|
||||||
describe("The mct-include directive", function () {
|
describe("The mct-include directive", function () {
|
||||||
var testTemplates,
|
var testTemplates,
|
||||||
mockSce,
|
testUrls,
|
||||||
|
mockLinker,
|
||||||
|
mockScope,
|
||||||
|
mockElement,
|
||||||
|
mockChangeTemplate,
|
||||||
mctInclude;
|
mctInclude;
|
||||||
|
|
||||||
|
function fireWatch(expr, value) {
|
||||||
|
mockScope.$watch.calls.forEach(function (call) {
|
||||||
|
if (call.args[0] === expr) {
|
||||||
|
call.args[1](value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
testTemplates = [
|
testTemplates = [
|
||||||
{
|
{
|
||||||
@ -47,40 +59,44 @@ define(
|
|||||||
templateUrl: "z/template.html"
|
templateUrl: "z/template.html"
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
mockSce = jasmine.createSpyObj(
|
testUrls = {};
|
||||||
'$sce',
|
testTemplates.forEach(function (t, i) {
|
||||||
['trustAsResourceUrl']
|
testUrls[t.key] = "some URL " + String(i);
|
||||||
);
|
|
||||||
mockSce.trustAsResourceUrl.andCallFake(function (url) {
|
|
||||||
return url;
|
|
||||||
});
|
});
|
||||||
mctInclude = new MCTInclude(testTemplates, mockSce);
|
mockLinker = jasmine.createSpyObj(
|
||||||
});
|
'templateLinker',
|
||||||
|
['link', 'getPath']
|
||||||
it("has a built-in template, with ng-include src=inclusion", function () {
|
);
|
||||||
// Not rigorous, but should detect many cases when template is broken.
|
mockScope = jasmine.createSpyObj('$scope', ['$watch', '$on']);
|
||||||
expect(mctInclude.template.indexOf("ng-include")).not.toEqual(-1);
|
mockElement = jasmine.createSpyObj('element', ['empty']);
|
||||||
expect(mctInclude.template.indexOf("inclusion")).not.toEqual(-1);
|
mockChangeTemplate = jasmine.createSpy('changeTemplate');
|
||||||
|
mockLinker.link.andReturn(mockChangeTemplate);
|
||||||
|
mockLinker.getPath.andCallFake(function (template) {
|
||||||
|
return testUrls[template.key];
|
||||||
|
});
|
||||||
|
mctInclude = new MCTInclude(testTemplates, mockLinker);
|
||||||
|
mctInclude.link(mockScope, mockElement, {});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("is restricted to elements", function () {
|
it("is restricted to elements", function () {
|
||||||
expect(mctInclude.restrict).toEqual("E");
|
expect(mctInclude.restrict).toEqual("E");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("reads a template location from a scope's key variable", function () {
|
it("exposes templates via the templateLinker", function () {
|
||||||
var scope = { key: "abc" };
|
expect(mockLinker.link)
|
||||||
mctInclude.controller(scope);
|
.toHaveBeenCalledWith(mockScope, mockElement, undefined);
|
||||||
expect(scope.inclusion).toEqual("a/b/c/template.html");
|
|
||||||
|
|
||||||
scope = { key: "xyz" };
|
|
||||||
mctInclude.controller(scope);
|
|
||||||
expect(scope.inclusion).toEqual("x/y/z/template.html");
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it("trusts template URLs", function () {
|
it("reads a template location from a scope's key variable", function () {
|
||||||
mctInclude.controller({ key: "xyz" });
|
mockScope.key = 'abc';
|
||||||
expect(mockSce.trustAsResourceUrl)
|
fireWatch('key', mockScope.key);
|
||||||
.toHaveBeenCalledWith("x/y/z/template.html");
|
expect(mockChangeTemplate)
|
||||||
|
.toHaveBeenCalledWith(testUrls.abc);
|
||||||
|
|
||||||
|
mockScope.key = 'xyz';
|
||||||
|
fireWatch('key', mockScope.key);
|
||||||
|
expect(mockChangeTemplate)
|
||||||
|
.toHaveBeenCalledWith(testUrls.xyz);
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -36,10 +36,12 @@ define(
|
|||||||
describe("The mct-representation directive", function () {
|
describe("The mct-representation directive", function () {
|
||||||
var testRepresentations,
|
var testRepresentations,
|
||||||
testViews,
|
testViews,
|
||||||
|
testUrls,
|
||||||
mockRepresenters,
|
mockRepresenters,
|
||||||
mockQ,
|
mockQ,
|
||||||
mockSce,
|
mockLinker,
|
||||||
mockLog,
|
mockLog,
|
||||||
|
mockChangeTemplate,
|
||||||
mockScope,
|
mockScope,
|
||||||
mockElement,
|
mockElement,
|
||||||
mockDomainObject,
|
mockDomainObject,
|
||||||
@ -54,7 +56,17 @@ define(
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function fireWatch(expr, value) {
|
||||||
|
mockScope.$watch.calls.forEach(function (call) {
|
||||||
|
if (call.args[0] === expr) {
|
||||||
|
call.args[1](value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
|
testUrls = {};
|
||||||
|
|
||||||
testRepresentations = [
|
testRepresentations = [
|
||||||
{
|
{
|
||||||
key: "abc",
|
key: "abc",
|
||||||
@ -85,6 +97,11 @@ define(
|
|||||||
|
|
||||||
testModel = { someKey: "some value" };
|
testModel = { someKey: "some value" };
|
||||||
|
|
||||||
|
testUrls = {};
|
||||||
|
testViews.concat(testRepresentations).forEach(function (t, i) {
|
||||||
|
testUrls[t.key] = "some URL " + String(i);
|
||||||
|
});
|
||||||
|
|
||||||
mockRepresenters = ["A", "B"].map(function (name) {
|
mockRepresenters = ["A", "B"].map(function (name) {
|
||||||
var constructor = jasmine.createSpy("Representer" + name),
|
var constructor = jasmine.createSpy("Representer" + name),
|
||||||
representer = jasmine.createSpyObj(
|
representer = jasmine.createSpyObj(
|
||||||
@ -96,45 +113,44 @@ define(
|
|||||||
});
|
});
|
||||||
|
|
||||||
mockQ = { when: mockPromise };
|
mockQ = { when: mockPromise };
|
||||||
mockSce = jasmine.createSpyObj(
|
mockLinker = jasmine.createSpyObj(
|
||||||
'$sce',
|
'templateLinker',
|
||||||
['trustAsResourceUrl']
|
['link', 'getPath']
|
||||||
);
|
);
|
||||||
|
mockChangeTemplate = jasmine.createSpy('changeTemplate');
|
||||||
mockLog = jasmine.createSpyObj("$log", LOG_FUNCTIONS);
|
mockLog = jasmine.createSpyObj("$log", LOG_FUNCTIONS);
|
||||||
|
|
||||||
|
|
||||||
mockSce.trustAsResourceUrl.andCallFake(function (url) {
|
|
||||||
return url;
|
|
||||||
});
|
|
||||||
mockScope = jasmine.createSpyObj("scope", [ "$watch", "$on" ]);
|
mockScope = jasmine.createSpyObj("scope", [ "$watch", "$on" ]);
|
||||||
mockElement = jasmine.createSpyObj("element", JQLITE_FUNCTIONS);
|
mockElement = jasmine.createSpyObj("element", JQLITE_FUNCTIONS);
|
||||||
mockDomainObject = jasmine.createSpyObj("domainObject", DOMAIN_OBJECT_METHODS);
|
mockDomainObject = jasmine.createSpyObj("domainObject", DOMAIN_OBJECT_METHODS);
|
||||||
|
|
||||||
mockDomainObject.getModel.andReturn(testModel);
|
mockDomainObject.getModel.andReturn(testModel);
|
||||||
|
mockLinker.link.andReturn(mockChangeTemplate);
|
||||||
|
mockLinker.getPath.andCallFake(function (ext) {
|
||||||
|
return testUrls[ext.key];
|
||||||
|
});
|
||||||
|
|
||||||
mctRepresentation = new MCTRepresentation(
|
mctRepresentation = new MCTRepresentation(
|
||||||
testRepresentations,
|
testRepresentations,
|
||||||
testViews,
|
testViews,
|
||||||
mockRepresenters,
|
mockRepresenters,
|
||||||
mockQ,
|
mockQ,
|
||||||
mockSce,
|
mockLinker,
|
||||||
mockLog
|
mockLog
|
||||||
);
|
);
|
||||||
});
|
mctRepresentation.link(mockScope, mockElement);
|
||||||
|
|
||||||
|
|
||||||
it("has a built-in template, with ng-include src=inclusion", function () {
|
|
||||||
// Not rigorous, but should detect many cases when template is broken.
|
|
||||||
expect(mctRepresentation.template.indexOf("ng-include")).not.toEqual(-1);
|
|
||||||
expect(mctRepresentation.template.indexOf("inclusion")).not.toEqual(-1);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it("is restricted to elements", function () {
|
it("is restricted to elements", function () {
|
||||||
expect(mctRepresentation.restrict).toEqual("E");
|
expect(mctRepresentation.restrict).toEqual("E");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("exposes templates via the templateLinker", function () {
|
||||||
|
expect(mockLinker.link)
|
||||||
|
.toHaveBeenCalledWith(mockScope, mockElement);
|
||||||
|
});
|
||||||
|
|
||||||
it("watches scope when linked", function () {
|
it("watches scope when linked", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
expect(mockScope.$watch).toHaveBeenCalledWith(
|
expect(mockScope.$watch).toHaveBeenCalledWith(
|
||||||
"key",
|
"key",
|
||||||
jasmine.any(Function)
|
jasmine.any(Function)
|
||||||
@ -150,42 +166,46 @@ define(
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("recognizes keys for representations", function () {
|
it("recognizes keys for representations", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
|
|
||||||
mockScope.key = "abc";
|
mockScope.key = "abc";
|
||||||
|
mockScope.domainObject = mockDomainObject;
|
||||||
|
|
||||||
// Trigger the watch
|
// Trigger the watch
|
||||||
mockScope.$watch.calls[0].args[1]();
|
fireWatch('key', mockScope.key);
|
||||||
|
fireWatch('domainObject', mockDomainObject);
|
||||||
|
|
||||||
expect(mockScope.inclusion).toEqual("a/b/c/template.html");
|
expect(mockChangeTemplate)
|
||||||
|
.toHaveBeenCalledWith(testUrls.abc);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("recognizes keys for views", function () {
|
it("recognizes keys for views", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
|
|
||||||
mockScope.key = "xyz";
|
mockScope.key = "xyz";
|
||||||
|
mockScope.domainObject = mockDomainObject;
|
||||||
|
|
||||||
// Trigger the watch
|
// Trigger the watches
|
||||||
mockScope.$watch.calls[0].args[1]();
|
fireWatch('key', mockScope.key);
|
||||||
|
fireWatch('domainObject', mockDomainObject);
|
||||||
|
|
||||||
expect(mockScope.inclusion).toEqual("x/y/z/template.html");
|
expect(mockChangeTemplate)
|
||||||
|
.toHaveBeenCalledWith(testUrls.xyz);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("trusts template URLs", function () {
|
it("does not load templates until there is an object", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
|
|
||||||
mockScope.key = "xyz";
|
mockScope.key = "xyz";
|
||||||
|
|
||||||
// Trigger the watch
|
// Trigger the watch
|
||||||
mockScope.$watch.calls[0].args[1]();
|
fireWatch('key', mockScope.key);
|
||||||
|
|
||||||
expect(mockSce.trustAsResourceUrl)
|
expect(mockChangeTemplate)
|
||||||
.toHaveBeenCalledWith("x/y/z/template.html");
|
.not.toHaveBeenCalledWith(jasmine.any(String));
|
||||||
|
|
||||||
|
mockScope.domainObject = mockDomainObject;
|
||||||
|
fireWatch('domainObject', mockDomainObject);
|
||||||
|
|
||||||
|
expect(mockChangeTemplate)
|
||||||
|
.toHaveBeenCalledWith(jasmine.any(String));
|
||||||
});
|
});
|
||||||
|
|
||||||
it("loads declared capabilities", function () {
|
it("loads declared capabilities", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
|
|
||||||
mockScope.key = "def";
|
mockScope.key = "def";
|
||||||
mockScope.domainObject = mockDomainObject;
|
mockScope.domainObject = mockDomainObject;
|
||||||
|
|
||||||
@ -199,8 +219,6 @@ define(
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("logs when no representation is available for a key", function () {
|
it("logs when no representation is available for a key", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
|
|
||||||
mockScope.key = "someUnknownThing";
|
mockScope.key = "someUnknownThing";
|
||||||
|
|
||||||
// Verify precondition
|
// Verify precondition
|
||||||
@ -214,8 +232,6 @@ define(
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("clears out obsolete peroperties from scope", function () {
|
it("clears out obsolete peroperties from scope", function () {
|
||||||
mctRepresentation.link(mockScope, mockElement);
|
|
||||||
|
|
||||||
mockScope.key = "def";
|
mockScope.key = "def";
|
||||||
mockScope.domainObject = mockDomainObject;
|
mockScope.domainObject = mockDomainObject;
|
||||||
mockDomainObject.useCapability.andReturn("some value");
|
mockDomainObject.useCapability.andReturn("some value");
|
||||||
|
211
platform/representation/test/TemplateLinkerSpec.js
Normal file
211
platform/representation/test/TemplateLinkerSpec.js
Normal file
@ -0,0 +1,211 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* 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/TemplateLinker"],
|
||||||
|
function (TemplateLinker) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var JQLITE_METHODS = [ 'replaceWith', 'empty', 'append' ];
|
||||||
|
|
||||||
|
describe("TemplateLinker", function () {
|
||||||
|
var mockTemplateRequest,
|
||||||
|
mockSce,
|
||||||
|
mockCompile,
|
||||||
|
mockLog,
|
||||||
|
mockScope,
|
||||||
|
mockElement,
|
||||||
|
mockTemplates,
|
||||||
|
mockElements,
|
||||||
|
mockPromise,
|
||||||
|
linker;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
mockTemplateRequest = jasmine.createSpy('$templateRequest');
|
||||||
|
mockSce = jasmine.createSpyObj('$sce', ['trustAsResourceUrl']);
|
||||||
|
mockCompile = jasmine.createSpy('$compile');
|
||||||
|
mockLog = jasmine.createSpyObj('$log', ['error', 'warn']);
|
||||||
|
mockScope = jasmine.createSpyObj('$scope', ['$on']);
|
||||||
|
mockElement = jasmine.createSpyObj('element', JQLITE_METHODS);
|
||||||
|
mockPromise = jasmine.createSpyObj('promise', ['then']);
|
||||||
|
mockTemplates = {};
|
||||||
|
mockElements = {};
|
||||||
|
|
||||||
|
mockTemplateRequest.andReturn(mockPromise);
|
||||||
|
mockCompile.andCallFake(function (html) {
|
||||||
|
mockTemplates[html] = jasmine.createSpy('template');
|
||||||
|
mockElements[html] =
|
||||||
|
jasmine.createSpyObj('templateEl', JQLITE_METHODS);
|
||||||
|
mockTemplates[html].andReturn(mockElements[html]);
|
||||||
|
return mockTemplates[html];
|
||||||
|
});
|
||||||
|
mockSce.trustAsResourceUrl.andCallFake(function (url) {
|
||||||
|
return { trusted: url };
|
||||||
|
});
|
||||||
|
|
||||||
|
linker = new TemplateLinker(
|
||||||
|
mockTemplateRequest,
|
||||||
|
mockSce,
|
||||||
|
mockCompile,
|
||||||
|
mockLog
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("resolves extension paths", function () {
|
||||||
|
expect(linker.getPath({
|
||||||
|
bundle: {
|
||||||
|
path: 'a',
|
||||||
|
resources: 'b'
|
||||||
|
},
|
||||||
|
templateUrl: 'c/d.html'
|
||||||
|
})).toEqual('a/b/c/d.html');
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("when linking elements", function () {
|
||||||
|
var changeTemplate,
|
||||||
|
commentElement;
|
||||||
|
|
||||||
|
function findCommentElement() {
|
||||||
|
mockCompile.calls.forEach(function (call) {
|
||||||
|
var html = call.args[0];
|
||||||
|
if (html.indexOf("<!--") > -1) {
|
||||||
|
commentElement = mockElements[html];
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
changeTemplate = linker.link(mockScope, mockElement);
|
||||||
|
findCommentElement();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("compiles a comment to use to replace element", function () {
|
||||||
|
expect(commentElement).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("initially replaces elements with comments", function () {
|
||||||
|
expect(mockElement.replaceWith)
|
||||||
|
.toHaveBeenCalledWith(commentElement);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("provides a function to change templates", function () {
|
||||||
|
expect(changeTemplate).toEqual(jasmine.any(Function));
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("and then changing templates", function () {
|
||||||
|
var testUrl,
|
||||||
|
testTemplate;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testUrl = "some/url/template.html";
|
||||||
|
testTemplate = "<div>Some template!</div>";
|
||||||
|
changeTemplate(testUrl);
|
||||||
|
mockPromise.then.mostRecentCall
|
||||||
|
.args[0](testTemplate);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("loads templates using $templateRequest", function () {
|
||||||
|
expect(mockTemplateRequest).toHaveBeenCalledWith({
|
||||||
|
trusted: testUrl
|
||||||
|
}, false);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("compiles loaded templates with linked scope", function () {
|
||||||
|
expect(mockCompile).toHaveBeenCalledWith(testTemplate);
|
||||||
|
expect(mockTemplates[testTemplate])
|
||||||
|
.toHaveBeenCalledWith(mockScope);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("replaces comments with specified element", function () {
|
||||||
|
expect(commentElement.replaceWith)
|
||||||
|
.toHaveBeenCalledWith(mockElement);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("appends rendered content to the specified element", function () {
|
||||||
|
expect(mockElement.append)
|
||||||
|
.toHaveBeenCalledWith(mockElements[testTemplate]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("clears templates when called with undefined", function () {
|
||||||
|
expect(mockElement.replaceWith.callCount)
|
||||||
|
.toEqual(1);
|
||||||
|
changeTemplate(undefined);
|
||||||
|
expect(mockElement.replaceWith.callCount)
|
||||||
|
.toEqual(2);
|
||||||
|
expect(mockElement.replaceWith.mostRecentCall.args[0])
|
||||||
|
.toEqual(commentElement);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("logs no warnings for nominal changes", function () {
|
||||||
|
expect(mockLog.warn).not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("which cannot be found", function () {
|
||||||
|
beforeEach(function () {
|
||||||
|
changeTemplate("some/bad/url");
|
||||||
|
// Reject the template promise
|
||||||
|
mockPromise.then.mostRecentCall.args[1]();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("removes the element from the DOM", function () {
|
||||||
|
expect(mockElement.replaceWith.callCount)
|
||||||
|
.toEqual(2);
|
||||||
|
expect(
|
||||||
|
mockElement.replaceWith.mostRecentCall.args[0]
|
||||||
|
).toEqual(commentElement);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("logs a warning", function () {
|
||||||
|
expect(mockLog.warn)
|
||||||
|
.toHaveBeenCalledWith(jasmine.any(String));
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("when an initial template URL is provided", function () {
|
||||||
|
var testUrl;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
testUrl = "some/test/url.html";
|
||||||
|
linker.link(mockScope, mockElement, testUrl);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("does not remove the element initially", function () {
|
||||||
|
expect(mockElement.replaceWith)
|
||||||
|
.not.toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("loads the specified template", function () {
|
||||||
|
expect(mockTemplateRequest).toHaveBeenCalledWith({
|
||||||
|
trusted: testUrl
|
||||||
|
}, false);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -7,5 +7,6 @@
|
|||||||
"gestures/GestureRepresenter",
|
"gestures/GestureRepresenter",
|
||||||
"services/DndService",
|
"services/DndService",
|
||||||
"MCTInclude",
|
"MCTInclude",
|
||||||
"MCTRepresentation"
|
"MCTRepresentation",
|
||||||
]
|
"TemplateLinker"
|
||||||
|
]
|
||||||
|
Loading…
Reference in New Issue
Block a user