Investigation edits

This commit is contained in:
Dean 2022-08-01 15:23:41 +01:00
parent 5067e4682c
commit 776160df7f
6 changed files with 76 additions and 32 deletions

View File

@ -8,6 +8,7 @@
import Search from "./Search.svelte" import Search from "./Search.svelte"
import Icon from "../../Icon/Icon.svelte" import Icon from "../../Icon/Icon.svelte"
import StatusLight from "../../StatusLight/StatusLight.svelte" import StatusLight from "../../StatusLight/StatusLight.svelte"
import Badge from "../../Badge/Badge.svelte"
export let id = null export let id = null
export let disabled = false export let disabled = false
@ -19,6 +20,8 @@
export let placeholderOption = null export let placeholderOption = null
export let options = [] export let options = []
export let isOptionSelected = () => false export let isOptionSelected = () => false
export let isOptionEnabled = () => true
export let getBadgeLabel = () => ""
export let onSelectOption = () => {} export let onSelectOption = () => {}
export let getOptionLabel = option => option export let getOptionLabel = option => option
export let getOptionValue = option => option export let getOptionValue = option => option
@ -164,6 +167,7 @@
aria-selected="true" aria-selected="true"
tabindex="0" tabindex="0"
on:click={() => onSelectOption(getOptionValue(option, idx))} on:click={() => onSelectOption(getOptionValue(option, idx))}
class:is-disabled={!isOptionEnabled(option)}
> >
{#if getOptionIcon(option, idx)} {#if getOptionIcon(option, idx)}
<span class="option-extra"> <span class="option-extra">
@ -175,6 +179,11 @@
<StatusLight square color={getOptionColour(option, idx)} /> <StatusLight square color={getOptionColour(option, idx)} />
</span> </span>
{/if} {/if}
{#if getBadgeLabel(option)}
<span class="badge-pro">
<Badge grey quiet size="S">{getBadgeLabel(option)}</Badge>
</span>
{/if}
<span class="spectrum-Menu-itemLabel"> <span class="spectrum-Menu-itemLabel">
{getOptionLabel(option, idx)} {getOptionLabel(option, idx)}
</span> </span>
@ -194,6 +203,9 @@
</div> </div>
<style> <style>
.badge-pro {
padding-right: var(--spacing-s);
}
.spectrum-Popover { .spectrum-Popover {
max-height: 240px; max-height: 240px;
z-index: 999; z-index: 999;
@ -256,4 +268,7 @@
.spectrum-Popover :global(.spectrum-Search .spectrum-Textfield-icon) { .spectrum-Popover :global(.spectrum-Search .spectrum-Textfield-icon) {
top: 9px; top: 9px;
} }
.spectrum-Menu-item.is-disabled {
pointer-events: none;
}
</style> </style>

View File

@ -12,6 +12,8 @@
export let getOptionValue = option => option export let getOptionValue = option => option
export let getOptionIcon = () => null export let getOptionIcon = () => null
export let getOptionColour = () => null export let getOptionColour = () => null
export let isOptionEnabled
export let getBadgeLabel
export let readonly = false export let readonly = false
export let quiet = false export let quiet = false
export let autoWidth = false export let autoWidth = false
@ -66,6 +68,8 @@
{getOptionValue} {getOptionValue}
{getOptionIcon} {getOptionIcon}
{getOptionColour} {getOptionColour}
{isOptionEnabled}
{getBadgeLabel}
{autocomplete} {autocomplete}
{sort} {sort}
isPlaceholder={value == null || value === ""} isPlaceholder={value == null || value === ""}

View File

@ -15,6 +15,8 @@
export let getOptionValue = option => extractProperty(option, "value") export let getOptionValue = option => extractProperty(option, "value")
export let getOptionIcon = option => option?.icon export let getOptionIcon = option => option?.icon
export let getOptionColour = option => option?.colour export let getOptionColour = option => option?.colour
export let isOptionEnabled
export let getBadgeLabel
export let quiet = false export let quiet = false
export let autoWidth = false export let autoWidth = false
export let sort = false export let sort = false
@ -49,6 +51,8 @@
{getOptionValue} {getOptionValue}
{getOptionIcon} {getOptionIcon}
{getOptionColour} {getOptionColour}
{isOptionEnabled}
{getBadgeLabel}
on:change={onChange} on:change={onChange}
on:click on:click
/> />

View File

@ -106,12 +106,3 @@
{/if} {/if}
</ModalContent> </ModalContent>
</Modal> </Modal>
<style>
.icon-wrapper {
display: contents;
}
.icon-wrapper.highlight :global(svg) {
color: var(--spectrum-global-color-blue-600);
}
</style>

View File

@ -1,5 +1,5 @@
<script> <script>
import { Layout, Table, Select, Pagination, Link } from "@budibase/bbui" import { Layout, Table, Select, Pagination, Banner } from "@budibase/bbui"
import DateTimeRenderer from "components/common/renderers/DateTimeRenderer.svelte" import DateTimeRenderer from "components/common/renderers/DateTimeRenderer.svelte"
import StatusRenderer from "./StatusRenderer.svelte" import StatusRenderer from "./StatusRenderer.svelte"
import HistoryDetailsPanel from "./HistoryDetailsPanel.svelte" import HistoryDetailsPanel from "./HistoryDetailsPanel.svelte"
@ -14,8 +14,7 @@
STOPPED = "stopped" STOPPED = "stopped"
export let app export let app
$: licensePlan = $auth.user?.license?.plan let licensePlan = $auth.user?.license?.plan
$: console.log($auth.user?.license)
$: upgradeUrl = `${$admin.accountPortalUrl}/portal/upgrade` $: upgradeUrl = `${$admin.accountPortalUrl}/portal/upgrade`
let pageInfo = createPaginationStore() let pageInfo = createPaginationStore()
@ -38,19 +37,17 @@
{ value: "5-m", label: "Past 5 mins" }, { value: "5-m", label: "Past 5 mins" },
] ]
$: allowedTimeOptions = timeOptions.filter(option => { const allowedFilters = ["1-d", "1-h", "15-m", "5-m"]
option.value === "1-d" && licensePlan.type === "free"
})
$: console.log(allowedTimeOptions)
$: parsedOptions = timeOptions.reduce((acc, ele) => { let parsedOptions = timeOptions.filter(ele => {
if (ele.value !== "1-d" && licensePlan.type === "free") { return allowedFilters.indexOf(ele.value) >= 0
ele = { ...ele, disabled: true } })
}
acc.push(ele) if (parsedOptions.length && timeRange === null) {
return acc timeRange = parsedOptions[0].value
}, []) }
$: console.log(parsedOptions)
$: console.log("parsed options", parsedOptions)
const statusOptions = [ const statusOptions = [
{ value: SUCCESS, label: "Success" }, { value: SUCCESS, label: "Success" },
@ -138,14 +135,25 @@
</script> </script>
<div class="root" class:panelOpen={showPanel}> <div class="root" class:panelOpen={showPanel}>
<!-- {#if licensePlan?.type === "free"}
<Layout noPadding>
<div class="pro-banner">
<Banner
type="info"
showCloseButton={false}
extraButtonText={"Check it out!"}
extraButtonAction={() => {
window.open(upgradeUrl)
}}
>
24 hrs of logs currently available. Upgrade your budibase installation
to unlock additional features.
</Banner>
</div>
</Layout>
{/if} -->
<Layout noPadding gap="M" alignContent="start"> <Layout noPadding gap="M" alignContent="start">
<div class="search"> <div class="search">
{#if licensePlan.type === "free"}
<div>
Upgrade your budibase installation to unlock additional features.
<Link size="L" href={upgradeUrl}>Pro</Link>
</div>
{/if}
<div class="select"> <div class="select">
<Select <Select
placeholder="All automations" placeholder="All automations"
@ -156,10 +164,27 @@
</div> </div>
<div class="select"> <div class="select">
<Select <Select
placeholder={allowedTimeOptions[0]?.label} placeholder={parsedOptions[0]?.label}
label="Date range" label="Date range"
bind:value={timeRange} bind:value={timeRange}
options={parsedOptions} options={timeOptions}
isOptionEnabled={x => {
if (licensePlan?.type === "free") {
return allowedFilters.indexOf(x.value) >= 0
}
return true
}}
getBadgeLabel={x => {
console.log("Running label change", licensePlan)
if (
licensePlan?.type === "free" &&
allowedFilters.indexOf(x.value) < 0
) {
return "Pro"
} else {
return ""
}
}}
/> />
</div> </div>
<div class="select"> <div class="select">
@ -246,4 +271,8 @@
.panelOpen { .panelOpen {
grid-template-columns: auto 420px; grid-template-columns: auto 420px;
} }
.pro-banner {
margin-bottom: var(--spectrum-global-dimension-static-size-300);
}
</style> </style>

View File

@ -71,6 +71,7 @@
}) })
</script> </script>
{"is adming" + $auth.isAdmin}
{#if $auth.isAdmin} {#if $auth.isAdmin}
<Layout noPadding> <Layout noPadding>
<Layout gap="XS" noPadding> <Layout gap="XS" noPadding>