File size: 2,354 Bytes
b61753c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
7860afc
 
 
 
 
 
b61753c
 
 
 
 
 
 
e965642
 
 
 
 
 
 
 
 
 
 
 
7860afc
b61753c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<svelte:options accessors={true} />

<script context="module" lang="ts">
  export { default as BaseTextbox } from "./shared/Textbox.svelte";
  export { default as BaseExample } from "./Example.svelte";
</script>

<script lang="ts">
  import { onMount } from "svelte";
  import type { Gradio, SelectData } from "@gradio/utils";
  import { BlockTitle } from "@gradio/atoms";

  import SequenceInput from "./shared/SequenceInput.svelte";
  import { Block } from "@gradio/atoms";
  import { StatusTracker } from "@gradio/statustracker";
  import type { LoadingStatus } from "@gradio/statustracker";

  export let gradio: Gradio<{
    change: string;
    submit: never;
    blur: never;
    select: SelectData;
    input: never;
    focus: never;
  }>;
  export let label = "CofoldingInput";
  export let info: string | undefined = undefined;
  export let elem_id = "";
  export let elem_classes: string[] = [];
  export let visible = true;
  export let value = { chains: [], covMods: [] };
  export let show_label: boolean;
  export let container = true;
  export let scale: number | null = null;
  export let min_width: number | undefined = undefined;
  export let loading_status: LoadingStatus | undefined = undefined;

  function syncValue(event) {
    //remove empty values and open attributes
    // let entries = event.detail.map((entry) =>
    //   Object.fromEntries(
    //     Object.entries(entry).filter(([key, value]))
    //   )
    // );
    value["chains"] = event.detail; //entries;
  }

  function syncCovMod(event) {
    value["covMods"] = event.detail;
  }

  onMount(() => {});

  $: console.log(value);

  // let id = 0;
  // trigger reload of values
  // when the value is changed
  // // let old_value = value;
  // $: if (JSON.stringify(old_value) !== JSON.stringify(value)) {
  //   // gradio.dispatch("change");
  //   old_value = value;
  //   // id += 1;
  // }
  import "./style.css";
</script>

<Block
  {visible}
  {elem_id}
  {elem_classes}
  {scale}
  {min_width}
  allow_overflow={false}
  padding={container}
>
  {#if loading_status}
    <StatusTracker
      autoscroll={gradio.autoscroll}
      i18n={gradio.i18n}
      {...loading_status}
    />
  {/if}

  <BlockTitle {show_label} {info}>{label}</BlockTitle>

  <SequenceInput
    bind:value
    on:updateVals={syncValue}
    on:updateCovMod={syncCovMod}
  />
</Block>