summaryrefslogtreecommitdiff
path: root/same-android/src/main/java/com/orbekk/same/android/VariableTestActivity.java
blob: b84f144f1c62ffe1565698288a45b6ecb3bed2c3 (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
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
94
95
96
/**
 * Copyright 2012 Kjetil Ørbekk <kjetil.orbekk@gmail.com>
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.orbekk.same.android;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;

import com.orbekk.same.Variable;
import com.orbekk.util.DelayedOperation;

public class VariableTestActivity extends Activity {
    private Logger logger = LoggerFactory.getLogger(getClass());
    private ClientInterfaceBridge client;
    private Variable<String> variable;
    
    private Variable.OnChangeListener<String> onChangeListener =
            new Variable.OnChangeListener<String>() {
        @Override
        public void valueChanged(Variable<String> unused) {
            variable.update();
            displayVariable();
        }
    };
    
    private class UpdateVariableTask
            extends AsyncTask<String, Void, DelayedOperation.Status> {
        @Override protected DelayedOperation.Status doInBackground(String... values) {
            String value = values[0];
            return variable.set(value).getStatus();
        }
        
        @Override protected void onPostExecute(DelayedOperation.Status status) {
            if (!status.isOk()) {
                Toast.makeText(VariableTestActivity.this,
                        "Update failed: " + status, Toast.LENGTH_SHORT)
                                .show();
            }
        }
    }
    
    private void displayVariable() {
        TextView tv = (TextView)findViewById(R.id.variable_text);
        if (variable.get() != null) {
            tv.setText(variable.get());
        }
    }
    
    public void setVariable(View unused) {
        EditText et = (EditText)findViewById(R.id.set_variable_text);
        String newValue = et.getText().toString();
        new UpdateVariableTask().execute(newValue);
    }
    
    @Override public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.variable_test);
    }
    
    @Override public void onResume() {
        super.onResume();
        client = new ClientInterfaceBridge(this);
        client.connect();
        variable = client.createVariableFactory()
                .createString("TestVariable");
        variable.addOnChangeListener(onChangeListener);
        variable.set("Hello, World!");
        displayVariable();
    }
    
    @Override public void onStop() {
        super.onStop();
        variable.removeOnChangeListener(onChangeListener);
        client.disconnect();
    }
}