summaryrefslogtreecommitdiff
path: root/src/webex/components.ts
blob: 1f5d18731c462834435f143f7205b17c3fe45d97 (plain)
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
/*
 This file is part of TALER
 (C) 2016 Inria

 TALER is free software; you can redistribute it and/or modify it under the
 terms of the GNU General Public License as published by the Free Software
 Foundation; either version 3, or (at your option) any later version.

 TALER is distributed in the hope that it will be useful, but WITHOUT ANY
 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
 A PARTICULAR PURPOSE.  See the GNU General Public License for more details.

 You should have received a copy of the GNU General Public License along with
 TALER; see the file COPYING.  If not, see <http://www.gnu.org/licenses/>
 */


/**
 * General helper React components.
 */


/**
 * Imports.
 */
import * as React from "react";

/**
 * Wrapper around state that will cause updates to the
 * containing component.
 */
export interface StateHolder<T> {
  (): T;
  (newState: T): void;
}

/**
 * Component that doesn't hold its state in one object,
 * but has multiple state holders.
 */
export abstract class ImplicitStateComponent<PropType> extends React.Component<PropType, any> {
  private _implicit = {needsUpdate: false, didMount: false};
  componentDidMount() {
    this._implicit.didMount = true;
    if (this._implicit.needsUpdate) {
      this.setState({} as any);
    }
  }
  makeState<StateType>(initial: StateType): StateHolder<StateType> {
    let state: StateType = initial;
    return (s?: StateType): StateType => {
      if (s !== undefined) {
        state = s;
        if (this._implicit.didMount) {
          this.setState({} as any);
        } else {
          this._implicit.needsUpdate = true;
        }
      }
      return state;
    };
  }
}