2022-04-22 17:03:47 +02:00
|
|
|
<script>
|
2023-11-21 15:51:01 +01:00
|
|
|
import { AbsTooltip, Icon, Body } from "@budibase/bbui"
|
2022-04-22 17:03:47 +02:00
|
|
|
|
|
|
|
export let title
|
2022-05-11 14:06:41 +02:00
|
|
|
export let icon
|
2023-11-21 15:51:01 +01:00
|
|
|
export let iconTooltip
|
2022-04-26 09:23:53 +02:00
|
|
|
export let showAddButton = false
|
|
|
|
export let showBackButton = false
|
2022-07-25 11:20:59 +02:00
|
|
|
export let showCloseButton = false
|
2022-04-22 17:03:47 +02:00
|
|
|
export let onClickAddButton
|
2022-04-26 09:23:53 +02:00
|
|
|
export let onClickBackButton
|
2022-07-25 11:20:59 +02:00
|
|
|
export let onClickCloseButton
|
2022-05-11 14:06:41 +02:00
|
|
|
export let borderLeft = false
|
|
|
|
export let borderRight = false
|
2023-03-08 20:22:19 +01:00
|
|
|
export let wide = false
|
2023-09-26 13:27:27 +02:00
|
|
|
export let extraWide = false
|
|
|
|
export let closeButtonIcon = "Close"
|
2022-04-27 09:06:09 +02:00
|
|
|
|
2023-03-08 15:40:13 +01:00
|
|
|
$: customHeaderContent = $$slots["panel-header-content"]
|
2023-10-20 10:44:42 +02:00
|
|
|
$: customTitleContent = $$slots["panel-title-content"]
|
2022-04-22 17:03:47 +02:00
|
|
|
</script>
|
|
|
|
|
2023-09-26 13:27:27 +02:00
|
|
|
<div
|
|
|
|
class="panel"
|
|
|
|
class:wide
|
|
|
|
class:extraWide
|
|
|
|
class:borderLeft
|
|
|
|
class:borderRight
|
|
|
|
>
|
2023-03-08 15:40:13 +01:00
|
|
|
<div class="header" class:custom={customHeaderContent}>
|
2022-04-26 09:23:53 +02:00
|
|
|
{#if showBackButton}
|
|
|
|
<Icon name="ArrowLeft" hoverable on:click={onClickBackButton} />
|
|
|
|
{/if}
|
2022-05-11 14:06:41 +02:00
|
|
|
{#if icon}
|
2023-11-21 15:51:01 +01:00
|
|
|
<AbsTooltip type="info" text={iconTooltip}>
|
|
|
|
<Icon name={icon} />
|
|
|
|
</AbsTooltip>
|
2022-05-11 14:06:41 +02:00
|
|
|
{/if}
|
2022-04-22 17:03:47 +02:00
|
|
|
<div class="title">
|
2023-10-20 10:44:42 +02:00
|
|
|
{#if customTitleContent}
|
|
|
|
<slot name="panel-title-content" />
|
|
|
|
{:else}
|
|
|
|
<Body size="S">{title || ""}</Body>
|
|
|
|
{/if}
|
2022-04-22 17:03:47 +02:00
|
|
|
</div>
|
|
|
|
{#if showAddButton}
|
2022-04-25 15:37:14 +02:00
|
|
|
<div class="add-button" on:click={onClickAddButton}>
|
|
|
|
<Icon name="Add" />
|
2022-04-22 17:03:47 +02:00
|
|
|
</div>
|
|
|
|
{/if}
|
2022-07-25 11:20:59 +02:00
|
|
|
{#if showCloseButton}
|
2023-09-26 13:27:27 +02:00
|
|
|
<Icon name={closeButtonIcon} hoverable on:click={onClickCloseButton} />
|
2022-07-25 11:20:59 +02:00
|
|
|
{/if}
|
2022-04-22 17:03:47 +02:00
|
|
|
</div>
|
2023-03-08 15:40:13 +01:00
|
|
|
|
|
|
|
{#if customHeaderContent}
|
|
|
|
<span class="custom-content-wrap">
|
|
|
|
<slot name="panel-header-content" />
|
|
|
|
</span>
|
|
|
|
{/if}
|
|
|
|
|
2022-04-26 14:44:21 +02:00
|
|
|
<div class="body">
|
|
|
|
<slot />
|
|
|
|
</div>
|
2022-04-22 17:03:47 +02:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<style>
|
2022-05-11 14:09:21 +02:00
|
|
|
.panel {
|
2022-07-01 13:47:30 +02:00
|
|
|
width: 260px;
|
2022-12-17 15:13:06 +01:00
|
|
|
flex: 0 0 260px;
|
2022-04-22 17:03:47 +02:00
|
|
|
background: var(--background);
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
justify-content: flex-start;
|
|
|
|
align-items: stretch;
|
2022-04-27 09:06:09 +02:00
|
|
|
transition: width 130ms ease-out;
|
2023-05-18 13:48:57 +02:00
|
|
|
overflow: hidden;
|
2022-04-26 09:23:53 +02:00
|
|
|
}
|
2022-05-11 14:09:21 +02:00
|
|
|
.panel.borderLeft {
|
2022-05-11 14:06:41 +02:00
|
|
|
border-left: var(--border-light);
|
|
|
|
}
|
2022-05-11 14:09:21 +02:00
|
|
|
.panel.borderRight {
|
2022-05-11 14:06:41 +02:00
|
|
|
border-right: var(--border-light);
|
|
|
|
}
|
2022-05-11 14:09:21 +02:00
|
|
|
.panel.wide {
|
2023-03-08 20:22:19 +01:00
|
|
|
width: 310px;
|
|
|
|
flex: 0 0 310px;
|
2022-04-22 17:03:47 +02:00
|
|
|
}
|
2023-09-26 13:27:27 +02:00
|
|
|
.panel.extraWide {
|
|
|
|
width: 450px;
|
|
|
|
flex: 0 0 450px;
|
|
|
|
}
|
2022-04-22 17:03:47 +02:00
|
|
|
.header {
|
2022-04-26 09:23:53 +02:00
|
|
|
flex: 0 0 48px;
|
2022-04-22 17:03:47 +02:00
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
justify-content: space-between;
|
|
|
|
align-items: center;
|
2022-04-25 20:33:43 +02:00
|
|
|
padding: 0 var(--spacing-l);
|
2022-04-22 17:03:47 +02:00
|
|
|
border-bottom: var(--border-light);
|
2023-08-22 17:29:40 +02:00
|
|
|
gap: var(--spacing-m);
|
2022-04-22 17:03:47 +02:00
|
|
|
}
|
|
|
|
.title {
|
|
|
|
flex: 1 1 auto;
|
|
|
|
width: 0;
|
|
|
|
}
|
2023-08-22 17:29:40 +02:00
|
|
|
.title :global(p) {
|
2022-04-22 17:03:47 +02:00
|
|
|
overflow: hidden;
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
white-space: nowrap;
|
|
|
|
}
|
|
|
|
.add-button {
|
2022-04-25 20:59:30 +02:00
|
|
|
flex: 0 0 30px;
|
|
|
|
height: 30px;
|
2022-04-22 17:03:47 +02:00
|
|
|
display: grid;
|
|
|
|
place-items: center;
|
|
|
|
border-radius: 4px;
|
|
|
|
position: relative;
|
|
|
|
cursor: pointer;
|
|
|
|
background: var(--spectrum-semantic-cta-color-background-default);
|
|
|
|
transition: background var(--spectrum-global-animation-duration-100, 130ms)
|
|
|
|
ease-out;
|
|
|
|
}
|
|
|
|
.add-button:hover {
|
|
|
|
background: var(--spectrum-semantic-cta-color-background-hover);
|
|
|
|
}
|
|
|
|
.add-button :global(svg) {
|
|
|
|
fill: white;
|
|
|
|
}
|
2022-04-26 14:44:21 +02:00
|
|
|
.body {
|
|
|
|
flex: 1 1 auto;
|
|
|
|
overflow: auto;
|
|
|
|
overflow-x: hidden;
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
justify-content: flex-start;
|
|
|
|
align-items: stretch;
|
|
|
|
}
|
2023-03-08 15:40:13 +01:00
|
|
|
.header.custom {
|
|
|
|
border: none;
|
|
|
|
}
|
|
|
|
.custom-content-wrap {
|
|
|
|
border-bottom: var(--border-light);
|
|
|
|
}
|
2023-10-20 10:44:42 +02:00
|
|
|
.title {
|
|
|
|
display: flex;
|
|
|
|
}
|
2022-04-22 17:03:47 +02:00
|
|
|
</style>
|