From d157165e346f624bb3e145805828f57ce5e475f6 Mon Sep 17 00:00:00 2001 From: Conor_Mack Date: Mon, 30 Mar 2020 11:20:55 +0100 Subject: [PATCH 1/2] Updating material components to reference bb apis properly --- .../src/Button/Button.svelte | 3 +- .../src/Card/CardBody.svelte | 4 +- .../src/Checkbox/Checkbox.svelte | 13 ++-- .../src/Checkbox/CheckboxGroup.svelte | 9 ++- .../src/Common/ItemStore.js | 4 +- .../src/DatePicker/DatePicker.svelte | 37 ++++++---- .../src/IconButton/IconButton.svelte | 2 +- .../src/List/List.svelte | 9 ++- .../src/Menu/Menu.svelte | 9 ++- .../src/Radiobutton/Radiobutton.svelte | 4 +- .../src/Radiobutton/RadiobuttonGroup.svelte | 11 ++- .../src/Select/Select.svelte | 19 +++-- .../src/Slider/Slider.svelte | 70 +++---------------- .../src/Switch/Switch.svelte | 5 +- .../src/Test/TestApp.svelte | 12 +--- .../src/Test/props.js | 2 +- .../src/Textfield/Textfield.svelte | 10 +-- 17 files changed, 101 insertions(+), 122 deletions(-) diff --git a/packages/materialdesign-components/src/Button/Button.svelte b/packages/materialdesign-components/src/Button/Button.svelte index 7b7880e2ff..6142352280 100644 --- a/packages/materialdesign-components/src/Button/Button.svelte +++ b/packages/materialdesign-components/src/Button/Button.svelte @@ -6,6 +6,7 @@ const cb = new ClassBuilder("button", ["primary", "medium", "text"]) + export let _bb export let onClick export let variant = "text" @@ -20,8 +21,6 @@ export let text = "" export let disabled = false - export let _bb - onMount(() => { let ctx = _bb.getContext("BBMD:button:context") extras = [ctx] diff --git a/packages/materialdesign-components/src/Card/CardBody.svelte b/packages/materialdesign-components/src/Card/CardBody.svelte index 08cb549e06..6be83a319e 100644 --- a/packages/materialdesign-components/src/Card/CardBody.svelte +++ b/packages/materialdesign-components/src/Card/CardBody.svelte @@ -2,9 +2,11 @@ export let _bb export let onClick = () => {} + export let clicked = () => _bb.call(onClick) + let cardBody $: cardBody && _bb.attachChildren(cardBody) -
+
diff --git a/packages/materialdesign-components/src/Checkbox/Checkbox.svelte b/packages/materialdesign-components/src/Checkbox/Checkbox.svelte index ba9cfcf40c..05c057889c 100644 --- a/packages/materialdesign-components/src/Checkbox/Checkbox.svelte +++ b/packages/materialdesign-components/src/Checkbox/Checkbox.svelte @@ -6,7 +6,7 @@ import { MDCCheckbox } from "@material/checkbox" import { generate } from "shortid" - export let onClick = item => {} + export let onChange = item => {} export let _bb @@ -59,13 +59,15 @@ function changed(e) { const val = e.target.checked checked = val + handleOnClick() if (_bb.isBound(_bb.props.checked)) { _bb.setStateFromBinding(_bb.props.checked, val) } } function handleOnClick() { - let item = { _id, label, value } + let item = { _id, checked, label, value } + if (context === "checkboxgroup") { let idx = selectedItems.getItemIdx($selectedItems, _id) if (idx > -1) { @@ -73,9 +75,8 @@ } else { selectedItems.addItem(item) } - } else { - onClick(item) } + _bb.call(onChange, item) } $: isChecked = @@ -101,7 +102,6 @@ {id} disabled={isDisabled} {isChecked} - on:click={handleOnClick} on:change={changed} />
@@ -123,8 +123,7 @@ {id} disabled={isDisabled} {isChecked} - on:change={changed} - on:click={handleOnClick} /> + on:change={changed} />
{ _bb.setContext("BBMD:input:context", "checkboxgroup") - selectedItemsStore = createItemsStore(() => onChange($selectedItemsStore)) + selectedItemsStore = createItemsStore(() => { + value = $selectedItemsStore + if (_bb.isBound(_bb.props.value)) { + _bb.setStateFromBinding(_bb.props.value, value) + } + _bb.call(onChange, value) + }, value) _bb.setContext("BBMD:checkbox:selectedItemsStore", selectedItemsStore) _bb.setContext("BBMD:checkbox:props", { alignEnd, disabled }) }) diff --git a/packages/materialdesign-components/src/Common/ItemStore.js b/packages/materialdesign-components/src/Common/ItemStore.js index ed553cd847..18904116e6 100644 --- a/packages/materialdesign-components/src/Common/ItemStore.js +++ b/packages/materialdesign-components/src/Common/ItemStore.js @@ -1,7 +1,7 @@ import { writable } from "svelte/store" -function createItemsStore(componentOnSelect) { - const { subscribe, set, update } = writable([]) +function createItemsStore(componentOnSelect, initialState = []) { + const { subscribe, set, update } = writable(initialState) function addItem(item) { update(items => { diff --git a/packages/materialdesign-components/src/DatePicker/DatePicker.svelte b/packages/materialdesign-components/src/DatePicker/DatePicker.svelte index 1dc3defd1b..bfc250ede6 100644 --- a/packages/materialdesign-components/src/DatePicker/DatePicker.svelte +++ b/packages/materialdesign-components/src/DatePicker/DatePicker.svelte @@ -38,11 +38,31 @@ } }) + function handleSelect(date) { + if (_bb.isBound(_bb.props.date)) { + _bb.setStateFromBinding(_bb.props.date, date) + } + _bb.call(onSelect, date) + } + function selectDate(dayOfMonth) { let month = getMonth(navDate) let year = getYear(navDate) date = new Date(year, month, dayOfMonth) - onSelect(date) + handleSelect(date) + } + + function dateFieldChange(value) { + const isDate = /^\d{1,2}\/\d{1,2}\/\d{4}$/ + if (isDate.test(value)) { + const [year, month, day] = value.split("/").reverse() + if (month > 0 && month <= 12 && (day > 0 && day <= 31)) { + date = new Date(year, month - 1, day) + navDate = date + openCalendar(true) + handleSelect(date) + } + } } function addMonth() { @@ -57,19 +77,6 @@ instance.open = isOpen === undefined ? !instance.open : isOpen } - function textFieldChange(value) { - const isDate = /^\d{1,2}\/\d{1,2}\/\d{4}$/ - if (isDate.test(value)) { - const [year, month, day] = value.split("/").reverse() - if (month > 0 && month <= 12 && (day > 0 && day <= 31)) { - date = new Date(year, month - 1, day) - navDate = date - openCalendar(true) - onSelect(date) - } - } - } - $: dateMonthEnds = endOfMonth(navDate).getDate() $: dateMonthBegins = startOfMonth(navDate).getDay() $: dayStart = dateMonthBegins + 1 //1 = sunday @@ -92,7 +99,7 @@
{ let ctx = getContext("BBMD:list:context") - selectedItemsStore = createItemsStore(() => onSelect($selectedItemsStore)) + selectedItemsStore = createItemsStore(() => { + value = $selectedItemsStore + if (_bb.isBound(_bb.props.value)) { + _bb.setStateFromBinding(_bb.props.value, value) + } + _bb.call(onSelect, value) + }, value) _bb.setContext("BBMD:list:selectItemStore", selectedItemsStore) _bb.setContext("BBMD:list:props", { diff --git a/packages/materialdesign-components/src/Menu/Menu.svelte b/packages/materialdesign-components/src/Menu/Menu.svelte index 8439128208..ba63b32ebf 100644 --- a/packages/materialdesign-components/src/Menu/Menu.svelte +++ b/packages/materialdesign-components/src/Menu/Menu.svelte @@ -24,7 +24,14 @@ _bb.setContext("BBMD:list:context", "menu") _bb.setContext("BBMD:list:props", { singleSelection: true }) - selectedItemsStore = createItemsStore(() => onSelect($selectedItemsStore)) + selectedItemsStore = createItemsStore(() => { + let value = + $selectedItemsStore && $selectedItemsStore.length > 0 + ? $selectedItemsStore[0] + : "" + + _bb.call(onSelect, value) + }) _bb.setContext("BBMD:list:selectItemStore", selectedItemsStore) if (!!menu) { diff --git a/packages/materialdesign-components/src/Radiobutton/Radiobutton.svelte b/packages/materialdesign-components/src/Radiobutton/Radiobutton.svelte index 65f54d95e7..64ea7b980e 100644 --- a/packages/materialdesign-components/src/Radiobutton/Radiobutton.svelte +++ b/packages/materialdesign-components/src/Radiobutton/Radiobutton.svelte @@ -46,7 +46,7 @@ if (context === "radiobuttongroup") { selectedItems.addSingleItem(item) } else { - onClick(item) + _bb.call(onClick, item) } } @@ -106,7 +106,7 @@ {name} {checked} disabled={isDisabled} - on:click={onClick} /> + on:click={handleOnClick} />
diff --git a/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte b/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte index ffe97ad6d8..b5fd333bc7 100644 --- a/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte +++ b/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte @@ -13,6 +13,9 @@ export let fullwidth = false export let alignEnd = false export let disabled = false + export let value = [] + + $: safeValue = Array.isArray(value) ? value : [value] let selectedItemsStore let selected = null @@ -20,7 +23,13 @@ onMount(() => { _bb.setContext("BBMD:input:context", "radiobuttongroup") - selectedItemsStore = createItemStore(() => onChange($selectedItemsStore)) + selectedItemsStore = createItemStore(() => { + value = $selectedItemsStore + if (_bb.isBound(_bb.props.value)) { + _bb.setStateFromBinding(_bb.props.value, value) + } + _bb.call(onChange, value) + }, safeValue) _bb.setContext("BBMD:radiobutton:props", { name, disabled, alignEnd }) _bb.setContext("BBMD:radiobutton:selectedItemsStore", selectedItemsStore) }) diff --git a/packages/materialdesign-components/src/Select/Select.svelte b/packages/materialdesign-components/src/Select/Select.svelte index c9b4a3bd91..d9aed189a8 100644 --- a/packages/materialdesign-components/src/Select/Select.svelte +++ b/packages/materialdesign-components/src/Select/Select.svelte @@ -30,21 +30,22 @@ export let persistent = false export let value = "" + $: safeValue = Array.isArray(value) ? value : [value] + onMount(() => { _bb.setContext("BBMD:list:props", { singleSelection: true }) - _bb.setContext("BBMD:list:addItem", i => listItems = [...listItems, i]) + _bb.setContext("BBMD:list:addItem", i => (listItems = [...listItems, i])) selectedItemsStore = createItemsStore(() => { - - const v = $selectedItemsStore && $selectedItemsStore.length > 0 - ? $selectedItemsStore[0].value - : ""; + const v = + $selectedItemsStore && $selectedItemsStore.length > 0 + ? $selectedItemsStore[0].value + : "" value = v _bb.setStateFromBinding(_bb.props.value, v) _bb.call(onSelect, v) - - }) + }, safeValue) _bb.setContext("BBMD:list:selectItemStore", selectedItemsStore) _helperId = generate() @@ -58,10 +59,8 @@ } }) - $: useNotchedOutline = variant === "outlined" $: selectList && _bb.attachChildren(selectList) - $: modifiers = { variant, disabled, required, noLabel: !label } $: props = { modifiers } @@ -69,8 +68,6 @@ $: if (value !== undefined && instance && listItems.length > 0) { instance.selectedIndex = listItems.findIndex(i => i.value === value) } - -
diff --git a/packages/materialdesign-components/src/Slider/Slider.svelte b/packages/materialdesign-components/src/Slider/Slider.svelte index 02193510dd..3d41f9024b 100644 --- a/packages/materialdesign-components/src/Slider/Slider.svelte +++ b/packages/materialdesign-components/src/Slider/Slider.svelte @@ -8,6 +8,7 @@ let slider let instance + export let _bb export let variant = "continuous" //or discrete export let showTicks = false export let min = 0 @@ -17,6 +18,14 @@ export let label = "" export let disabled = false + function handleChange(val) { + value = val + if (_bb.isBound(_bb.props.value)) { + _bb.setStateFromBinding(_bb.props.value, value) + } + _bb.call(onChange, val) + } + onMount(() => { let s = MDCSlider.attachTo(slider) return () => instance.destroy() @@ -28,16 +37,12 @@ } } - $: instance && console.log("instance dot value: ", instance.value) - $: isDiscrete = variant === "discrete" $: displayMarkers = isDiscrete && showTicks $: modifiers = { variant, displayMarkers } $: props = { modifiers } $: sliderCls = cb.build({ props }) - - $: console.log("VALUE", value)
console.log('SLIDER VAL', e.detail.value)}> + on:MDCSlider:input={e => handleChange(e.detail.value)} + on:MDCSlider:change={e => handleChange(e.detail.value)}>
@@ -63,57 +69,3 @@
- - - - diff --git a/packages/materialdesign-components/src/Switch/Switch.svelte b/packages/materialdesign-components/src/Switch/Switch.svelte index c98d384859..34d6c14a0b 100644 --- a/packages/materialdesign-components/src/Switch/Switch.svelte +++ b/packages/materialdesign-components/src/Switch/Switch.svelte @@ -15,7 +15,10 @@ function handleChange() { checked = !checked - onChange(checked) + if (_bb.isBound(_bb.props.checked)) { + _bb.setStateFromBinding(_bb.props.checked, checked) + } + _bb.call(onChange, checked) } $: modifiers = { disabled, checked } diff --git a/packages/materialdesign-components/src/Test/TestApp.svelte b/packages/materialdesign-components/src/Test/TestApp.svelte index d839988147..01aeb8b18a 100644 --- a/packages/materialdesign-components/src/Test/TestApp.svelte +++ b/packages/materialdesign-components/src/Test/TestApp.svelte @@ -33,17 +33,7 @@ const page = { props: { _component: "testcomponents/rootComponent", - _children: [ - BodyBoundToStore, - Textfield, - Select, - Radiobutton, - Radiobuttongroup, - DatePicker, - IconButton, - Switch, - Slider, - ], + _children: [Checkbox], }, } _appPromise.then(initialise => { diff --git a/packages/materialdesign-components/src/Test/props.js b/packages/materialdesign-components/src/Test/props.js index 75244cf0c8..1980a2c10f 100644 --- a/packages/materialdesign-components/src/Test/props.js +++ b/packages/materialdesign-components/src/Test/props.js @@ -79,7 +79,7 @@ export const props = { id: "test-check", alignEnd: true, label: "Check Yo Self", - onClick: () => alert`Before ya reck yo'self`, + onChange: item => console.log(item), }, Checkboxgroup: { _component: "@budibase/materialdesign-components/Checkboxgroup", diff --git a/packages/materialdesign-components/src/Textfield/Textfield.svelte b/packages/materialdesign-components/src/Textfield/Textfield.svelte index 36c4618df3..dff9ac6413 100644 --- a/packages/materialdesign-components/src/Textfield/Textfield.svelte +++ b/packages/materialdesign-components/src/Textfield/Textfield.svelte @@ -18,6 +18,7 @@ let tfInstance = null onMount(() => { + debugger if (!!tf) tfInstance = new MDCTextField(tf) return () => { !!tfInstance && tf.tfInstance && tf.tfInstance.destroy() @@ -97,11 +98,10 @@ function changed(e) { const val = e.target.value value = val - onChange(value) - // if (_bb.isBound(_bb.props.value)) { - // _bb.setStateFromBinding(_bb.props.value, val) - // } - // _bb.call(onChange, val) + if (_bb.isBound(_bb.props.value)) { + _bb.setStateFromBinding(_bb.props.value, val) + } + _bb.call(onChange, val) } From c09544923d91ad759e3d3b95a523b9419a93cb89 Mon Sep 17 00:00:00 2001 From: Conor_Mack Date: Mon, 30 Mar 2020 13:09:36 +0100 Subject: [PATCH 2/2] Tidyup --- .../src/Checkbox/Checkbox.svelte | 3 ++- .../src/Checkbox/CheckboxGroup.svelte | 1 + .../src/Radiobutton/RadiobuttonGroup.svelte | 2 +- .../src/Slider/Slider.svelte | 1 + .../src/Test/TestApp.svelte | 17 ++++++++++++++++- .../materialdesign-components/src/Test/props.js | 2 -- .../src/Textfield/Textfield.svelte | 1 - 7 files changed, 21 insertions(+), 6 deletions(-) diff --git a/packages/materialdesign-components/src/Checkbox/Checkbox.svelte b/packages/materialdesign-components/src/Checkbox/Checkbox.svelte index 05c057889c..9a6c6119fb 100644 --- a/packages/materialdesign-components/src/Checkbox/Checkbox.svelte +++ b/packages/materialdesign-components/src/Checkbox/Checkbox.svelte @@ -59,6 +59,7 @@ function changed(e) { const val = e.target.checked checked = val + handleOnClick() if (_bb.isBound(_bb.props.checked)) { _bb.setStateFromBinding(_bb.props.checked, val) @@ -67,7 +68,7 @@ function handleOnClick() { let item = { _id, checked, label, value } - + debugger if (context === "checkboxgroup") { let idx = selectedItems.getItemIdx($selectedItems, _id) if (idx > -1) { diff --git a/packages/materialdesign-components/src/Checkbox/CheckboxGroup.svelte b/packages/materialdesign-components/src/Checkbox/CheckboxGroup.svelte index 89449185f2..2070e903b8 100644 --- a/packages/materialdesign-components/src/Checkbox/CheckboxGroup.svelte +++ b/packages/materialdesign-components/src/Checkbox/CheckboxGroup.svelte @@ -24,6 +24,7 @@ if (_bb.isBound(_bb.props.value)) { _bb.setStateFromBinding(_bb.props.value, value) } + debugger _bb.call(onChange, value) }, value) _bb.setContext("BBMD:checkbox:selectedItemsStore", selectedItemsStore) diff --git a/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte b/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte index b5fd333bc7..631a63fe20 100644 --- a/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte +++ b/packages/materialdesign-components/src/Radiobutton/RadiobuttonGroup.svelte @@ -24,7 +24,7 @@ onMount(() => { _bb.setContext("BBMD:input:context", "radiobuttongroup") selectedItemsStore = createItemStore(() => { - value = $selectedItemsStore + value = $selectedItemsStore[0] if (_bb.isBound(_bb.props.value)) { _bb.setStateFromBinding(_bb.props.value, value) } diff --git a/packages/materialdesign-components/src/Slider/Slider.svelte b/packages/materialdesign-components/src/Slider/Slider.svelte index 3d41f9024b..e45cfda2b4 100644 --- a/packages/materialdesign-components/src/Slider/Slider.svelte +++ b/packages/materialdesign-components/src/Slider/Slider.svelte @@ -9,6 +9,7 @@ let instance export let _bb + export let onChange = value => {} export let variant = "continuous" //or discrete export let showTicks = false export let min = 0 diff --git a/packages/materialdesign-components/src/Test/TestApp.svelte b/packages/materialdesign-components/src/Test/TestApp.svelte index 01aeb8b18a..2012a81593 100644 --- a/packages/materialdesign-components/src/Test/TestApp.svelte +++ b/packages/materialdesign-components/src/Test/TestApp.svelte @@ -33,7 +33,22 @@ const page = { props: { _component: "testcomponents/rootComponent", - _children: [Checkbox], + _children: [ + Textfield, + Checkboxgroup, + Radiobutton, + Radiobuttongroup, + Datatable, + CustomersIndexTable, + Icon, + List, + Select, + DatePicker, + IconButton, + Card, + Switch, + Slider, + ], }, } _appPromise.then(initialise => { diff --git a/packages/materialdesign-components/src/Test/props.js b/packages/materialdesign-components/src/Test/props.js index 1980a2c10f..b09f5e528b 100644 --- a/packages/materialdesign-components/src/Test/props.js +++ b/packages/materialdesign-components/src/Test/props.js @@ -84,7 +84,6 @@ export const props = { Checkboxgroup: { _component: "@budibase/materialdesign-components/Checkboxgroup", label: "Whats your favourite?", - disabled: true, alignEnd: true, onChange: selectedItems => console.log(selectedItems), _children: [ @@ -117,7 +116,6 @@ export const props = { _component: "@budibase/materialdesign-components/Radiobuttongroup", label: "Preferred method of contact: ", orientation: "column", - disabled: true, alignEnd: true, onChange: selected => console.log("Radiobutton Group", selected), _children: [ diff --git a/packages/materialdesign-components/src/Textfield/Textfield.svelte b/packages/materialdesign-components/src/Textfield/Textfield.svelte index dff9ac6413..ace20dbf3f 100644 --- a/packages/materialdesign-components/src/Textfield/Textfield.svelte +++ b/packages/materialdesign-components/src/Textfield/Textfield.svelte @@ -18,7 +18,6 @@ let tfInstance = null onMount(() => { - debugger if (!!tf) tfInstance = new MDCTextField(tf) return () => { !!tfInstance && tf.tfInstance && tf.tfInstance.destroy()