@genesislcap/foundation-layout 14.74.0 → 14.76.0
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +57 -1
- package/dist/custom-elements.json +33 -54
- package/dist/dts/index.d.ts +2 -1
- package/dist/dts/index.d.ts.map +1 -1
- package/dist/dts/main/layout-main.d.ts +13 -1
- package/dist/dts/main/layout-main.d.ts.map +1 -1
- package/dist/dts/styles/constants.d.ts +20 -4
- package/dist/dts/styles/constants.d.ts.map +1 -1
- package/dist/dts/utils/types.d.ts +11 -0
- package/dist/dts/utils/types.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/main/layout-main.js +19 -0
- package/dist/esm/styles/constants.js +25 -4
- package/dist/esm/styles/layout.styles.js +6 -6
- package/dist/foundation-layout.api.json +102 -0
- package/dist/foundation-layout.d.ts +45 -0
- package/docs/api/foundation-layout.custombutton.md +21 -0
- package/docs/api/foundation-layout.foundationlayout.custombuttons.md +18 -0
- package/docs/api/foundation-layout.foundationlayout.md +1 -0
- package/docs/api/foundation-layout.layout_icons.md +33 -0
- package/docs/api/foundation-layout.md +2 -0
- package/docs/api-report.md +16 -0
- package/package.json +6 -6
package/README.md
CHANGED
@@ -209,6 +209,34 @@ this.$emit(eventType, eventDetail)
|
|
209
209
|
```
|
210
210
|
Each event requires a certain detail to process the event - see [the map of events to their required details](./docs/api/foundation-layout.layoutreceiveeventsdetail.md).
|
211
211
|
|
212
|
+
## Customising header buttons
|
213
|
+
|
214
|
+
You can add custom buttons on layout items, and then control their behaviour. See [the custom button API](./docs/api/foundation-layout.custombutton.md) to see the full definition. Setting this is optional. If you do define it, you define it as an array which allow you to add multiple custom buttons if you wish.
|
215
|
+
|
216
|
+
* The `svg` parameter controls the icon which your button displays. The format must be a base64 image definition. See the format as explained on the linked api document, and then replace the text around the `<< >>` part with a base64 encoded definition of the svg you wish to use.
|
217
|
+
* The `onClick` parameter will register a callback with the button. When the user clicks the button, your callback will be called. The callback receives a reference to the clicked button element, and the element which is contained in the layout item associated with the clicked button.
|
218
|
+
|
219
|
+
Different layout instances can have their own custom buttons, or share definitions. You are not able to have fine-grained control over each layout item though, so if a layout has a custom button then every item it contains will have the button.
|
220
|
+
|
221
|
+
### Applying the custom button
|
222
|
+
|
223
|
+
To ensure that every item gets the button as expected, you need to ensure that you apply the custom button definitions as early as possible. If you are using the html API then you'll likely want to apply the definitions in the template.
|
224
|
+
|
225
|
+
```html
|
226
|
+
<foundation-layout :customButtons=${() => buttonDefinition}>
|
227
|
+
...
|
228
|
+
</foundation-layout>
|
229
|
+
```
|
230
|
+
|
231
|
+
If you are only using the javascript API then you should just apply the property as soon as you can.
|
232
|
+
```typescript
|
233
|
+
layout.customButtons = buttonDefinition;
|
234
|
+
```
|
235
|
+
|
236
|
+
### Renaming example
|
237
|
+
|
238
|
+
See [here](#custom-item-renaming-header-button) to see an example of creating a custom button to allow the user to rename an item.
|
239
|
+
|
212
240
|
## Autosaving layout
|
213
241
|
|
214
242
|
There is opt-in functionality provided in the layout to autosave the layout in local storage as the user interacts with it. Set the `auto-save-key` attribute to a unique string on the root element to enable the feature, and this is the key in which the layout will be saved into. As the user performs the following actions: adding an item, removing an item, resizing items using the divider, and dragging items around the layout - the layout will be saved for later recall in local storage.
|
@@ -261,7 +289,7 @@ At the very least, you must run `super` calls to the lifecycle methods, or else
|
|
261
289
|
:::
|
262
290
|
|
263
291
|
### Resource-intensive components
|
264
|
-
Throughout Foundation UI, there is no need to
|
292
|
+
Throughout Foundation UI, there is no need to de-register a component that is registered in the layout while it is not in use. However, if you have a component that is extremely resource-intensive, then you can use this lifecycle control method to ensure that it only consumes resources when it is in use.
|
265
293
|
|
266
294
|
- When the element is part of the layout registry, then `shouldRunConnect` will be false and you can use this to ensure that your component isn't doing unnecessary work while part of the cache.
|
267
295
|
|
@@ -781,6 +809,34 @@ Only items _missing_ from the `requiredRegistrations` is an issue. If there are
|
|
781
809
|
If you are calling `registerItem` manually and are using the autosave feature, [see here](#reloading-the-layout).
|
782
810
|
:::
|
783
811
|
|
812
|
+
### Custom item renaming header button
|
813
|
+
|
814
|
+
Here is an example of creating a custom button for the layout which when clicked will prompt the user for a name, and will rename the item in the layout.
|
815
|
+
|
816
|
+
```typescript
|
817
|
+
export const layoutCustomButtons: CustomButton[] = [
|
818
|
+
{
|
819
|
+
svg: LAYOUT_ICONS.renameSVG,
|
820
|
+
onClick: (button: HTMLElement, elem: HTMLElement) => {
|
821
|
+
const title = prompt('New name?');
|
822
|
+
const event: LayoutReceiveEventsDetail['changeTitle'] = {
|
823
|
+
title,
|
824
|
+
mode: 'replace',
|
825
|
+
};
|
826
|
+
elem.dispatchEvent(
|
827
|
+
new CustomEvent(LayoutReceiveEvents.changeTitle, { detail: event, bubbles: true }),
|
828
|
+
);
|
829
|
+
},
|
830
|
+
},
|
831
|
+
];
|
832
|
+
```
|
833
|
+
|
834
|
+
You can import `LAYOUT_ICONS`, `CustomButton`, `LayoutReceiveEvents`, and `LayoutReceiveEventsDetail` from the foundation-layout package, to get strong typing.
|
835
|
+
|
836
|
+
:::warning
|
837
|
+
You'll likely want to improve this callback function to handle cases where the user doesn't enter a prompt value.
|
838
|
+
:::
|
839
|
+
|
784
840
|
## Incorrect examples
|
785
841
|
|
786
842
|
The following section contains examples of incorrect usage, which are useful for troubleshooting.
|
@@ -21,6 +21,22 @@
|
|
21
21
|
"package": "./main"
|
22
22
|
}
|
23
23
|
},
|
24
|
+
{
|
25
|
+
"kind": "js",
|
26
|
+
"name": "LAYOUT_ICONS",
|
27
|
+
"declaration": {
|
28
|
+
"name": "LAYOUT_ICONS",
|
29
|
+
"module": "./styles"
|
30
|
+
}
|
31
|
+
},
|
32
|
+
{
|
33
|
+
"kind": "js",
|
34
|
+
"name": "CustomButton",
|
35
|
+
"declaration": {
|
36
|
+
"name": "CustomButton",
|
37
|
+
"module": "./utils"
|
38
|
+
}
|
39
|
+
},
|
24
40
|
{
|
25
41
|
"kind": "js",
|
26
42
|
"name": "DEFAULT_RELOAD_BUFFER",
|
@@ -482,6 +498,15 @@
|
|
482
498
|
"description": "Boolean signifies whether the layout has loaded for the first time or not.",
|
483
499
|
"privacy": "public"
|
484
500
|
},
|
501
|
+
{
|
502
|
+
"kind": "field",
|
503
|
+
"name": "customButtons",
|
504
|
+
"type": {
|
505
|
+
"text": "CustomButton[]"
|
506
|
+
},
|
507
|
+
"description": "Set custom button definition on this property to add them to the layout header controls",
|
508
|
+
"privacy": "public"
|
509
|
+
},
|
485
510
|
{
|
486
511
|
"kind": "field",
|
487
512
|
"name": "dragging",
|
@@ -1000,35 +1025,13 @@
|
|
1000
1025
|
},
|
1001
1026
|
{
|
1002
1027
|
"kind": "variable",
|
1003
|
-
"name": "
|
1028
|
+
"name": "LAYOUT_ICONS",
|
1004
1029
|
"type": {
|
1005
|
-
"text": "
|
1030
|
+
"text": "{\n renameSVG,\n maximiseSVG,\n minimiseSVG,\n closeSVG,\n tabDropdownSVG,\n}"
|
1006
1031
|
},
|
1007
|
-
"default": "
|
1008
|
-
|
1009
|
-
|
1010
|
-
"kind": "variable",
|
1011
|
-
"name": "minimiseSVG",
|
1012
|
-
"type": {
|
1013
|
-
"text": "string"
|
1014
|
-
},
|
1015
|
-
"default": "''"
|
1016
|
-
},
|
1017
|
-
{
|
1018
|
-
"kind": "variable",
|
1019
|
-
"name": "closeSVG",
|
1020
|
-
"type": {
|
1021
|
-
"text": "string"
|
1022
|
-
},
|
1023
|
-
"default": "''"
|
1024
|
-
},
|
1025
|
-
{
|
1026
|
-
"kind": "variable",
|
1027
|
-
"name": "tabDropdownSVG",
|
1028
|
-
"type": {
|
1029
|
-
"text": "string"
|
1030
|
-
},
|
1031
|
-
"default": "''"
|
1032
|
+
"default": "{\n renameSVG,\n maximiseSVG,\n minimiseSVG,\n closeSVG,\n tabDropdownSVG,\n}",
|
1033
|
+
"description": "A collection of SVG icons in base64 format.",
|
1034
|
+
"privacy": "public"
|
1032
1035
|
}
|
1033
1036
|
],
|
1034
1037
|
"exports": [
|
@@ -1042,33 +1045,9 @@
|
|
1042
1045
|
},
|
1043
1046
|
{
|
1044
1047
|
"kind": "js",
|
1045
|
-
"name": "
|
1046
|
-
"declaration": {
|
1047
|
-
"name": "maximisSVG",
|
1048
|
-
"module": "src/styles/constants.ts"
|
1049
|
-
}
|
1050
|
-
},
|
1051
|
-
{
|
1052
|
-
"kind": "js",
|
1053
|
-
"name": "minimiseSVG",
|
1054
|
-
"declaration": {
|
1055
|
-
"name": "minimiseSVG",
|
1056
|
-
"module": "src/styles/constants.ts"
|
1057
|
-
}
|
1058
|
-
},
|
1059
|
-
{
|
1060
|
-
"kind": "js",
|
1061
|
-
"name": "closeSVG",
|
1062
|
-
"declaration": {
|
1063
|
-
"name": "closeSVG",
|
1064
|
-
"module": "src/styles/constants.ts"
|
1065
|
-
}
|
1066
|
-
},
|
1067
|
-
{
|
1068
|
-
"kind": "js",
|
1069
|
-
"name": "tabDropdownSVG",
|
1048
|
+
"name": "LAYOUT_ICONS",
|
1070
1049
|
"declaration": {
|
1071
|
-
"name": "
|
1050
|
+
"name": "LAYOUT_ICONS",
|
1072
1051
|
"module": "src/styles/constants.ts"
|
1073
1052
|
}
|
1074
1053
|
}
|
@@ -1134,7 +1113,7 @@
|
|
1134
1113
|
{
|
1135
1114
|
"kind": "variable",
|
1136
1115
|
"name": "layoutStyles",
|
1137
|
-
"default": "css`\n ${containerStyles}\n ${loadingSpinnerStyles}\n\n .lm_goldenlayout {\n padding: 1px;\n background: ${neutralLayer1};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n }\n\n .lm_stack.lm_item {\n background-color: ${neutralLayer4};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n }\n .lm_maximised .lm_header {\n background-color: ${neutralLayer4};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n position: unset;\n }\n\n .lm_maximised .lm_header .lm_tabs {\n z-index: 3;\n }\n\n .lm_content {\n background-color: ${neutralLayer3};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n border: 1px solid;\n border-color: #2e3339;\n box-sizing: border-box;\n }\n\n .lm-header {\n z-index: 1;\n }\n .lm_header .lm_tabs {\n padding: 0 16px;\n }\n\n .lm_stack > .lm_items {\n z-index: 2;\n box-shadow: 0px -1px 15px rgba(0, 0, 0, 0.35);\n }\n\n .lm_header .lm_tab.lm_active.lm_focused {\n background-color: ${neutralLayer3};\n }\n .lm_header .lm_tab.lm_active {\n background-color: ${neutralLayer3};\n border: 1px solid;\n border-color: #2e3339;\n border-bottom: 0;\n color: ${accentFillRest};\n }\n\n .lm_header .lm_tab {\n align-items: center;\n background-color: ${neutralLayer4};\n border: 1px solid;\n border-bottom-color: #2e3339;\n border-bottom: 0px solid;\n border-color: rgba(0, 0, 0, 0.35);\n border-radius: calc(${controlCornerRadius} * 1.5px) calc(${controlCornerRadius} * 1.5px) 0 0;\n box-shadow: 1px -1px 2px rgba(0, 0, 0, 0.35);\n color: rgba(255, 255, 255, 0.3);\n display: flex;\n font-family: inherit;\n font-size: 13px;\n font-weight: 700;\n height: 30px;\n margin-right: 2px;\n margin-top: 3px;\n padding: 2px 16px;\n }\n\n .lm_header .lm_tab:not(.lm_active):hover {\n background-color: rgba(255, 255, 255, 0.1);\n color: #f1f1f1;\n }\n\n .lm_header .lm_controls {\n top: 4px;\n display: flex;\n }\n .lm_header .lm_controls > * {\n width: 30px;\n height: 30px;\n background-repeat: no-repeat;\n background-position: center;\n background-size: 16px;\n background-color: rgba(255, 255, 255, 0.03);\n border-radius: calc(${controlCornerRadius} * 1.5px);\n margin-right: 4px;\n top: 3px;\n opacity: 1;\n }\n .lm_header .lm_controls > *:hover {\n background-color: rgba(255, 255, 255, 0.1);\n cursor: pointer;\n }\n\n .lm_controls .lm_maximise {\n background-image: url('${maximisSVG}');\n }\n .lm_maximised .lm_controls .lm_maximise {\n background-image: url('${minimiseSVG}');\n }\n .lm_controls .lm_close {\n background-image: url('${closeSVG}');\n }\n .lm_header .lm_tab .lm_close_tab {\n background-image: url('${closeSVG}');\n background-size: 10px;\n background-repeat: no-repeat;\n margin-left: 12px;\n position: relative;\n top: 0;\n right: 0;\n }\n\n .lm_header .lm_tab.lm_active {\n padding: 4px 25px 3px 10px;\n }\n\n .lm_header .lm_tab:not(.lm_active) .lm_title {\n color: ${accentFillRest};\n opacity: 0.7;\n }\n\n .lm_header .lm_controls .lm_tabdropdown::before {\n content: none;\n }\n .lm_header .lm_controls .lm_tabdropdown {\n background-image: url('${tabDropdownSVG}');\n }\n .lm_header .lm_tabdropdown_list {\n top: 38px;\n right: 108px;\n background-color: ${neutralLayer3};\n border: 1px solid;\n border-color: #2e3339;\n border-radius: calc(${controlCornerRadius} * 1.5px);\n box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.35);\n }\n .lm_header .lm_tabdropdown_list > .lm_tab {\n box-shadow: none;\n padding: 0 16px;\n white-space: nowrap;\n background-color: transparent;\n color: #c9c9c9;\n height: 36px;\n border-radius: 0;\n overflow: visible;\n text-overflow: normal;\n }\n .lm_header .lm_tabdropdown_list > .lm_tab:last-child {\n border-bottom: 0;\n }\n\n /* gl base styles start */\n .lm_root {\n position: relative;\n }\n .lm_row > .lm_item {\n float: left;\n }\n .lm_content {\n overflow: hidden;\n position: relative;\n }\n .lm_dragging,\n .lm_dragging * {\n cursor: move !important;\n user-select: none;\n }\n .lm_maximised {\n left: 0;\n padding: 1px;\n position: absolute;\n top: 0;\n z-index: 40;\n }\n .lm_maximise_placeholder {\n display: none;\n }\n .lm_splitter {\n position: relative;\n z-index: 20;\n }\n .lm_splitter:hover,\n .lm_splitter.lm_dragging {\n background: ${accentFillRest};\n border-radius: calc(${controlCornerRadius} * 4px);\n }\n .lm_splitter.lm_vertical .lm_drag_handle {\n width: 100%;\n height: 15px;\n position: absolute;\n top: -5px;\n cursor: ns-resize;\n }\n .lm_splitter.lm_horizontal {\n float: left;\n height: 100%;\n }\n .lm_splitter.lm_horizontal .lm_drag_handle {\n width: 15px;\n height: 100%;\n position: absolute;\n left: -5px;\n cursor: ew-resize;\n }\n .lm_header {\n overflow: visible;\n position: relative;\n z-index: 1;\n }\n .lm_header [class^='lm_'] {\n box-sizing: content-box !important;\n }\n .lm_header .lm_controls {\n position: absolute;\n right: 3px;\n }\n .lm_header .lm_controls > li {\n cursor: pointer;\n float: left;\n width: 18px;\n height: 18px;\n text-align: center;\n }\n .lm_header ul {\n margin: 0;\n padding: 0;\n list-style-type: none;\n }\n .lm_header .lm_tabs {\n position: absolute;\n }\n .lm_header .lm_tab {\n cursor: pointer;\n float: left;\n margin-top: 1px;\n padding: 3px 25px 3px 10px;\n position: relative;\n }\n .lm_header .lm_tab i {\n width: 2px;\n height: 19px;\n position: absolute;\n }\n .lm_header .lm_tab i.lm_left {\n top: 0;\n left: -2px;\n }\n .lm_header .lm_tab i.lm_right {\n top: 0;\n right: -2px;\n }\n .lm_header .lm_tab .lm_title {\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n .lm_header .lm_tab .lm_title:only-child {\n padding-left: 10px;\n }\n .lm_header .lm_tab .lm_close_tab {\n width: 14px;\n height: 14px;\n position: absolute;\n top: 11px;\n right: 0;\n text-align: center;\n }\n .lm_stack.lm_left .lm_header,\n .lm_stack.lm_right .lm_header {\n height: 100%;\n }\n .lm_dragProxy.lm_left .lm_header,\n .lm_dragProxy.lm_right .lm_header,\n .lm_stack.lm_left .lm_header,\n .lm_stack.lm_right .lm_header {\n width: 20px;\n float: left;\n vertical-align: top;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabs,\n .lm_dragProxy.lm_right .lm_header .lm_tabs,\n .lm_stack.lm_left .lm_header .lm_tabs,\n .lm_stack.lm_right .lm_header .lm_tabs {\n transform-origin: left top;\n top: 0;\n width: 1000px;\n }\n .lm_dragProxy.lm_left .lm_header .lm_controls,\n .lm_dragProxy.lm_right .lm_header .lm_controls,\n .lm_stack.lm_left .lm_header .lm_controls,\n .lm_stack.lm_right .lm_header .lm_controls {\n bottom: 0;\n }\n .lm_dragProxy.lm_left .lm_items,\n .lm_dragProxy.lm_right .lm_items,\n .lm_stack.lm_left .lm_items,\n .lm_stack.lm_right .lm_items {\n float: left;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabs,\n .lm_stack.lm_left .lm_header .lm_tabs {\n transform: rotate(-90deg) scaleX(-1);\n left: 0;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabs .lm_tab,\n .lm_stack.lm_left .lm_header .lm_tabs .lm_tab {\n transform: scaleX(-1);\n margin-top: 1px;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabdropdown_list,\n .lm_stack.lm_left .lm_header .lm_tabdropdown_list {\n top: initial;\n right: initial;\n left: 20px;\n }\n .lm_dragProxy.lm_right .lm_content {\n float: left;\n }\n .lm_dragProxy.lm_right .lm_header .lm_tabs,\n .lm_stack.lm_right .lm_header .lm_tabs {\n transform: rotate(90deg) scaleX(1);\n left: 100%;\n margin-left: 0;\n }\n .lm_dragProxy.lm_right .lm_header .lm_controls,\n .lm_stack.lm_right .lm_header .lm_controls {\n left: 3px;\n }\n .lm_dragProxy.lm_right .lm_header .lm_tabdropdown_list,\n .lm_stack.lm_right .lm_header .lm_tabdropdown_list {\n top: initial;\n right: 20px;\n }\n .lm_dragProxy.lm_bottom .lm_header .lm_tab,\n .lm_stack.lm_bottom .lm_header .lm_tab {\n margin-top: 0;\n border-top: none;\n }\n .lm_dragProxy.lm_bottom .lm_header .lm_controls,\n .lm_stack.lm_bottom .lm_header .lm_controls {\n top: 3px;\n }\n .lm_dragProxy.lm_bottom .lm_header .lm_tabdropdown_list,\n .lm_stack.lm_bottom .lm_header .lm_tabdropdown_list {\n top: initial;\n bottom: 20px;\n }\n .lm_drop_tab_placeholder {\n float: left;\n width: 100px;\n height: 10px;\n visibility: hidden;\n }\n .lm_header .lm_tabdropdown_list {\n position: absolute;\n top: 20px;\n right: 0;\n z-index: 5;\n overflow: hidden;\n }\n .lm_header .lm_tabdropdown_list .lm_tab {\n clear: both;\n padding-right: 10px;\n margin: 0;\n }\n .lm_header .lm_tabdropdown_list .lm_tab .lm_title {\n width: 100px;\n }\n .lm_header .lm_tabdropdown_list .lm_close_tab {\n display: none !important;\n }\n .lm_dragProxy {\n position: absolute;\n top: 0;\n left: 0;\n z-index: 30;\n }\n .lm_dragProxy .lm_header {\n background: transparent;\n }\n .lm_dragProxy .lm_content {\n border-top: none;\n overflow: hidden;\n }\n .lm_dropTargetIndicator {\n display: none;\n position: absolute;\n z-index: 20;\n }\n .lm_dropTargetIndicator .lm_inner {\n width: 100%;\n height: 100%;\n position: relative;\n top: 0;\n left: 0;\n }\n .lm_transition_indicator {\n display: none;\n width: 20px;\n height: 20px;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 20;\n }\n .lm_popin {\n width: 20px;\n height: 20px;\n position: absolute;\n bottom: 0;\n right: 0;\n z-index: 9999;\n }\n .lm_popin > * {\n width: 100%;\n height: 100%;\n position: absolute;\n top: 0;\n left: 0;\n }\n .lm_popin > .lm_bg {\n z-index: 10;\n }\n .lm_popin > .lm_icon {\n z-index: 20;\n } /*# sourceMappingURL=goldenlayout-base.css.map */\n`",
|
1116
|
+
"default": "css`\n ${containerStyles}\n ${loadingSpinnerStyles}\n\n .lm_goldenlayout {\n padding: 1px;\n background: ${neutralLayer1};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n }\n\n .lm_stack.lm_item {\n background-color: ${neutralLayer4};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n }\n .lm_maximised .lm_header {\n background-color: ${neutralLayer4};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n position: unset;\n }\n\n .lm_maximised .lm_header .lm_tabs {\n z-index: 3;\n }\n\n .lm_content {\n background-color: ${neutralLayer3};\n border-radius: calc(${controlCornerRadius} * 1.5px);\n border: 1px solid;\n border-color: #2e3339;\n box-sizing: border-box;\n }\n\n .lm-header {\n z-index: 1;\n }\n .lm_header .lm_tabs {\n padding: 0 16px;\n }\n\n .lm_stack > .lm_items {\n z-index: 2;\n box-shadow: 0px -1px 15px rgba(0, 0, 0, 0.35);\n }\n\n .lm_header .lm_tab.lm_active.lm_focused {\n background-color: ${neutralLayer3};\n }\n .lm_header .lm_tab.lm_active {\n background-color: ${neutralLayer3};\n border: 1px solid;\n border-color: #2e3339;\n border-bottom: 0;\n color: ${accentFillRest};\n }\n\n .lm_header .lm_tab {\n align-items: center;\n background-color: ${neutralLayer4};\n border: 1px solid;\n border-bottom-color: #2e3339;\n border-bottom: 0px solid;\n border-color: rgba(0, 0, 0, 0.35);\n border-radius: calc(${controlCornerRadius} * 1.5px) calc(${controlCornerRadius} * 1.5px) 0 0;\n box-shadow: 1px -1px 2px rgba(0, 0, 0, 0.35);\n color: rgba(255, 255, 255, 0.3);\n display: flex;\n font-family: inherit;\n font-size: 13px;\n font-weight: 700;\n height: 30px;\n margin-right: 2px;\n margin-top: 3px;\n padding: 2px 16px;\n }\n\n .lm_header .lm_tab:not(.lm_active):hover {\n background-color: rgba(255, 255, 255, 0.1);\n color: #f1f1f1;\n }\n\n .lm_header .lm_controls {\n top: 4px;\n display: flex;\n }\n .lm_header .lm_controls > * {\n width: 30px;\n height: 30px;\n background-repeat: no-repeat;\n background-position: center;\n background-size: 16px;\n background-color: rgba(255, 255, 255, 0.03);\n border-radius: calc(${controlCornerRadius} * 1.5px);\n margin-right: 4px;\n top: 3px;\n opacity: 1;\n }\n .lm_header .lm_controls > *:hover {\n background-color: rgba(255, 255, 255, 0.1);\n cursor: pointer;\n }\n\n .lm_controls .lm_maximise {\n background-image: url('${LAYOUT_ICONS.maximiseSVG}');\n }\n .lm_maximised .lm_controls .lm_maximise {\n background-image: url('${LAYOUT_ICONS.minimiseSVG}');\n }\n .lm_controls .lm_close {\n background-image: url('${LAYOUT_ICONS.closeSVG}');\n }\n .lm_header .lm_tab .lm_close_tab {\n background-image: url('${LAYOUT_ICONS.closeSVG}');\n background-size: 10px;\n background-repeat: no-repeat;\n margin-left: 12px;\n position: relative;\n top: 0;\n right: 0;\n }\n\n .lm_header .lm_tab.lm_active {\n padding: 4px 25px 3px 10px;\n }\n\n .lm_header .lm_tab:not(.lm_active) .lm_title {\n color: ${accentFillRest};\n opacity: 0.7;\n }\n\n .lm_header .lm_controls .lm_tabdropdown::before {\n content: none;\n }\n .lm_header .lm_controls .lm_tabdropdown {\n background-image: url('${LAYOUT_ICONS.tabDropdownSVG}');\n }\n .lm_header .lm_tabdropdown_list {\n top: 38px;\n right: 108px;\n background-color: ${neutralLayer3};\n border: 1px solid;\n border-color: #2e3339;\n border-radius: calc(${controlCornerRadius} * 1.5px);\n box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.35);\n }\n .lm_header .lm_tabdropdown_list > .lm_tab {\n box-shadow: none;\n padding: 0 16px;\n white-space: nowrap;\n background-color: transparent;\n color: #c9c9c9;\n height: 36px;\n border-radius: 0;\n overflow: visible;\n text-overflow: normal;\n }\n .lm_header .lm_tabdropdown_list > .lm_tab:last-child {\n border-bottom: 0;\n }\n\n /* gl base styles start */\n .lm_root {\n position: relative;\n }\n .lm_row > .lm_item {\n float: left;\n }\n .lm_content {\n overflow: hidden;\n position: relative;\n }\n .lm_dragging,\n .lm_dragging * {\n cursor: move !important;\n user-select: none;\n }\n .lm_maximised {\n left: 0;\n padding: 1px;\n position: absolute;\n top: 0;\n z-index: 40;\n }\n .lm_maximise_placeholder {\n display: none;\n }\n .lm_splitter {\n position: relative;\n z-index: 20;\n }\n .lm_splitter:hover,\n .lm_splitter.lm_dragging {\n background: ${accentFillRest};\n border-radius: calc(${controlCornerRadius} * 4px);\n }\n .lm_splitter.lm_vertical .lm_drag_handle {\n width: 100%;\n height: 15px;\n position: absolute;\n top: -5px;\n cursor: ns-resize;\n }\n .lm_splitter.lm_horizontal {\n float: left;\n height: 100%;\n }\n .lm_splitter.lm_horizontal .lm_drag_handle {\n width: 15px;\n height: 100%;\n position: absolute;\n left: -5px;\n cursor: ew-resize;\n }\n .lm_header {\n overflow: visible;\n position: relative;\n z-index: 1;\n }\n .lm_header [class^='lm_'] {\n box-sizing: content-box !important;\n }\n .lm_header .lm_controls {\n position: absolute;\n right: 3px;\n }\n .lm_header .lm_controls > li {\n cursor: pointer;\n float: left;\n width: 18px;\n height: 18px;\n text-align: center;\n }\n .lm_header ul {\n margin: 0;\n padding: 0;\n list-style-type: none;\n }\n .lm_header .lm_tabs {\n position: absolute;\n }\n .lm_header .lm_tab {\n cursor: pointer;\n float: left;\n margin-top: 1px;\n padding: 3px 25px 3px 10px;\n position: relative;\n }\n .lm_header .lm_tab i {\n width: 2px;\n height: 19px;\n position: absolute;\n }\n .lm_header .lm_tab i.lm_left {\n top: 0;\n left: -2px;\n }\n .lm_header .lm_tab i.lm_right {\n top: 0;\n right: -2px;\n }\n .lm_header .lm_tab .lm_title {\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n .lm_header .lm_tab .lm_title:only-child {\n padding-left: 10px;\n }\n .lm_header .lm_tab .lm_close_tab {\n width: 14px;\n height: 14px;\n position: absolute;\n top: 11px;\n right: 0;\n text-align: center;\n }\n .lm_stack.lm_left .lm_header,\n .lm_stack.lm_right .lm_header {\n height: 100%;\n }\n .lm_dragProxy.lm_left .lm_header,\n .lm_dragProxy.lm_right .lm_header,\n .lm_stack.lm_left .lm_header,\n .lm_stack.lm_right .lm_header {\n width: 20px;\n float: left;\n vertical-align: top;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabs,\n .lm_dragProxy.lm_right .lm_header .lm_tabs,\n .lm_stack.lm_left .lm_header .lm_tabs,\n .lm_stack.lm_right .lm_header .lm_tabs {\n transform-origin: left top;\n top: 0;\n width: 1000px;\n }\n .lm_dragProxy.lm_left .lm_header .lm_controls,\n .lm_dragProxy.lm_right .lm_header .lm_controls,\n .lm_stack.lm_left .lm_header .lm_controls,\n .lm_stack.lm_right .lm_header .lm_controls {\n bottom: 0;\n }\n .lm_dragProxy.lm_left .lm_items,\n .lm_dragProxy.lm_right .lm_items,\n .lm_stack.lm_left .lm_items,\n .lm_stack.lm_right .lm_items {\n float: left;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabs,\n .lm_stack.lm_left .lm_header .lm_tabs {\n transform: rotate(-90deg) scaleX(-1);\n left: 0;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabs .lm_tab,\n .lm_stack.lm_left .lm_header .lm_tabs .lm_tab {\n transform: scaleX(-1);\n margin-top: 1px;\n }\n .lm_dragProxy.lm_left .lm_header .lm_tabdropdown_list,\n .lm_stack.lm_left .lm_header .lm_tabdropdown_list {\n top: initial;\n right: initial;\n left: 20px;\n }\n .lm_dragProxy.lm_right .lm_content {\n float: left;\n }\n .lm_dragProxy.lm_right .lm_header .lm_tabs,\n .lm_stack.lm_right .lm_header .lm_tabs {\n transform: rotate(90deg) scaleX(1);\n left: 100%;\n margin-left: 0;\n }\n .lm_dragProxy.lm_right .lm_header .lm_controls,\n .lm_stack.lm_right .lm_header .lm_controls {\n left: 3px;\n }\n .lm_dragProxy.lm_right .lm_header .lm_tabdropdown_list,\n .lm_stack.lm_right .lm_header .lm_tabdropdown_list {\n top: initial;\n right: 20px;\n }\n .lm_dragProxy.lm_bottom .lm_header .lm_tab,\n .lm_stack.lm_bottom .lm_header .lm_tab {\n margin-top: 0;\n border-top: none;\n }\n .lm_dragProxy.lm_bottom .lm_header .lm_controls,\n .lm_stack.lm_bottom .lm_header .lm_controls {\n top: 3px;\n }\n .lm_dragProxy.lm_bottom .lm_header .lm_tabdropdown_list,\n .lm_stack.lm_bottom .lm_header .lm_tabdropdown_list {\n top: initial;\n bottom: 20px;\n }\n .lm_drop_tab_placeholder {\n float: left;\n width: 100px;\n height: 10px;\n visibility: hidden;\n }\n .lm_header .lm_tabdropdown_list {\n position: absolute;\n top: 20px;\n right: 0;\n z-index: 5;\n overflow: hidden;\n }\n .lm_header .lm_tabdropdown_list .lm_tab {\n clear: both;\n padding-right: 10px;\n margin: 0;\n }\n .lm_header .lm_tabdropdown_list .lm_tab .lm_title {\n width: 100px;\n }\n .lm_header .lm_tabdropdown_list .lm_close_tab {\n display: none !important;\n }\n .lm_dragProxy {\n position: absolute;\n top: 0;\n left: 0;\n z-index: 30;\n }\n .lm_dragProxy .lm_header {\n background: transparent;\n }\n .lm_dragProxy .lm_content {\n border-top: none;\n overflow: hidden;\n }\n .lm_dropTargetIndicator {\n display: none;\n position: absolute;\n z-index: 20;\n }\n .lm_dropTargetIndicator .lm_inner {\n width: 100%;\n height: 100%;\n position: relative;\n top: 0;\n left: 0;\n }\n .lm_transition_indicator {\n display: none;\n width: 20px;\n height: 20px;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 20;\n }\n .lm_popin {\n width: 20px;\n height: 20px;\n position: absolute;\n bottom: 0;\n right: 0;\n z-index: 9999;\n }\n .lm_popin > * {\n width: 100%;\n height: 100%;\n position: absolute;\n top: 0;\n left: 0;\n }\n .lm_popin > .lm_bg {\n z-index: 10;\n }\n .lm_popin > .lm_icon {\n z-index: 20;\n } /*# sourceMappingURL=goldenlayout-base.css.map */\n`",
|
1138
1117
|
"description": "`ElementStyles` which defines the css for FoundationLayout.",
|
1139
1118
|
"privacy": "public"
|
1140
1119
|
}
|
package/dist/dts/index.d.ts
CHANGED
@@ -1,3 +1,4 @@
|
|
1
1
|
export * from './main';
|
2
|
-
export {
|
2
|
+
export { LAYOUT_ICONS } from './styles';
|
3
|
+
export { CustomButton, DEFAULT_RELOAD_BUFFER, LayoutEmitEvents, LayoutReceiveEvents, LayoutReceiveEventsDetail, LayoutRegionType, LayoutRegistrationError, LayoutUsageError, Placement, RegisteredElementConfig, RegistrationConfig, SerialisedLayout, } from './utils';
|
3
4
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/dts/index.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,OAAO,EACL,qBAAqB,EACrB,gBAAgB,EAChB,mBAAmB,EACnB,yBAAyB,EACzB,gBAAgB,EAChB,uBAAuB,EACvB,gBAAgB,EAChB,SAAS,EACT,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EACL,YAAY,EACZ,qBAAqB,EACrB,gBAAgB,EAChB,mBAAmB,EACnB,yBAAyB,EACzB,gBAAgB,EAChB,uBAAuB,EACvB,gBAAgB,EAChB,SAAS,EACT,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { RootItemConfig } from '@genesis-community/golden-layout';
|
2
2
|
import { FoundationElement } from '@microsoft/fast-foundation';
|
3
|
-
import { LayoutComponent, Placement, RegisteredElementConfig, RegistrationConfig, SerialisedLayout, componentType } from '../utils/';
|
3
|
+
import { LayoutComponent, Placement, RegisteredElementConfig, RegistrationConfig, SerialisedLayout, componentType, CustomButton } from '../utils/';
|
4
4
|
export { layoutStyles } from '../styles';
|
5
5
|
/**
|
6
6
|
* @public
|
@@ -56,6 +56,13 @@ export declare class FoundationLayout extends FoundationElement implements Layou
|
|
56
56
|
hasFirstLoaded: boolean;
|
57
57
|
/** @internal */
|
58
58
|
usingDeclerativeAPI: boolean;
|
59
|
+
/**
|
60
|
+
* Set custom button definition on this property to add them to the layout header controls
|
61
|
+
* @remarks
|
62
|
+
* To see more information see {@link CustomButton}.
|
63
|
+
* @public
|
64
|
+
*/
|
65
|
+
customButtons: CustomButton[];
|
59
66
|
/**
|
60
67
|
* @public
|
61
68
|
* Set to true when the user is currently dragging the panes inside of the layout
|
@@ -252,6 +259,11 @@ export declare class FoundationLayout extends FoundationElement implements Layou
|
|
252
259
|
* @internal
|
253
260
|
*/
|
254
261
|
private attatchResizeEvents;
|
262
|
+
/**
|
263
|
+
* If the user has provided any custom buttons, register a callback with golden layout to add them to any new items
|
264
|
+
* @internal
|
265
|
+
*/
|
266
|
+
private setupCustomButtons;
|
255
267
|
}
|
256
268
|
/**
|
257
269
|
* `ViewTemplate` which defines the html for {@link FoundationLayout}.
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"layout-main.d.ts","sourceRoot":"","sources":["../../../src/main/layout-main.ts"],"names":[],"mappings":"AAAA,OAAO,EAOL,cAAc,EAGf,MAAM,kCAAkC,CAAC;AAI1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAE/D,OAAO,EAEL,eAAe,EAGf,SAAS,EACT,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,EAChB,aAAa,
|
1
|
+
{"version":3,"file":"layout-main.d.ts","sourceRoot":"","sources":["../../../src/main/layout-main.ts"],"names":[],"mappings":"AAAA,OAAO,EAOL,cAAc,EAGf,MAAM,kCAAkC,CAAC;AAI1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAE/D,OAAO,EAEL,eAAe,EAGf,SAAS,EACT,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,EAChB,aAAa,EAKb,YAAY,EACb,MAAM,WAAW,CAAC;AAKnB,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAiBzC;;;;;;GAMG;AACH,qBAAa,gBAAiB,SAAQ,iBAAkB,YAAW,eAAe;;IAChF,OAAO,CAAC,MAAM,CAAe;IAC7B,gBAAgB;IAChB,aAAa,EAAE,WAAW,CAAC;IAC3B,OAAO,CAAC,YAAY,CAAqC;IAEzD,gBAAgB;IAChB,CAAC,aAAa,CAAC,SAAmB;IAElC;;;;OAIG;IACmC,YAAY,EAAE,MAAM,CAAyB;IACnF,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,oBAAoB,CAAK;IAEjC,gBAAgB;IACV,OAAO,CAAC,IAAI,CAAO;IAEzB,gBAAgB;IACP,OAAO,CAAC,OAAO,CAAU;IAClC;;;;;OAKG;IACmC,WAAW,CAAC,EAAE,MAAM,CAAC;IAC3D;;;;OAIG;IACS,sBAAsB,gBAAiB,MAAM,YAC2B;IAEpF;;;;;;;;;;OAUG;IACS,cAAc,UAAS;IACnC,gBAAgB;IACJ,mBAAmB,UAAS;IAExC;;;;;OAKG;IACH,aAAa,EAAE,YAAY,EAAE,CAAC;IAE9B;;;OAGG;IACS,QAAQ,EAAE,OAAO,CAAS;IAEtC;;;;;;;OAOG;IACI,oBAAoB,EAAE,MAAM,GAAG,SAAS,CAAa;IAE5D,gBAAgB;;IAUhB,gBAAgB;IAChB,iBAAiB,IAAI,IAAI;IAsBzB,gBAAgB;IAChB,oBAAoB,IAAI,IAAI;IAO5B,gBAAgB;IAChB,OAAO,CAAC,WAAW;IAInB,gBAAgB;IAChB,OAAO,CAAC,UAAU;IAMlB,gBAAgB;IAChB,OAAO,CAAC,eAAe;IAOvB,gBAAgB;IAChB,OAAO,CAAC,gBAAgB;IAIxB,gBAAgB;IAChB,OAAO,CAAC,iBAAiB;IAOzB,gBAAgB;IAChB,OAAO,CAAC,iBAAiB;IAKzB;;OAEG;IAEH;;;;;;;;;;OAUG;IACH,MAAM,CAAC,2BAA2B,CAAC,MAAM,EAAE,gBAAgB,GAAG,MAAM,EAAE;IActE;;;;;;;;OAQG;IACH,eAAe,IAAI,MAAM,EAAE;IAI3B;;;;OAIG;IACH,SAAS,IAAI,gBAAgB;IAI7B;;;;;;;;;;;;OAYG;IACH,6BAA6B,IAAI,OAAO;IAcxC;;;;;;;;;;;OAWG;IACH,UAAU,CAAC,MAAM,EAAE,gBAAgB,EAAE,iBAAiB,GAAE,aAAa,GAAG,OAAiB;IAsBzF;;;;;;;;;;;OAWG;IACH,OAAO,CACL,MAAM,EAAE,uBAAuB,GAAG,uBAAuB,EAAE,EAC3D,SAAS,GAAE,SAAmC;IA+DhD;;;;;;;;;;;;;;;OAeG;IACH,YAAY,CAAC,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,MAAM;IAW/D;;OAEG;IAEH;;;;;OAKG;IACH,OAAO,CAAC,oBAAoB;IAI5B;;;;OAIG;IACH,mBAAmB,IAAI,IAAI;IAmB3B;;;;;;;OAOG;IACH,gBAAgB,CAAC,CAAC,SAAS,cAAc,EAAE,IAAI,EAAE,CAAC,GAAG,CAAC;IAetD;;;;;;;OAOG;IACH,wBAAwB,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,kBAAkB,GAAG,MAAM;IA0DtE;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IAehC;;;;SAIK;IACL,OAAO,CAAC,kBAAkB;IAY1B;;;;;;;;OAQG;IACH,OAAO,CAAC,kCAAkC;IA4B1C;;;;;;;;;OASG;IACH,OAAO,CAAC,oBAAoB;IAO5B;;;;;;;;OAQG;IACH,OAAO,CAAC,mBAAmB;IAU3B;;;OAGG;IACH,OAAO,CAAC,kBAAkB;CAa3B;AAMD;;;;;GAKG;AACH,eAAO,MAAM,cAAc,uEAK1B,CAAC;AAEF;;;;;;;;GAQG;AACH,eAAO,MAAM,gBAAgB;;;;;;;;2BAI3B,CAAC"}
|
@@ -1,7 +1,23 @@
|
|
1
1
|
import { LayoutConfig } from '@genesis-community/golden-layout';
|
2
2
|
export declare const glVisualConfig: Omit<LayoutConfig, 'root'>;
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
3
|
+
/**
|
4
|
+
* A collection of SVG icons in base64 format.
|
5
|
+
* @remarks
|
6
|
+
* These icons are used by the layout manager for the UI buttons. You can use these as examples for your own custom icons when creating a custom button.
|
7
|
+
* @example
|
8
|
+
* ```
|
9
|
+
* export const layoutCustomButtons: CustomButton[] = [
|
10
|
+
* { svg: LAYOUT_ICONS.renameSVG, onClick: (button: HTMLElement, elem: HTMLElement) => {} },
|
11
|
+
* ];
|
12
|
+
* ```
|
13
|
+
*
|
14
|
+
* @public
|
15
|
+
*/
|
16
|
+
export declare const LAYOUT_ICONS: {
|
17
|
+
readonly renameSVG: "";
|
18
|
+
readonly maximiseSVG: "";
|
19
|
+
readonly minimiseSVG: "";
|
20
|
+
readonly closeSVG: "";
|
21
|
+
readonly tabDropdownSVG: "";
|
22
|
+
};
|
7
23
|
//# sourceMappingURL=constants.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/styles/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAEhE,eAAO,MAAM,cAAc,EAAE,IAAI,CAAC,YAAY,EAAE,MAAM,CAUrD,CAAC;
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/styles/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAEhE,eAAO,MAAM,cAAc,EAAE,IAAI,CAAC,YAAY,EAAE,MAAM,CAUrD,CAAC;AAiBF;;;;;;;;;;;;GAYG;AACH,eAAO,MAAM,YAAY;;;;;;CAMf,CAAC"}
|
@@ -1,5 +1,16 @@
|
|
1
1
|
import { ResolvedLayoutConfig } from '@genesis-community/golden-layout';
|
2
2
|
import { componentType } from './constants';
|
3
|
+
/**
|
4
|
+
* Definition of a custom button which will be added to all layout items.
|
5
|
+
* @remarks
|
6
|
+
* `svg` - string of the SVG to use for the button. Needs to be in the format `data:image/svg+xml;base64,<<base64 encoded definition>>`.
|
7
|
+
* `onClick` - function which will be called when the button is clicked. The clicked button and the contained element associated with the clicked button will be passed to the function.
|
8
|
+
* @public
|
9
|
+
*/
|
10
|
+
export type CustomButton = {
|
11
|
+
svg: string;
|
12
|
+
onClick: (button: HTMLElement, element: HTMLElement) => void;
|
13
|
+
};
|
3
14
|
/**
|
4
15
|
* @public
|
5
16
|
* Versioned layout config objects. `v` is the version and `c` contains the layout config.
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/utils/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C;;;;;;;;;;GAUG;AACH,MAAM,MAAM,gBAAgB,GAAG;IAC7B,CAAC,EAAE,GAAG,CAAC;IACP,CAAC,EAAE,oBAAoB,CAAC;CACzB,CAAC;AAEF;;;;;;;;;;GAUG;AACH,MAAM,WAAW,uBAAuB;IACtC,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED;;;;;;;;;GASG;AACH,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IAC1C,QAAQ,CAAC,EAAE;QACT,IAAI,EAAE,gBAAgB,CAAC;QACvB,IAAI,CAAC,EAAE,MAAM,CAAC;KACf,CAAC;CACH,CAAC;AAEF,gBAAgB;AAChB,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,EAAE,CAAC,EAAE,MAAM,CAAC;CACb;AAED,gBAAgB;AAChB,eAAO,MAAM,iBAAiB,6CAA8C,CAAC;AAC7E;;;;GAIG;AACH,MAAM,MAAM,gBAAgB,GAAG,CAAC,OAAO,iBAAiB,CAAC,CAAC,MAAM,CAAC,CAAC;AAClE,gBAAgB;AAChB,MAAM,MAAM,cAAc,GAAG,gBAAgB,GAAG,MAAM,GAAG,MAAM,CAAC;AAEhE,gBAAgB;AAChB,MAAM,WAAW,eAAe;IAC9B,CAAC,aAAa,CAAC,EAAE,cAAc,CAAC;IAChC,wBAAwB,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM,CAAC;IAC7D,mBAAmB,IAAI,IAAI,CAAC;CAC7B;AAED,gBAAgB;AAChB,MAAM,MAAM,gBAAgB,GAAG;IAC7B,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACrB,CAAC"}
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/utils/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C;;;;;;GAMG;AACH,MAAM,MAAM,YAAY,GAAG;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,KAAK,IAAI,CAAC;CAC9D,CAAC;AAEF;;;;;;;;;;GAUG;AACH,MAAM,MAAM,gBAAgB,GAAG;IAC7B,CAAC,EAAE,GAAG,CAAC;IACP,CAAC,EAAE,oBAAoB,CAAC;CACzB,CAAC;AAEF;;;;;;;;;;GAUG;AACH,MAAM,WAAW,uBAAuB;IACtC,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED;;;;;;;;;GASG;AACH,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IAC1C,QAAQ,CAAC,EAAE;QACT,IAAI,EAAE,gBAAgB,CAAC;QACvB,IAAI,CAAC,EAAE,MAAM,CAAC;KACf,CAAC;CACH,CAAC;AAEF,gBAAgB;AAChB,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,EAAE,CAAC,EAAE,MAAM,CAAC;CACb;AAED,gBAAgB;AAChB,eAAO,MAAM,iBAAiB,6CAA8C,CAAC;AAC7E;;;;GAIG;AACH,MAAM,MAAM,gBAAgB,GAAG,CAAC,OAAO,iBAAiB,CAAC,CAAC,MAAM,CAAC,CAAC;AAClE,gBAAgB;AAChB,MAAM,MAAM,cAAc,GAAG,gBAAgB,GAAG,MAAM,GAAG,MAAM,CAAC;AAEhE,gBAAgB;AAChB,MAAM,WAAW,eAAe;IAC9B,CAAC,aAAa,CAAC,EAAE,cAAc,CAAC;IAChC,wBAAwB,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM,CAAC;IAC7D,mBAAmB,IAAI,IAAI,CAAC;CAC7B;AAED,gBAAgB;AAChB,MAAM,MAAM,gBAAgB,GAAG;IAC7B,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACrB,CAAC"}
|
package/dist/esm/index.js
CHANGED
@@ -108,6 +108,7 @@ export class FoundationLayout extends FoundationElement {
|
|
108
108
|
this.shadowRoot.addEventListener('dragStop', this.onDragStop, true);
|
109
109
|
this.shadowRoot.addEventListener('closeButtonPre', this.onPreItemRemoved, true);
|
110
110
|
this.shadowRoot.addEventListener('closeButtonPressed', this.onPostItemRemoved, true);
|
111
|
+
this.setupCustomButtons();
|
111
112
|
}
|
112
113
|
/** @internal */
|
113
114
|
disconnectedCallback() {
|
@@ -524,6 +525,24 @@ export class FoundationLayout extends FoundationElement {
|
|
524
525
|
h.addEventListener('click', __classPrivateFieldGet(this, _FoundationLayout__boundDragListener, "f"));
|
525
526
|
});
|
526
527
|
}
|
528
|
+
/**
|
529
|
+
* If the user has provided any custom buttons, register a callback with golden layout to add them to any new items
|
530
|
+
* @internal
|
531
|
+
*/
|
532
|
+
setupCustomButtons() {
|
533
|
+
this.layout.on('stackCreated', (stack) => {
|
534
|
+
var _b;
|
535
|
+
const controlElem = stack.target.header.controlsContainerElement;
|
536
|
+
const containedElement = () => stack.target.getActiveContentItem().container.element;
|
537
|
+
(_b = this.customButtons) === null || _b === void 0 ? void 0 : _b.forEach((customButton) => {
|
538
|
+
const button = document.createElement('div');
|
539
|
+
button.classList.add('lm_custom_button');
|
540
|
+
button.style['background-image'] = `url('${customButton.svg}')`;
|
541
|
+
button.addEventListener('click', () => customButton.onClick(button, containedElement()));
|
542
|
+
controlElem.prepend(button);
|
543
|
+
});
|
544
|
+
});
|
545
|
+
}
|
527
546
|
}
|
528
547
|
_FoundationLayout__boundPreDeletionListener = new WeakMap(), _FoundationLayout__boundDragListener = new WeakMap(), _a = componentType;
|
529
548
|
__decorate([
|
@@ -9,7 +9,28 @@ export const glVisualConfig = {
|
|
9
9
|
popout: false,
|
10
10
|
},
|
11
11
|
};
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
12
|
+
const renameSVG = '';
|
13
|
+
const maximiseSVG = '';
|
14
|
+
const minimiseSVG = '';
|
15
|
+
const closeSVG = '';
|
16
|
+
const tabDropdownSVG = '';
|
17
|
+
/**
|
18
|
+
* A collection of SVG icons in base64 format.
|
19
|
+
* @remarks
|
20
|
+
* These icons are used by the layout manager for the UI buttons. You can use these as examples for your own custom icons when creating a custom button.
|
21
|
+
* @example
|
22
|
+
* ```
|
23
|
+
* export const layoutCustomButtons: CustomButton[] = [
|
24
|
+
* { svg: LAYOUT_ICONS.renameSVG, onClick: (button: HTMLElement, elem: HTMLElement) => {} },
|
25
|
+
* ];
|
26
|
+
* ```
|
27
|
+
*
|
28
|
+
* @public
|
29
|
+
*/
|
30
|
+
export const LAYOUT_ICONS = {
|
31
|
+
renameSVG,
|
32
|
+
maximiseSVG,
|
33
|
+
minimiseSVG,
|
34
|
+
closeSVG,
|
35
|
+
tabDropdownSVG,
|
36
|
+
};
|
@@ -1,7 +1,7 @@
|
|
1
1
|
// NOTE: This file is stylelint ignored as the css class names that golden layout use go against the rules
|
2
2
|
import { accentFillRest, controlCornerRadius, neutralLayer1, neutralLayer3, neutralLayer4, } from '@microsoft/fast-components';
|
3
3
|
import { css } from '@microsoft/fast-element';
|
4
|
-
import {
|
4
|
+
import { LAYOUT_ICONS } from './constants';
|
5
5
|
const containerStyles = `
|
6
6
|
:host {
|
7
7
|
contain: content;
|
@@ -194,16 +194,16 @@ export const layoutStyles = css `
|
|
194
194
|
}
|
195
195
|
|
196
196
|
.lm_controls .lm_maximise {
|
197
|
-
background-image: url('${
|
197
|
+
background-image: url('${LAYOUT_ICONS.maximiseSVG}');
|
198
198
|
}
|
199
199
|
.lm_maximised .lm_controls .lm_maximise {
|
200
|
-
background-image: url('${minimiseSVG}');
|
200
|
+
background-image: url('${LAYOUT_ICONS.minimiseSVG}');
|
201
201
|
}
|
202
202
|
.lm_controls .lm_close {
|
203
|
-
background-image: url('${closeSVG}');
|
203
|
+
background-image: url('${LAYOUT_ICONS.closeSVG}');
|
204
204
|
}
|
205
205
|
.lm_header .lm_tab .lm_close_tab {
|
206
|
-
background-image: url('${closeSVG}');
|
206
|
+
background-image: url('${LAYOUT_ICONS.closeSVG}');
|
207
207
|
background-size: 10px;
|
208
208
|
background-repeat: no-repeat;
|
209
209
|
margin-left: 12px;
|
@@ -225,7 +225,7 @@ export const layoutStyles = css `
|
|
225
225
|
content: none;
|
226
226
|
}
|
227
227
|
.lm_header .lm_controls .lm_tabdropdown {
|
228
|
-
background-image: url('${tabDropdownSVG}');
|
228
|
+
background-image: url('${LAYOUT_ICONS.tabDropdownSVG}');
|
229
229
|
}
|
230
230
|
.lm_header .lm_tabdropdown_list {
|
231
231
|
top: 38px;
|
@@ -184,6 +184,50 @@
|
|
184
184
|
"name": "",
|
185
185
|
"preserveMemberOrder": false,
|
186
186
|
"members": [
|
187
|
+
{
|
188
|
+
"kind": "TypeAlias",
|
189
|
+
"canonicalReference": "@genesislcap/foundation-layout!CustomButton:type",
|
190
|
+
"docComment": "/**\n * Definition of a custom button which will be added to all layout items.\n *\n * @remarks\n *\n * `svg` - string of the SVG to use for the button. Needs to be in the format `data:image/svg+xml;base64,<<base64 encoded definition>>`. `onClick` - function which will be called when the button is clicked. The clicked button and the contained element associated with the clicked button will be passed to the function.\n *\n * @public\n */\n",
|
191
|
+
"excerptTokens": [
|
192
|
+
{
|
193
|
+
"kind": "Content",
|
194
|
+
"text": "export type CustomButton = "
|
195
|
+
},
|
196
|
+
{
|
197
|
+
"kind": "Content",
|
198
|
+
"text": "{\n svg: string;\n onClick: (button: "
|
199
|
+
},
|
200
|
+
{
|
201
|
+
"kind": "Reference",
|
202
|
+
"text": "HTMLElement",
|
203
|
+
"canonicalReference": "!HTMLElement:interface"
|
204
|
+
},
|
205
|
+
{
|
206
|
+
"kind": "Content",
|
207
|
+
"text": ", element: "
|
208
|
+
},
|
209
|
+
{
|
210
|
+
"kind": "Reference",
|
211
|
+
"text": "HTMLElement",
|
212
|
+
"canonicalReference": "!HTMLElement:interface"
|
213
|
+
},
|
214
|
+
{
|
215
|
+
"kind": "Content",
|
216
|
+
"text": ") => void;\n}"
|
217
|
+
},
|
218
|
+
{
|
219
|
+
"kind": "Content",
|
220
|
+
"text": ";"
|
221
|
+
}
|
222
|
+
],
|
223
|
+
"fileUrlPath": "src/utils/types.ts",
|
224
|
+
"releaseTag": "Public",
|
225
|
+
"name": "CustomButton",
|
226
|
+
"typeTokenRange": {
|
227
|
+
"startIndex": 1,
|
228
|
+
"endIndex": 6
|
229
|
+
}
|
230
|
+
},
|
187
231
|
{
|
188
232
|
"kind": "Variable",
|
189
233
|
"canonicalReference": "@genesislcap/foundation-layout!DEFAULT_RELOAD_BUFFER:var",
|
@@ -354,6 +398,41 @@
|
|
354
398
|
"isProtected": false,
|
355
399
|
"isAbstract": false
|
356
400
|
},
|
401
|
+
{
|
402
|
+
"kind": "Property",
|
403
|
+
"canonicalReference": "@genesislcap/foundation-layout!FoundationLayout#customButtons:member",
|
404
|
+
"docComment": "/**\n * Set custom button definition on this property to add them to the layout header controls\n *\n * @remarks\n *\n * To see more information see {@link CustomButton}.\n *\n * @public\n */\n",
|
405
|
+
"excerptTokens": [
|
406
|
+
{
|
407
|
+
"kind": "Content",
|
408
|
+
"text": "customButtons: "
|
409
|
+
},
|
410
|
+
{
|
411
|
+
"kind": "Reference",
|
412
|
+
"text": "CustomButton",
|
413
|
+
"canonicalReference": "@genesislcap/foundation-layout!CustomButton:type"
|
414
|
+
},
|
415
|
+
{
|
416
|
+
"kind": "Content",
|
417
|
+
"text": "[]"
|
418
|
+
},
|
419
|
+
{
|
420
|
+
"kind": "Content",
|
421
|
+
"text": ";"
|
422
|
+
}
|
423
|
+
],
|
424
|
+
"isReadonly": false,
|
425
|
+
"isOptional": false,
|
426
|
+
"releaseTag": "Public",
|
427
|
+
"name": "customButtons",
|
428
|
+
"propertyTypeTokenRange": {
|
429
|
+
"startIndex": 1,
|
430
|
+
"endIndex": 3
|
431
|
+
},
|
432
|
+
"isStatic": false,
|
433
|
+
"isProtected": false,
|
434
|
+
"isAbstract": false
|
435
|
+
},
|
357
436
|
{
|
358
437
|
"kind": "Property",
|
359
438
|
"canonicalReference": "@genesislcap/foundation-layout!FoundationLayout#dragging:member",
|
@@ -1269,6 +1348,29 @@
|
|
1269
1348
|
}
|
1270
1349
|
]
|
1271
1350
|
},
|
1351
|
+
{
|
1352
|
+
"kind": "Variable",
|
1353
|
+
"canonicalReference": "@genesislcap/foundation-layout!LAYOUT_ICONS:var",
|
1354
|
+
"docComment": "/**\n * A collection of SVG icons in base64 format.\n *\n * @remarks\n *\n * These icons are used by the layout manager for the UI buttons. You can use these as examples for your own custom icons when creating a custom button.\n *\n * @example\n * ```\n * export const layoutCustomButtons: CustomButton[] = [\n * { svg: LAYOUT_ICONS.renameSVG, onClick: (button: HTMLElement, elem: HTMLElement) => {} },\n * ];\n * ```\n *\n * @public\n */\n",
|
1355
|
+
"excerptTokens": [
|
1356
|
+
{
|
1357
|
+
"kind": "Content",
|
1358
|
+
"text": "LAYOUT_ICONS: "
|
1359
|
+
},
|
1360
|
+
{
|
1361
|
+
"kind": "Content",
|
1362
|
+
"text": "{\n readonly renameSVG: \"\";\n readonly maximiseSVG: \"\";\n readonly minimiseSVG: \"\";\n readonly closeSVG: \"\";\n readonly tabDropdownSVG: \"\";\n}"
|
1363
|
+
}
|
1364
|
+
],
|
1365
|
+
"fileUrlPath": "src/styles/constants.ts",
|
1366
|
+
"isReadonly": true,
|
1367
|
+
"releaseTag": "Public",
|
1368
|
+
"name": "LAYOUT_ICONS",
|
1369
|
+
"variableTypeTokenRange": {
|
1370
|
+
"startIndex": 1,
|
1371
|
+
"endIndex": 2
|
1372
|
+
}
|
1373
|
+
},
|
1272
1374
|
{
|
1273
1375
|
"kind": "Variable",
|
1274
1376
|
"canonicalReference": "@genesislcap/foundation-layout!LayoutEmitEvents:var",
|
@@ -16,6 +16,18 @@ declare const componentType: unique symbol;
|
|
16
16
|
/** @internal */
|
17
17
|
declare type ComponentTypes = LayoutRegionType | 'root' | 'item';
|
18
18
|
|
19
|
+
/**
|
20
|
+
* Definition of a custom button which will be added to all layout items.
|
21
|
+
* @remarks
|
22
|
+
* `svg` - string of the SVG to use for the button. Needs to be in the format `data:image/svg+xml;base64,<<base64 encoded definition>>`.
|
23
|
+
* `onClick` - function which will be called when the button is clicked. The clicked button and the contained element associated with the clicked button will be passed to the function.
|
24
|
+
* @public
|
25
|
+
*/
|
26
|
+
export declare type CustomButton = {
|
27
|
+
svg: string;
|
28
|
+
onClick: (button: HTMLElement, element: HTMLElement) => void;
|
29
|
+
};
|
30
|
+
|
19
31
|
/**
|
20
32
|
* Default time in milliseconds for the layout to buffer calls to reloading
|
21
33
|
* the layout while the declarative API is loading.
|
@@ -79,6 +91,13 @@ export declare class FoundationLayout extends FoundationElement implements Layou
|
|
79
91
|
hasFirstLoaded: boolean;
|
80
92
|
/** @internal */
|
81
93
|
usingDeclerativeAPI: boolean;
|
94
|
+
/**
|
95
|
+
* Set custom button definition on this property to add them to the layout header controls
|
96
|
+
* @remarks
|
97
|
+
* To see more information see {@link CustomButton}.
|
98
|
+
* @public
|
99
|
+
*/
|
100
|
+
customButtons: CustomButton[];
|
82
101
|
/**
|
83
102
|
* @public
|
84
103
|
* Set to true when the user is currently dragging the panes inside of the layout
|
@@ -275,6 +294,11 @@ export declare class FoundationLayout extends FoundationElement implements Layou
|
|
275
294
|
* @internal
|
276
295
|
*/
|
277
296
|
private attatchResizeEvents;
|
297
|
+
/**
|
298
|
+
* If the user has provided any custom buttons, register a callback with golden layout to add them to any new items
|
299
|
+
* @internal
|
300
|
+
*/
|
301
|
+
private setupCustomButtons;
|
278
302
|
}
|
279
303
|
|
280
304
|
/**
|
@@ -421,6 +445,27 @@ export declare class FoundationLayoutRegion extends FoundationElement implements
|
|
421
445
|
cacheElementsAndRegister(config: RegistrationConfig): string;
|
422
446
|
}
|
423
447
|
|
448
|
+
/**
|
449
|
+
* A collection of SVG icons in base64 format.
|
450
|
+
* @remarks
|
451
|
+
* These icons are used by the layout manager for the UI buttons. You can use these as examples for your own custom icons when creating a custom button.
|
452
|
+
* @example
|
453
|
+
* ```
|
454
|
+
* export const layoutCustomButtons: CustomButton[] = [
|
455
|
+
* { svg: LAYOUT_ICONS.renameSVG, onClick: (button: HTMLElement, elem: HTMLElement) => {} },
|
456
|
+
* ];
|
457
|
+
* ```
|
458
|
+
*
|
459
|
+
* @public
|
460
|
+
*/
|
461
|
+
export declare const LAYOUT_ICONS: {
|
462
|
+
readonly renameSVG: "";
|
463
|
+
readonly maximiseSVG: "";
|
464
|
+
readonly minimiseSVG: "";
|
465
|
+
readonly closeSVG: "";
|
466
|
+
readonly tabDropdownSVG: "";
|
467
|
+
};
|
468
|
+
|
424
469
|
/** @internal */
|
425
470
|
declare interface LayoutComponent {
|
426
471
|
[componentType]: ComponentTypes;
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<!-- Do not edit this file. It is automatically generated by API Documenter. -->
|
2
|
+
|
3
|
+
[Home](./index.md) > [@genesislcap/foundation-layout](./foundation-layout.md) > [CustomButton](./foundation-layout.custombutton.md)
|
4
|
+
|
5
|
+
## CustomButton type
|
6
|
+
|
7
|
+
Definition of a custom button which will be added to all layout items.
|
8
|
+
|
9
|
+
**Signature:**
|
10
|
+
|
11
|
+
```typescript
|
12
|
+
export type CustomButton = {
|
13
|
+
svg: string;
|
14
|
+
onClick: (button: HTMLElement, element: HTMLElement) => void;
|
15
|
+
};
|
16
|
+
```
|
17
|
+
|
18
|
+
## Remarks
|
19
|
+
|
20
|
+
`svg` - string of the SVG to use for the button. Needs to be in the format `data:image/svg+xml;base64,<<base64 encoded definition>>`<!-- -->. `onClick` - function which will be called when the button is clicked. The clicked button and the contained element associated with the clicked button will be passed to the function.
|
21
|
+
|
@@ -0,0 +1,18 @@
|
|
1
|
+
<!-- Do not edit this file. It is automatically generated by API Documenter. -->
|
2
|
+
|
3
|
+
[Home](./index.md) > [@genesislcap/foundation-layout](./foundation-layout.md) > [FoundationLayout](./foundation-layout.foundationlayout.md) > [customButtons](./foundation-layout.foundationlayout.custombuttons.md)
|
4
|
+
|
5
|
+
## FoundationLayout.customButtons property
|
6
|
+
|
7
|
+
Set custom button definition on this property to add them to the layout header controls
|
8
|
+
|
9
|
+
**Signature:**
|
10
|
+
|
11
|
+
```typescript
|
12
|
+
customButtons: CustomButton[];
|
13
|
+
```
|
14
|
+
|
15
|
+
## Remarks
|
16
|
+
|
17
|
+
To see more information see [CustomButton](./foundation-layout.custombutton.md)<!-- -->.
|
18
|
+
|
@@ -26,6 +26,7 @@ The constructor for this class is marked as internal. Third-party code should no
|
|
26
26
|
| Property | Modifiers | Type | Description |
|
27
27
|
| --- | --- | --- | --- |
|
28
28
|
| [autoSaveKey?](./foundation-layout.foundationlayout.autosavekey.md) | | string | _(Optional)_ Attribute which if set will auto save and load the layout as the user changes it. Omit this attribute to disable this feature. Set attribute using <code>auto-save-key</code>. |
|
29
|
+
| [customButtons](./foundation-layout.foundationlayout.custombuttons.md) | | [CustomButton](./foundation-layout.custombutton.md)<!-- -->\[\] | Set custom button definition on this property to add them to the layout header controls |
|
29
30
|
| [dragging](./foundation-layout.foundationlayout.dragging.md) | | boolean | Set to true when the user is currently dragging the panes inside of the layout |
|
30
31
|
| [hasFirstLoaded](./foundation-layout.foundationlayout.hasfirstloaded.md) | | boolean | Boolean signifies whether the layout has loaded for the first time or not. |
|
31
32
|
| [lifecycleUpdateToken](./foundation-layout.foundationlayout.lifecycleupdatetoken.md) | | string \| undefined | Used to calculate whether a layout item should run its lifecycle methods or not |
|
@@ -0,0 +1,33 @@
|
|
1
|
+
<!-- Do not edit this file. It is automatically generated by API Documenter. -->
|
2
|
+
|
3
|
+
[Home](./index.md) > [@genesislcap/foundation-layout](./foundation-layout.md) > [LAYOUT\_ICONS](./foundation-layout.layout_icons.md)
|
4
|
+
|
5
|
+
## LAYOUT\_ICONS variable
|
6
|
+
|
7
|
+
A collection of SVG icons in base64 format.
|
8
|
+
|
9
|
+
**Signature:**
|
10
|
+
|
11
|
+
```typescript
|
12
|
+
LAYOUT_ICONS: {
|
13
|
+
readonly renameSVG: "";
|
14
|
+
readonly maximiseSVG: "";
|
15
|
+
readonly minimiseSVG: "";
|
16
|
+
readonly closeSVG: "";
|
17
|
+
readonly tabDropdownSVG: "";
|
18
|
+
}
|
19
|
+
```
|
20
|
+
|
21
|
+
## Remarks
|
22
|
+
|
23
|
+
These icons are used by the layout manager for the UI buttons. You can use these as examples for your own custom icons when creating a custom button.
|
24
|
+
|
25
|
+
## Example
|
26
|
+
|
27
|
+
|
28
|
+
```
|
29
|
+
export const layoutCustomButtons: CustomButton[] = [
|
30
|
+
{ svg: LAYOUT_ICONS.renameSVG, onClick: (button: HTMLElement, elem: HTMLElement) => {} },
|
31
|
+
];
|
32
|
+
```
|
33
|
+
|
@@ -26,6 +26,7 @@
|
|
26
26
|
| --- | --- |
|
27
27
|
| [DEFAULT\_RELOAD\_BUFFER](./foundation-layout.default_reload_buffer.md) | <p>Default time in milliseconds for the layout to buffer calls to reloading the layout while the declarative API is loading.</p><p>During the first load of the layout, a loading spinner will be shown.</p> |
|
28
28
|
| [foundationLayoutComponents](./foundation-layout.foundationlayoutcomponents.md) | Registration object to register the layout with your design system. |
|
29
|
+
| [LAYOUT\_ICONS](./foundation-layout.layout_icons.md) | A collection of SVG icons in base64 format. |
|
29
30
|
| [LayoutEmitEvents](./foundation-layout.layoutemitevents.md) | <p>Defines events that the layout system emits</p><p>'firstLoaded' - emitted when the layout has finished loading the first time using the declarative API after [DEFAULT\_RELOAD\_BUFFER](./foundation-layout.default_reload_buffer.md) ms. <br/> 'itemAdded' - emitted when an item is added to the layout' <br/> 'itemRemoved' - emitted when an item is removed from the layout' <br/> 'itemResized' - emitted when the user drags the divider to resize elements</p> |
|
30
31
|
| [LayoutReceiveEvents](./foundation-layout.layoutreceiveevents.md) | <p>Defines events that the layout system listens for</p><p>'changeTitle' - emit this from a contained item to update the title of the window that contains it.</p> |
|
31
32
|
| [layoutStyles](./foundation-layout.layoutstyles.md) | <code>ElementStyles</code> which defines the css for [FoundationLayout](./foundation-layout.foundationlayout.md)<!-- -->. |
|
@@ -35,6 +36,7 @@
|
|
35
36
|
|
36
37
|
| Type Alias | Description |
|
37
38
|
| --- | --- |
|
39
|
+
| [CustomButton](./foundation-layout.custombutton.md) | Definition of a custom button which will be added to all layout items. |
|
38
40
|
| [LayoutReceiveEventsDetail](./foundation-layout.layoutreceiveeventsdetail.md) | <p>Defines the shape of the detail that the layout listens works with for events it listens on</p><p>'changeTitle' - <code>title</code> is the string you want to set. For <code>mode</code>: <code>replace</code> will set the title to be <code>title</code>, <code>suffix</code> will append <code>title</code> to the end of the existing title.</p> |
|
39
41
|
| [LayoutRegionType](./foundation-layout.layoutregiontype.md) | Union type describing the three different types of region splits. Set on the <code>type</code> attribute on [FoundationLayoutRegion](./foundation-layout.foundationlayoutregion.md)<!-- -->. |
|
40
42
|
| [Placement](./foundation-layout.placement.md) | Where to and how to add the new item(s) into the layout when using the [FoundationLayout.addItem()](./foundation-layout.foundationlayout.additem.md) API. |
|
package/docs/api-report.md
CHANGED
@@ -13,6 +13,12 @@ import { ResolvedLayoutConfig } from '@genesis-community/golden-layout';
|
|
13
13
|
import { RootItemConfig } from '@genesis-community/golden-layout';
|
14
14
|
import { ViewTemplate } from '@microsoft/fast-element';
|
15
15
|
|
16
|
+
// @public
|
17
|
+
export type CustomButton = {
|
18
|
+
svg: string;
|
19
|
+
onClick: (button: HTMLElement, element: HTMLElement) => void;
|
20
|
+
};
|
21
|
+
|
16
22
|
// @public
|
17
23
|
export const DEFAULT_RELOAD_BUFFER = 500;
|
18
24
|
|
@@ -32,6 +38,7 @@ export class FoundationLayout extends FoundationElement implements LayoutCompone
|
|
32
38
|
cacheElementsAndRegister({ elements, id }: RegistrationConfig): string;
|
33
39
|
// @internal (undocumented)
|
34
40
|
connectedCallback(): void;
|
41
|
+
customButtons: CustomButton[];
|
35
42
|
// @internal (undocumented)
|
36
43
|
disconnectedCallback(): void;
|
37
44
|
dragging: boolean;
|
@@ -113,6 +120,15 @@ export class FoundationLayoutRegion extends FoundationElement implements LayoutC
|
|
113
120
|
type: LayoutRegionType;
|
114
121
|
}
|
115
122
|
|
123
|
+
// @public
|
124
|
+
export const LAYOUT_ICONS: {
|
125
|
+
readonly renameSVG: "";
|
126
|
+
readonly maximiseSVG: "";
|
127
|
+
readonly minimiseSVG: "";
|
128
|
+
readonly closeSVG: "";
|
129
|
+
readonly tabDropdownSVG: "";
|
130
|
+
};
|
131
|
+
|
116
132
|
// @public
|
117
133
|
export const LayoutEmitEvents: {
|
118
134
|
readonly firstLoaded: "first-loaded";
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@genesislcap/foundation-layout",
|
3
3
|
"description": "Genesis Foundation UI App Layout",
|
4
|
-
"version": "14.
|
4
|
+
"version": "14.76.0",
|
5
5
|
"license": "SEE LICENSE IN license.txt",
|
6
6
|
"main": "dist/esm/index.js",
|
7
7
|
"types": "dist/foundation-layout.d.ts",
|
@@ -24,14 +24,14 @@
|
|
24
24
|
"test:debug": "genx test --debug"
|
25
25
|
},
|
26
26
|
"devDependencies": {
|
27
|
-
"@genesislcap/foundation-testing": "14.
|
28
|
-
"@genesislcap/genx": "14.
|
27
|
+
"@genesislcap/foundation-testing": "14.76.0",
|
28
|
+
"@genesislcap/genx": "14.76.0",
|
29
29
|
"rimraf": "^3.0.2"
|
30
30
|
},
|
31
31
|
"dependencies": {
|
32
32
|
"@genesis-community/golden-layout": "^2.10.0",
|
33
|
-
"@genesislcap/foundation-comms": "14.
|
34
|
-
"@genesislcap/foundation-utils": "14.
|
33
|
+
"@genesislcap/foundation-comms": "14.76.0",
|
34
|
+
"@genesislcap/foundation-utils": "14.76.0",
|
35
35
|
"@microsoft/fast-components": "^2.21.3",
|
36
36
|
"@microsoft/fast-element": "^1.7.0",
|
37
37
|
"@microsoft/fast-foundation": "^2.33.2",
|
@@ -46,5 +46,5 @@
|
|
46
46
|
"access": "public"
|
47
47
|
},
|
48
48
|
"customElements": "dist/custom-elements.json",
|
49
|
-
"gitHead": "
|
49
|
+
"gitHead": "9f90400b8a08e671c9ab61e8f44647f2a7306492"
|
50
50
|
}
|