@genesislcap/foundation-layout 14.75.0 → 14.77.0

Sign up to get free protection for your applications and to get access to all the features.
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 unregister 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.
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": "maximisSVG",
1028
+ "name": "LAYOUT_ICONS",
1004
1029
  "type": {
1005
- "text": "string"
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": "maximisSVG",
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": "tabDropdownSVG",
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
  }
@@ -1,3 +1,4 @@
1
1
  export * from './main';
2
- export { DEFAULT_RELOAD_BUFFER, LayoutEmitEvents, LayoutReceiveEvents, LayoutReceiveEventsDetail, LayoutRegionType, LayoutRegistrationError, LayoutUsageError, Placement, RegisteredElementConfig, RegistrationConfig, SerialisedLayout, } from './utils';
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
@@ -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":"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"}
1
+ {"version":3,"file":"layout-main.d.ts","sourceRoot":"","sources":["../../../src/main/layout-main.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,23 @@
1
1
  import { LayoutConfig } from '@genesis-community/golden-layout';
2
2
  export declare const glVisualConfig: Omit<LayoutConfig, 'root'>;
3
- export declare const maximisSVG = "";
4
- export declare const minimiseSVG = "";
5
- export declare const closeSVG = "";
6
- export declare const tabDropdownSVG = "";
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;AAEF,eAAO,MAAM,UAAU,ulCAC+jC,CAAC;AAEvlC,eAAO,MAAM,WAAW,+hBACsgB,CAAC;AAE/hB,eAAO,MAAM,QAAQ,u2BACi1B,CAAC;AAEv2B,eAAO,MAAM,cAAc,2sBAC+qB,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
@@ -1,2 +1,3 @@
1
1
  export * from './main';
2
+ export { LAYOUT_ICONS } from './styles';
2
3
  export { DEFAULT_RELOAD_BUFFER, LayoutEmitEvents, LayoutReceiveEvents, LayoutRegistrationError, LayoutUsageError, } from './utils';
@@ -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
- export const maximisSVG = '';
13
- export const minimiseSVG = '';
14
- export const closeSVG = '';
15
- export const tabDropdownSVG = '';
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 { maximisSVG, minimiseSVG, closeSVG, tabDropdownSVG } from './constants';
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('${maximisSVG}');
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) &gt; [@genesislcap/foundation-layout](./foundation-layout.md) &gt; [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) &gt; [@genesislcap/foundation-layout](./foundation-layout.md) &gt; [FoundationLayout](./foundation-layout.foundationlayout.md) &gt; [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) &gt; [@genesislcap/foundation-layout](./foundation-layout.md) &gt; [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. |
@@ -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.75.0",
4
+ "version": "14.77.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.75.0",
28
- "@genesislcap/genx": "14.75.0",
27
+ "@genesislcap/foundation-testing": "14.77.0",
28
+ "@genesislcap/genx": "14.77.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.75.0",
34
- "@genesislcap/foundation-utils": "14.75.0",
33
+ "@genesislcap/foundation-comms": "14.77.0",
34
+ "@genesislcap/foundation-utils": "14.77.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": "47be36812a2029840ec2691fcee14bb766e2e018"
49
+ "gitHead": "5902cd57f709923a2f8e85ccbdce1fe856bf216f"
50
50
  }