Difference between revisions of "GUI Basics"
| (44 intermediate revisions by 3 users not shown) | |||
| Line 86: | Line 86: | ||
| {| class="wikitable" | {| class="wikitable" | ||
| |- | |- | ||
| − | | Settings || Includes the option to change Panel ID, User Preferences ID, and Default Offset | + | | '''Settings''' || Includes the option to change Panel ID, User Preferences ID, and Default Offset | 
| |- | |- | ||
| − | | Style || Includes both styling and behavior options for the dividers | + | | '''Style''' || Includes both styling and behavior options for the dividers | 
| |- | |- | ||
| − | | Set Current Offset as Default || Sets the offset of the divider as the default. Reopening/rebuilding the layout will place the divider at this position | + | | '''Set Current Offset as Default''' || Sets the offset of the divider as the default. Reopening/rebuilding the layout will place the divider at this position | 
| |- | |- | ||
| − | | Clear Default Offset || Clears the divider position set | + | | '''Clear Default Offset''' || Clears the divider position set | 
| |- | |- | ||
| − | | Flip Panels || Flips the position of the panels | + | | '''Flip Panels''' || Flips the position of the panels | 
| |- | |- | ||
| − | | Rotate Panels Clockwise || Rotates the selected panels in a clockwise direction | + | | '''Rotate Panels Clockwise''' || Rotates the selected panels in a clockwise direction | 
| |- | |- | ||
| − | | Rotate Panels Counterclockwise || Rotates the selected panels in a counterclockwise direction | + | | '''Rotate Panels Counterclockwise''' || Rotates the selected panels in a counterclockwise direction | 
| |- | |- | ||
| − | | Change to 2 Tabs || Removes the divider and places each of the panels in a tab | + | | '''Change to 2 Tabs''' || Removes the divider and places each of the panels in a tab | 
| |- | |- | ||
| − | | Distribute Dividers || Evenly distributes the dividers | + | | '''Distribute Dividers''' || Evenly distributes the dividers | 
| |- | |- | ||
| − | | Replace With... || Replaces the panels with a different visualization or blank panel | + | | '''Replace With...''' || Replaces the panels with a different visualization or blank panel | 
| |- | |- | ||
| − | | Add Panel || Add a blank panel left, right, above, or below | + | | '''Add Panel''' || Add a blank panel left, right, above, or below | 
| |- | |- | ||
| − | | Place Highlighted in Scroll Panel || Places the selected panels in a scroll panel | + | | '''Place Highlighted in Scroll Panel''' || Places the selected panels in a scroll panel | 
| |- | |- | ||
| − | | Place Highlighted in Tab || Places the panels in tabs | + | | '''Place Highlighted in Tab''' || Places the panels in tabs | 
| |- | |- | ||
| − | | Place Highlighted in Window || Places the panels in a new window, leaving behind a blank panel in their place | + | | '''Place Highlighted in Window''' || Places the panels in a new window, leaving behind a blank panel in their place | 
| |- | |- | ||
| − | | Move to Different Layout File... || When working with multiple layouts - moves selected panels to a different layout | + | | '''Move to Different Layout File...''' || When working with multiple layouts - moves selected panels to a different layout | 
| |- | |- | ||
| − | | Cut Highlighted Panels || Cut the panels for pasting to a different panel | + | | '''Cut Highlighted Panels''' || Cut the panels for pasting to a different panel | 
| |- | |- | ||
| − | | Copy Highlighted Panels || Copies the panels for pasting to a different panel | + | | '''Copy Highlighted Panels''' || Copies the panels for pasting to a different panel | 
| |- | |- | ||
| − | | Delete Highlighted Panels || Deletes the selected panels | + | | '''Delete Highlighted Panels''' || Deletes the selected panels | 
| |- | |- | ||
| − | | Hide Highlighted Panels || Hides the selected panels. To unhide, use the '''Unhide Panel''' option in the panel configuration menu | + | | '''Hide Highlighted Panels''' || Hides the selected panels. To unhide, use the '''Unhide Panel''' option in the panel configuration menu | 
| |- | |- | ||
| − | | Export Highlighted Panels || Export the highlighted panels, as text, for use in another dashboard | + | | '''Export Highlighted Panels''' || Export the highlighted panels, as text, for use in another dashboard | 
| |- | |- | ||
| − | | Paste || Paste the cut/copied panel(s) | + | | '''Paste''' || Paste the cut/copied panel(s) | 
| |} | |} | ||
| − | + | <span style="color: purple;">'''Example'''</span> | |
| '''Adding panels''' | '''Adding panels''' | ||
| Line 219: | Line 219: | ||
| Another way to add tabs is to use the '''tab dropdown menu'''. This menu is located on each tab and is opened by clicking on the downward pointing green triangle. This menu contains all of the ways of modifying tabs - renaming, deleting, adding, and moving. This menu allows the addition of tabs to either the left or the right of the selected tab. | Another way to add tabs is to use the '''tab dropdown menu'''. This menu is located on each tab and is opened by clicking on the downward pointing green triangle. This menu contains all of the ways of modifying tabs - renaming, deleting, adding, and moving. This menu allows the addition of tabs to either the left or the right of the selected tab. | ||
| + | |||
| + | '''Export to Spreadsheet''': downloads the tables within a tab as a spreadsheet. If you have multiple table panels, these panels will be shown as separate tabs in the spreadsheet. You can disable this option by using the tab configuration menu ('''Hide Export Spreadsheet Menu Item''') | ||
| <span style="color: blue;">'''Moving Tabs'''</span> | <span style="color: blue;">'''Moving Tabs'''</span> | ||
| Line 242: | Line 244: | ||
| If you would like a specific tab to be the primary tab that is seen when a layout is opened, use the '''Set as Default''' option from the tab dropdown menu. This tab will then be opened regardless of which tab is last opened when the layout is closed. | If you would like a specific tab to be the primary tab that is seen when a layout is opened, use the '''Set as Default''' option from the tab dropdown menu. This tab will then be opened regardless of which tab is last opened when the layout is closed. | ||
| − | ==Navigating  | + | ==Navigating== | 
| When making complex layouts, you may end up with so many tabs that it won't be able to fit on the list of tabs. When the number of tabs exceed the space, control arrows will appear at the rightmost edge. You can use these control arrows to scroll through the tabs. | When making complex layouts, you may end up with so many tabs that it won't be able to fit on the list of tabs. When the number of tabs exceed the space, control arrows will appear at the rightmost edge. You can use these control arrows to scroll through the tabs. | ||
| Line 250: | Line 252: | ||
| To quickly get to a tab, hover over the tabs and use the mouse scroll to scroll the tab space (much like scrolling down a webpage) and select the desired tab. | To quickly get to a tab, hover over the tabs and use the mouse scroll to scroll the tab space (much like scrolling down a webpage) and select the desired tab. | ||
| − | ==Undocking | + | ==Undocking & Popping Out== | 
| + | Tabs can be undocked (panels remain on the layout) or popped out (panels are opened in a new browser window). In order to allow undocking and popping out, the '''Allow Undocking''' option must be enabled (tab configuration menu > Style > General). The option to hide a tab when it is popped out can also be found in the same menu (tab is hidden in non-developer mode) | ||
| + | |||
| + | [[File:GUI.Tabs.17.jpg]] | ||
| + | |||
| + | [[File:GUI.Tabs.18.jpg|600px]] | ||
| + | |||
| + | Note: closing a popped out window does not delete it - it is returned to the tab (or undocked window if it was undocked prior to popping out) | ||
| ==Blinking Tabs== | ==Blinking Tabs== | ||
| + | When particular attention has to be drawn to a certain tab, blinking can be used. The option to choose a blinking color and period are found in the tab settings (double click on the tab or tab dropdown menu > Rename/Settings) | ||
| + | |||
| + | [[File:GUI.Tabs.19.jpg|400px]] | ||
| + | |||
| + | =Sessions= | ||
| + | Both the AmiWeb and AmiCenter have and manage sessions. Sessions are uniquely identified by a unique session identifier('''_SESSIONID''').<br> | ||
| + | |||
| + | ==AmiWebSession== | ||
| + | An AmiWebSession is created every time a user logs in to the frontend dashboard. The same user name can have multiple logins and a login can have multiple sessions. The below ERD(Entity Relation Diagram) is created to describe the relationship:<br> | ||
| + | [[File:ER1.png]] | ||
| + | |||
| + | (1). One username can have multiple logins:<br> | ||
| + | A user logins into a dashboard with two different browsers. We will see two login records,uniquely identified by '''''__LOGINID''''', under the same username:<br> | ||
| + | [[File:Username login.png|500px]] <br><br> | ||
| + | (2). One login can have multiple sessions: | ||
| + | By default each login can have one session. This can be changed by configuring the property: <span style="color:#3c78d8">''''' ami.web.default.MAXSESSIONS '''''</span><br> | ||
| + | After updating the max sessions, if we click <span style="color:#3c78d8">'''''  Account->Start New Session '''''</span> we could create a new session under the same login.<br> | ||
| + | [[File:OneUserNameMultiSessions.png]] | ||
| + | <br> | ||
| + | |||
| + | ==Headless sessions== | ||
| + | (1).Getting Started<br> | ||
| + | A headless session is a session that no single user claims ownership of. To create a headless session, edit your headless.txt in amione/data/ by adding a line as follows: | ||
| + | <span style="color:#3c78d8">''''' headless|headless123|2000x1000|ISDEV=true '''''</span> | ||
| + | , where the first argument is the headless session name and the third argument is the resolution of the screen on which the headless session will be displayed.<br><br> | ||
| + | |||
| + | Before any user claims the ownership of a headless session, the __LOGINID for the headless session will be null.<br> | ||
| + | [[File:NullLogin.png]] | ||
| + | <br> | ||
| + | |||
| + | (2).Claiming ownership<br> | ||
| + | |||
| + | A user can claim ownership of a headless session by going to <span style="color:#3c78d8">'''''Account->Take Ownership of Headless Session -> <headless session name>'''''</span><br> | ||
| + | [[File:Headless2.png]]<br><br> | ||
| + | After ownership is taken, this headless session will be tied to the current login.<br> | ||
| + | [[File:TieToUser.png]]<br> | ||
| + | |||
| + | (3).Releasing ownership<br> | ||
| + | Likewise, the user can release the ownership of the headless session by clicking  | ||
| + | <span style="color:#3c78d8">''''' Account->Release Ownership of Headless Session '''''</span>.<br> | ||
| + | [[File:ReleaseOwnership.png]] | ||
| + | |||
| + | ==AmiCenterSessions== | ||
| + | Just like the notion of AmiWebSession, Ami Center also has the notion of session. One can see what sessions currently exist in the center by typing <span style="color:#3c78d8">''''' SHOW SESSIONS '''''</span> in the DB console or frontend shell tool. <br> | ||
| + | |||
| + | [[File:ShowSessions.png]] | ||
| + | |||
| + | * AmiCenterSession Composition<br> | ||
| + | |||
| + | [[File:CenterSessionChart.png]]<br> | ||
| + | |||
| + | Typically, there are 4 different types of AmiCenterSession:<br> | ||
| + | (1)   __SYSTEM is like the master session, sitting on top of the session hierarchy. | ||
| + | |||
| + | (2)  __RTFEED is another session that manages all the real time feeds. | ||
| + | |||
| + | (3) __SCHEDULER sessions are sessions associated with timers. Each timer has one unique session associated with it. | ||
| + | |||
| + | (4) Your DB console terminal or frontend shell tool also has one session associated with it. | ||
| + | |||
| + | ==Managing sessions with f1 console commands== | ||
| + | Sessions can also be managed through the f1 console port. By default, <span style="color:#3c78d8">'''''f1.console.port=3285'''''</span><br>. | ||
| + | [[File:F1ConsolePort.png]] | ||
| + | |||
| + | |||
| + | Commands available: | ||
| + | {| class="wikitable" | ||
| + | !Commands | ||
| + | !Example Usage | ||
| + | !Description | ||
| + | |- | ||
| + | |amiWebServer.showLogins() | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.showLogins() | ||
| + |  +----------+--------------------------+---------------------+--------+ | ||
| + |  |__USERNAME|__LOGINID                 |__LOGINTIME(GMT)     |Sessions| | ||
| + |  +----------+--------------------------+---------------------+--------+ | ||
| + |  |demo      |QIYSASDnM8MW7c0MLH3FEK3jKk|20231108 03:22:45.830|1       | | ||
| + |  +----------+--------------------------+---------------------+--------+</syntaxhighlight> | ||
| + | |Show all logins | ||
| + | |- | ||
| + | |amiWebServer.showSessions() | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.showSessions()</syntaxhighlight> | ||
| + | [[File:F1consoleshowsessions.png|1000px]] | ||
| + | |||
| + | |Show all sessions | ||
| + | |- | ||
| + | |amiWebServer.killSession(<i>String sessionId</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.killSession("xbqfQ4mmKxODw8f0jz2c") | ||
| + |  killed</syntaxhighlight> | ||
| + | |Kill a user session | ||
| + | |- | ||
| + | |amiWebServer.createHeadlessSession(<i>String sessionName, String username, String resolution, String attributes</i>)      | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.createHeadlessSession("headless1","headlessdemo", "2000x1000","ISDEV=true") | ||
| + |  headless session created and enabled</syntaxhighlight> | ||
| + | |Creates a headless session, resolution is in format widthXheight, eg 1000x2000, attributes in a comma delimited list  | ||
| + | |- | ||
| + | |amiWebServer.deleteHeadlessSession(<i>String sessionName</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.deleteHeadlessSession("headless1") | ||
| + |  headless session deleted</syntaxhighlight> | ||
| + | |Delete a headless session | ||
| + | |- | ||
| + | |amiWebServer.describeHeadlessSession(<i>String sessionName</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.describeHeadlessSession("headless1") | ||
| + |  headless1|headlessdemo|2000x1000|ISDEV=true</syntaxhighlight> | ||
| + | |Print the headless session details as it is saved in headless.txt | ||
| + | |- | ||
| + | |amiWebServer.disableHeadlessSession(<i>String name</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.disableHeadlessSession("headless1") | ||
| + |  headless session disabled</syntaxhighlight> | ||
| + | |Disables a headless session | ||
| + | |- | ||
| + | |amiWebServer.enableHeadlessSession(<i>String sessionName</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.enableHeadlessSession("headless1") | ||
| + |  headless session enabled</syntaxhighlight> | ||
| + | |Enable a headless session | ||
| + | |- | ||
| + | |amiWebServer.killLogin(<i>String uid</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.killLogin("vBduBdZzUrjjmsONMhV8nkLiqh") | ||
| + |  killed user login</syntaxhighlight> | ||
| + | |Kill user login | ||
| + | |- | ||
| + | |amiWebServer.showPanels(<i>String sessionId</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.showPanels("xbqfQ4mmKxODw8f0jz2c") | ||
| + |  +--------------------+-------------+-------+-------+-----+------+---------+ | ||
| + |  |Structure           |Type         |PanelId|Visible|Width|Height|Transient| | ||
| + |  +--------------------+-------------+-------+-------+-----+------+---------+ | ||
| + |  |Desktop - 3forge AMI|Main Window  !null   |true   |1920 |911   !null     | | ||
| + |  | Inner Desktop      |Inner Desktop!null   |true   |1920 |883   !null     | | ||
| + |  +--------------------+-------------+-------+-------+-----+------+---------+</syntaxhighlight> | ||
| + | |Show all panels | ||
| + | |- | ||
| + | |amiWebServer.exec(<i>String sessionId, String script</i>) | ||
| + | |<syntaxhighlight lang="amiscript">amiWebServer.exec("2un2sl88hTcPuDoPhxk9","round(2.3)") | ||
| + | 2</syntaxhighlight> | ||
| + | |Execute amiscript | ||
| + | |} | ||
Latest revision as of 06:51, 8 November 2023
Windows
In AMI, windows are the building blocks of layouts. Windows are highly customizable and entire complex layouts can be built within one window. This section will discuss the various options you have when starting out with a window.
The Windows option can be found on the top menu bar. Developers have the option of creating and managing windows whereas end-users are still able to use the menu to view a list of windows that are in the layout.
Renaming Windows
Once created, Windows can be renamed by double clicking on the Window name or by using the Configure Window found in the middle of the Window header.
Popping out, Minimizing, Maximizing, and Deleting Windows
Using the buttons found on the right side of the window header, you can pop out a window (into its own window), minimize, maximize, or delete a window.
 :
pops out the window its own window. When you close a popped out window, it will return the window onto the dashboard (it will not be deleted). The status of the window will be shown as [popped out] in the Windows menu.
:
pops out the window its own window. When you close a popped out window, it will return the window onto the dashboard (it will not be deleted). The status of the window will be shown as [popped out] in the Windows menu.
 : minimizes the window. Minimized windows can be accessed by selecting them from the Windows menu.
: minimizes the window. Minimized windows can be accessed by selecting them from the Windows menu.
 : maximizes the window or restores a maximized window to its original size.
: maximizes the window or restores a maximized window to its original size.
 : deletes the window. Windows in use will require confirmation before being deleted.
: deletes the window. Windows in use will require confirmation before being deleted.
Note: in order to delete individual panels within windows, use the configuration button menu of the panel and select Delete Highlighted Panels. If the window does not have any panels, selecting this option will delete the window.
Resizing and Moving Windows
In order to resize a window, click and hold any part of the edges or corners of the window. While holding the mouse button, drag the cursor to resize the window
In order to move a window around the dashboard, click and hold the window header. While holding the mouse button, move the window to any area of the dashboard.
The Configure Window menu found in the window header contains a lot of options to be used for the windows. The options to be discussed in this section are Type and Location in Menu Bar.
Type
Maximized, no Header: maximizes the size of the window and removes the window header. The Configure Window button will still be visible when in developer mode.
Regular: the default state of windows with all window header buttons available.
Hidden: hides the name of the window from the Windows drop down menu when not in developer mode. When in developer mode, the name of the window will be visible with a [hidden] label. This is useful when creating windows that will be kept minimized or behind other windows and only available when taking a certain action.
You can also use the Manage Windows option in the Windows menu in order to get an overview of all of the windows in the layout and apply a configuration to each.
Location in Menu Bar
If you would like to place a window under its own menu item in the menu bar, use the Location in Menu Bar option to assign a Menu Name. The menu item will then appear when not in developer mode (and the window is not hidden):
The window will list appear in the Windows menu:
Dividers
As a layout is made of a window or multiple windows, a window is made of a panel or multiple panels. Dividers allow you to take a single window and subdivide it as you see fit to best visualize your information.
Adding Panels
There are two ways to create dividers/divide a window into panels:
The first way to divide a window is using the Split Vertically and Split Horizontally found in the panel configuration menu (also known as the Green Button).
The second way to divide a window is to actually create panels using the Add Panel option also found in the panel configuration menu.
Both options lead to the creation of dividers with their own set of options. Dividers, by default, can be dragged by the user to adjust the real-estate of the two panels they divide. In order to further modify the window, use the divider configuration button found on the divider itself. Opening the configuration menu will highlight the associated panels and numbers will be assigned to each panel.
| Settings | Includes the option to change Panel ID, User Preferences ID, and Default Offset | 
| Style | Includes both styling and behavior options for the dividers | 
| Set Current Offset as Default | Sets the offset of the divider as the default. Reopening/rebuilding the layout will place the divider at this position | 
| Clear Default Offset | Clears the divider position set | 
| Flip Panels | Flips the position of the panels | 
| Rotate Panels Clockwise | Rotates the selected panels in a clockwise direction | 
| Rotate Panels Counterclockwise | Rotates the selected panels in a counterclockwise direction | 
| Change to 2 Tabs | Removes the divider and places each of the panels in a tab | 
| Distribute Dividers | Evenly distributes the dividers | 
| Replace With... | Replaces the panels with a different visualization or blank panel | 
| Add Panel | Add a blank panel left, right, above, or below | 
| Place Highlighted in Scroll Panel | Places the selected panels in a scroll panel | 
| Place Highlighted in Tab | Places the panels in tabs | 
| Place Highlighted in Window | Places the panels in a new window, leaving behind a blank panel in their place | 
| Move to Different Layout File... | When working with multiple layouts - moves selected panels to a different layout | 
| Cut Highlighted Panels | Cut the panels for pasting to a different panel | 
| Copy Highlighted Panels | Copies the panels for pasting to a different panel | 
| Delete Highlighted Panels | Deletes the selected panels | 
| Hide Highlighted Panels | Hides the selected panels. To unhide, use the Unhide Panel option in the panel configuration menu | 
| Export Highlighted Panels | Export the highlighted panels, as text, for use in another dashboard | 
| Paste | Paste the cut/copied panel(s) | 
Example
Adding panels
Adding a panel above using the right panel configuration button adds a panel only above the right panel:
Adding a panel above using the divider configuration button adds a panel above both panels:
Modifying Dividers
The options to modify dividers are all found in the divider's Style setting.
Style
Adjusting Size and Color
Under the Style section of the Divider Style menu, you can adjust the thickness of the divider, the color of the divider, and the color of the divider when the mouse is hovering over it. Note: To make a divider invisible, change the thickness to 0(px).
Behavior
Locking Dividers
Dividers may be locked in order to prevent it from moving when not in developer mode. A small lock will appear over the divider configuration button
Alignment
The Align options keeps the size of the panels consistent when resizing the windows. For example, when set to the Ratio option, resizing a window consisting of two panels will keep their sizes relatively similar to their original sizes.
Snapping
When enabled, the Snap Setting allows you to collapse a divider by double clicking on it. Depending on the setting used, the panel to the left, right, top, or bottom will be collapsed.
Note: when a panel is snapped away, it is considered hidden. This will affect the behavior of the panel when it is a real-time table. The real-time table will have a On-Hidden Behavior setting.
Unsnap minimum(%): when set, the divider will return to at least that % position of the window. For example: if the unsnap minimum is set to 60%, and the the divider was dragged to 40%; snapping and then unsnapping the divider will return the divider to the 60% location
Tabs
Tabs can be used to organize and increase the real-estate of dashboards. Through the use of tabs, you may be able to break down a layout into multiple components or even build entire layouts in a single tab. The creation of tabs differs depending on which panel or divider configuration button is used.
Creating Tabs
In order to place a single panel into a tab, click on the configuration button of the panel and select Place Highlighted in Tab
If the window consists of 2 or more panels, they can be separated into 2 tabs or can be placed into one tab.
To place the panels into 2 separate tabs, select Change to 2 Tabs from the divider configuration menu
Note: even if a panel is subdivided into multiple panels (such as the panel labeled 2below), it will still place the panel into one tab; it will not become 3 tabs.
To place multiple panels or the entire window into a single tab, choose the divider configuration button which highlights the desired panels and select Place Highlighted in Tab from the menu.
Adding, Editing, Moving, and Deleting Tabs
Adding New Tabs
To add additional tabs, click on the tab configuration button and select Add Tab. You can also enable the Show Add Button option in the Style menu.
Tab dropdown menu
Another way to add tabs is to use the tab dropdown menu. This menu is located on each tab and is opened by clicking on the downward pointing green triangle. This menu contains all of the ways of modifying tabs - renaming, deleting, adding, and moving. This menu allows the addition of tabs to either the left or the right of the selected tab.
Export to Spreadsheet: downloads the tables within a tab as a spreadsheet. If you have multiple table panels, these panels will be shown as separate tabs in the spreadsheet. You can disable this option by using the tab configuration menu (Hide Export Spreadsheet Menu Item)
Moving Tabs
If you have to move the tabs around, use the tab dropdown menu of the tab you would like to move and use one of the four options (move left, right, leftmost, or rightmost) until you get the tab to where you would like it to be
Renaming Tabs
In addition to the tab dropdown menu, the tab settings menu can be brought up by double clicking on a tab. This menu also includes the options to select colors for the tabs
Deleting Tabs
Tabs can also be deleted by deleting all of the panels within a tab. If there are multiple panels, select the divider that will highlight all of the panels.
When you are left with a single tab, you can also use the Remove Tab, Keep Panel open in the tab configuration menu in order to revert the panel to a regular window
Setting Default Tabs
If you would like a specific tab to be the primary tab that is seen when a layout is opened, use the Set as Default option from the tab dropdown menu. This tab will then be opened regardless of which tab is last opened when the layout is closed.
When making complex layouts, you may end up with so many tabs that it won't be able to fit on the list of tabs. When the number of tabs exceed the space, control arrows will appear at the rightmost edge. You can use these control arrows to scroll through the tabs.
To quickly get to a tab, hover over the tabs and use the mouse scroll to scroll the tab space (much like scrolling down a webpage) and select the desired tab.
Undocking & Popping Out
Tabs can be undocked (panels remain on the layout) or popped out (panels are opened in a new browser window). In order to allow undocking and popping out, the Allow Undocking option must be enabled (tab configuration menu > Style > General). The option to hide a tab when it is popped out can also be found in the same menu (tab is hidden in non-developer mode)
Note: closing a popped out window does not delete it - it is returned to the tab (or undocked window if it was undocked prior to popping out)
Blinking Tabs
When particular attention has to be drawn to a certain tab, blinking can be used. The option to choose a blinking color and period are found in the tab settings (double click on the tab or tab dropdown menu > Rename/Settings)
Sessions
Both the AmiWeb and AmiCenter have and manage sessions. Sessions are uniquely identified by a unique session identifier(_SESSIONID).
AmiWebSession
An AmiWebSession is created every time a user logs in to the frontend dashboard. The same user name can have multiple logins and a login can have multiple sessions. The below ERD(Entity Relation Diagram) is created to describe the relationship:
 
(1). One username can have multiple logins:
A user logins into a dashboard with two different browsers. We will see two login records,uniquely identified by __LOGINID, under the same username:
 
 
(2). One login can have multiple sessions:
By default each login can have one session. This can be changed by configuring the property:  ami.web.default.MAXSESSIONS 
After updating the max sessions, if we click   Account->Start New Session  we could create a new session under the same login.
 
Headless sessions
(1).Getting Started
A headless session is a session that no single user claims ownership of. To create a headless session, edit your headless.txt in amione/data/ by adding a line as follows:
 headless|headless123|2000x1000|ISDEV=true 
, where the first argument is the headless session name and the third argument is the resolution of the screen on which the headless session will be displayed.
Before any user claims the ownership of a headless session, the __LOGINID for the headless session will be null.
 
(2).Claiming ownership
A user can claim ownership of a headless session by going to Account->Take Ownership of Headless Session -> <headless session name>

After ownership is taken, this headless session will be tied to the current login.

(3).Releasing ownership
Likewise, the user can release the ownership of the headless session by clicking 
 Account->Release Ownership of Headless Session .
 
AmiCenterSessions
Just like the notion of AmiWebSession, Ami Center also has the notion of session. One can see what sessions currently exist in the center by typing  SHOW SESSIONS  in the DB console or frontend shell tool. 
- AmiCenterSession Composition
Typically, there are 4 different types of AmiCenterSession:
(1)   __SYSTEM is like the master session, sitting on top of the session hierarchy.
(2) __RTFEED is another session that manages all the real time feeds.
(3) __SCHEDULER sessions are sessions associated with timers. Each timer has one unique session associated with it.
(4) Your DB console terminal or frontend shell tool also has one session associated with it.
Managing sessions with f1 console commands
Sessions can also be managed through the f1 console port. By default, f1.console.port=3285
.
 
Commands available:
| Commands | Example Usage | Description | 
|---|---|---|
| amiWebServer.showLogins() | amiWebServer.showLogins()
 +----------+--------------------------+---------------------+--------+
 |__USERNAME|__LOGINID                 |__LOGINTIME(GMT)     |Sessions|
 +----------+--------------------------+---------------------+--------+
 |demo      |QIYSASDnM8MW7c0MLH3FEK3jKk|20231108 03:22:45.830|1       |
 +----------+--------------------------+---------------------+--------+
 | Show all logins | 
| amiWebServer.showSessions() | amiWebServer.showSessions()
 | Show all sessions | 
| amiWebServer.killSession(String sessionId) | amiWebServer.killSession("xbqfQ4mmKxODw8f0jz2c")
 killed
 | Kill a user session | 
| amiWebServer.createHeadlessSession(String sessionName, String username, String resolution, String attributes) | amiWebServer.createHeadlessSession("headless1","headlessdemo", "2000x1000","ISDEV=true")
 headless session created and enabled
 | Creates a headless session, resolution is in format widthXheight, eg 1000x2000, attributes in a comma delimited list | 
| amiWebServer.deleteHeadlessSession(String sessionName) | amiWebServer.deleteHeadlessSession("headless1")
 headless session deleted
 | Delete a headless session | 
| amiWebServer.describeHeadlessSession(String sessionName) | amiWebServer.describeHeadlessSession("headless1")
 headless1|headlessdemo|2000x1000|ISDEV=true
 | Print the headless session details as it is saved in headless.txt | 
| amiWebServer.disableHeadlessSession(String name) | amiWebServer.disableHeadlessSession("headless1")
 headless session disabled
 | Disables a headless session | 
| amiWebServer.enableHeadlessSession(String sessionName) | amiWebServer.enableHeadlessSession("headless1")
 headless session enabled
 | Enable a headless session | 
| amiWebServer.killLogin(String uid) | amiWebServer.killLogin("vBduBdZzUrjjmsONMhV8nkLiqh")
 killed user login
 | Kill user login | 
| amiWebServer.showPanels(String sessionId) | amiWebServer.showPanels("xbqfQ4mmKxODw8f0jz2c")
 +--------------------+-------------+-------+-------+-----+------+---------+
 |Structure           |Type         |PanelId|Visible|Width|Height|Transient|
 +--------------------+-------------+-------+-------+-----+------+---------+
 |Desktop - 3forge AMI|Main Window  !null   |true   |1920 |911   !null     |
 | Inner Desktop      |Inner Desktop!null   |true   |1920 |883   !null     |
 +--------------------+-------------+-------+-------+-----+------+---------+
 | Show all panels | 
| amiWebServer.exec(String sessionId, String script) | amiWebServer.exec("2un2sl88hTcPuDoPhxk9","round(2.3)")
2
 | Execute amiscript | 




































