not-bulma 1.2.72 → 1.2.74

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "not-bulma",
3
- "version": "1.2.72",
3
+ "version": "1.2.74",
4
4
  "description": "not-* family UI components on Bulma CSS Framework",
5
5
  "main": "src/index.js",
6
6
  "svelte": "src/index.js",
@@ -7,6 +7,7 @@ import UIDate from "./ui.date.svelte";
7
7
  import UIDatetimeInTZ from "./ui.datetime.in.tz.svelte";
8
8
  import UIEmail from "./ui.email.svelte";
9
9
  import UIHidden from "./ui.hidden.svelte";
10
+ import UIJSONArea from "./ui.json.area.svelte";
10
11
  import UILabel from "./ui.label.svelte";
11
12
  import UIListOfModels from "./ui.list.of.models.svelte";
12
13
  import UINamedNumbersList from "./ui.named.numbers.list.svelte";
@@ -15,8 +16,8 @@ import UIPassword from "./ui.password.svelte";
15
16
  import UIRadioButtons from "./ui.radio.buttons.svelte";
16
17
  import UIRange from "./ui.range.svelte";
17
18
  import UIRangeLogarithmic from "./ui.range.logarithmic.svelte";
18
- import UISelectFromModel from "./ui.select.from.model.svelte";
19
19
  import UISelect from "./ui.select.svelte";
20
+ import UISelectFromModel from "./ui.select.from.model.svelte";
20
21
  import UISwitch from "./ui.switch.svelte";
21
22
  import UISwitchList from "./ui.switch.list.svelte";
22
23
  import UITagSelect from "./ui.tag.select.svelte";
@@ -34,6 +35,7 @@ export {
34
35
  UIDatetimeInTZ,
35
36
  UIEmail,
36
37
  UIHidden,
38
+ UIJSONArea,
37
39
  UILabel,
38
40
  UIListOfModels,
39
41
  UINamedNumbersList,
@@ -42,8 +44,8 @@ export {
42
44
  UIRadioButtons,
43
45
  UIRange,
44
46
  UIRangeLogarithmic,
45
- UISelectFromModel,
46
47
  UISelect,
48
+ UISelectFromModel,
47
49
  UISwitch,
48
50
  UISwitchList,
49
51
  UITagSelect,
@@ -0,0 +1,67 @@
1
+ <script>
2
+ import UITextarea from "./ui.textarea.svelte";
3
+
4
+ import { createEventDispatcher, onMount } from "svelte";
5
+ let dispatch = createEventDispatcher();
6
+
7
+ export let inputStarted = false;
8
+ export let value = {};
9
+ export let placeholder = "";
10
+ export let fieldname = "jsonarea";
11
+ export let icon = false;
12
+ export let rows = 10;
13
+ export let required = true;
14
+ export let readonly = false;
15
+ export let disabled = false;
16
+ export let valid = true;
17
+ export let validated = false;
18
+ export let errors = false;
19
+ export let formErrors = false;
20
+ export let formLevelError = false;
21
+
22
+ let _value = "{}";
23
+
24
+ onMount(() => {
25
+ _value = JSON.stringify(value, null, 4);
26
+ });
27
+
28
+ function change() {
29
+ inputStarted = true;
30
+ dispatch("change", {
31
+ field: fieldname,
32
+ value,
33
+ });
34
+ }
35
+
36
+ function validateValueAndChange(val) {
37
+ try {
38
+ value = JSON.parse(val);
39
+ valid = true;
40
+ errors = false;
41
+ change();
42
+ } catch (error) {
43
+ valid = false;
44
+ errors = [error.message];
45
+ }
46
+ }
47
+
48
+ function onChange(ev) {
49
+ validateValueAndChange(ev.detail.value);
50
+ return true;
51
+ }
52
+ </script>
53
+
54
+ <UITextarea
55
+ bind:inputStarted
56
+ bind:value={_value}
57
+ on:change={onChange}
58
+ {placeholder}
59
+ {icon}
60
+ {rows}
61
+ {required}
62
+ {readonly}
63
+ {disabled}
64
+ {validated}
65
+ {formErrors}
66
+ {formLevelError}
67
+ />
@@ -5,7 +5,7 @@
5
5
  import UICommon from "../common.js";
6
6
  import ErrorsList from "../various/ui.errors.list.svelte";
7
7
  import { createEventDispatcher } from "svelte";
8
- let dispatch = createEventDispatcher();
8
+ const dispatch = createEventDispatcher();
9
9
 
10
10
  export let inputStarted = false;
11
11
  export let value = 10;
@@ -45,15 +45,15 @@
45
45
  return true;
46
46
  }
47
47
 
48
- /*function onInput(ev){
49
- let data = {
50
- field: fieldname,
51
- value: ev.currentTarget.value
52
- };
53
- inputStarted = true;
54
- dispatch('change', data);
55
- return true;
56
- }*/
48
+ function onInput(ev) {
49
+ let data = {
50
+ field: fieldname,
51
+ value: ev.currentTarget.value,
52
+ };
53
+ inputStarted = true;
54
+ dispatch("change", data);
55
+ return true;
56
+ }
57
57
  </script>
58
58
 
59
59
  <div class="control {iconClasses}">
@@ -1,12 +1,23 @@
1
1
  <script>
2
+ import { onMount } from "svelte";
2
3
  import UIBoolean from "./ui.boolean.svelte";
3
4
 
4
5
  export let values = [];
5
6
  export let inverted = false;
6
7
  export let componentConstructor = UIBoolean;
8
+
9
+ let _values = [];
10
+
11
+ onMount(() => {
12
+ if (typeof values === "boolean") {
13
+ _values = [values];
14
+ } else if (Array.isArray(values)) {
15
+ _values = [...values];
16
+ }
17
+ });
7
18
  </script>
8
19
 
9
- {#each values as item}
20
+ {#each _values as item}
10
21
  <svelte:component
11
22
  this={componentConstructor}
12
23
  {...item}