Wednesday, 25 March 2015

Dynamically Adding the Spinner and Edittext with Delete



Dynamically Adding the Spinner and Edittext with Delete


Programmatically Adding n Number of spinner and editext button with delete button





Main Activity:-

package com.example.dynamiccreation;

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.SimpleCursorAdapter;
import android.widget.Spinner;
import android.widget.Toast;

public class MainActivity extends Activity {
    Context context;
    ScrollView scrollView;
    LinearLayout container;
    LinearLayout layout,hor_layout;
   
     int i = 1;
   
    ArrayAdapter<String> dataAdapter;
   
    List<EditText> allEds ;
   
    List<Spinner> allSpinner ;
   
    
   
     List<String> list;
    
    
     private String[] productId = {};
     private String[] product = {};
     private String[] qty = {};
    
    
    
     ArrayList<String> list_productId = new ArrayList<String>();   
     ArrayList<String> list_product;
     ArrayList<String> list_qty = new ArrayList<String>();
    
    
    SQLiteDatabase db = null;
    
   
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        context = this;
        setContentView(R.layout.activity_main);
        layout = (LinearLayout) findViewById(R.id.layout_horittal);
        
        
        db = openOrCreateDatabase("dynamic.db", MODE_PRIVATE, null);
         String sql_create = "create table if not exists valuecheck(_id integer primary key autoincrement,spinner varchar(120),qty varchar(120))";
         String sql_product = "create table if not exists product(_id integer primary key autoincrement,productid varchar(120),product varchar(120),qty varchar(120))";
        
         db.execSQL(sql_create);
         db.execSQL(sql_product);
        
        allEds = new ArrayList<EditText>();
        
        list_product = new ArrayList<String>();
        list_product.add("Select Proudct");
       
        allSpinner = new ArrayList<Spinner>();
        
         String spinner_value[] = {"A","B","C","D","E","F","G","H","I"};
        
          list = new ArrayList<String>();
         list.add("A+");
         list.add("A");
         list.add("B");
         list.add("C");
         list.add("D");
         list.add("E");
         list.add("f");
         list.add("G");
         list.add("I");
         list.add("J");
         list.add("K");
         list.add("L");
        
         dataAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item, list_product);
         dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
        
         String url = "http://192.168.2.16/mjn/roycerest/pick_productinput.php?module=mktgproductallocation&pickname=products&user=5007456";
           
         Log.e("url for android", "======"+url);
           
           
         new AsyncHttpTask().execute(url);
           
           
    }

    public void addButton(View view) {
       
       
       
         final LinearLayout lin_layout = new LinearLayout(MainActivity.this);
         lin_layout.setOrientation(LinearLayout.HORIZONTAL);
            
            final Spinner spinner = new Spinner(MainActivity.this);
         final EditText edittext = new EditText(MainActivity.this);
         edittext.setHint("Please file the value");
       
         final Button btn_get = new Button(MainActivity.this);
         btn_get.setText("Delete");
        
               
         spinner.setOnItemSelectedListener(new OnItemSelectedListener() {
             @Override
             public void onItemSelected(AdapterView<?> parentView, View selectedItemView, int position, long id) {

                     int iv = 0;
               
                   String spin_value = spinner.getSelectedItem().toString();  
                   int spinner_id =  spinner.getId();
                  
                 if(!(spin_value.equals("Select Proudct")))
                 {
                    if(spinner_id>=1)
                    {
                        for(int ij = 0;ij<allSpinner.size();ij++)
                        {
                            String spinnervalue = allSpinner.get(ij).getSelectedItem().toString();
                                if(spin_value.equals(spinnervalue))
                                {
                                    iv++;
                                }
                        }
                        if(iv>=2)
                        {
                             spinner.setAdapter(dataAdapter);
                            Toast.makeText(getApplicationContext(), "Please select different product", Toast.LENGTH_SHORT).show();
                        }
                    }
                 }
             }

             @Override
             public void onNothingSelected(AdapterView<?> parentView) {
                 // your code here
             }

         });

        
        
         final Button btn_Saveas = new Button(MainActivity.this);
         btn_Saveas.setText("Save As");
       
            btn_get.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                   
                //    ((LinearLayout)layout.getParent()).removeView(lp);
                   
                    lin_layout.removeView(btn_get);
                    lin_layout.removeView(edittext);
                    lin_layout.removeView(spinner);
                   
                    allEds.remove(edittext);
                   
                    allSpinner.remove(spinner);
                   
//                    int  ading = spinner.getId();
//                   
//                    String edit_value = edittext.getText().toString();
//                   
                    Toast.makeText(getApplicationContext(), "hello", Toast.LENGTH_SHORT).show();


                }
            });
           
            LayoutParams lp = new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT);
           
            spinner.setLayoutParams(lp);
            edittext.setLayoutParams(lp);
            btn_get.setLayoutParams(lp);
            spinner.setAdapter(dataAdapter);
           
            spinner.setId(i);
            edittext.setId(i);
            btn_get.setId(i);
           
            allEds.add(edittext);
            allSpinner.add(spinner);
           
           
            lin_layout.addView(spinner);
            lin_layout.addView(edittext);
            lin_layout.addView(btn_get);
            layout.addView(lin_layout);
           
            i++;
    }

    public void saveButton(View view)
    {
       
        String inse_delete = "DELETE FROM valuecheck";
    //    String inse_alter ="ALTER TABLE valuecheck AUTO_INCREMENT = 1";
        db.execSQL(inse_delete);
        //db.execSQL(inse_alter);
       
            for(int i=0; i < allEds.size(); i++)
            {
                int id = allEds.get(i).getId();
                String edittestvalue = allEds.get(i).getText().toString();
                String spinnervalue = allSpinner.get(i).getSelectedItem().toString();
               
                Log.i(" ID===>", "ID==========>"+id);
               
                Toast.makeText(getApplicationContext(),"Spinner"+spinnervalue+"Edit Text"+edittestvalue, Toast.LENGTH_SHORT).show();
               
                Log.v(" vvvvvvvvvvvvvv==>Get All Value Dynamically", "Spinner"+spinnervalue+"Edit Text"+edittestvalue);
               
                Log.i(" iiiiiiiiiiiii===> Get All Value Dynamically", "Spinner"+spinnervalue+"Edit Text"+edittestvalue);

                String inse_query = "insert into valuecheck(spinner,qty) values('"+spinnervalue+"','"+edittestvalue+"')";
           
                db.execSQL(inse_query);
           
                Log.d("Insert query for valuecheck", ""+inse_query);
               
            }
           
    }
   
   
   
    public void updateButton(View view)
    {
           
        String inse_select = "SELECT * FROM valuecheck";
        Cursor cr_value = db.rawQuery(inse_select, null);
       
        if(cr_value.getCount()>0)
        {
            while(cr_value.moveToNext())
            {
               
                 final LinearLayout lin_layout1 = new LinearLayout(MainActivity.this);
                 lin_layout1.setOrientation(LinearLayout.HORIZONTAL);
                    
                    final Spinner spinner1 = new Spinner(MainActivity.this);
                 final EditText edittext1 = new EditText(MainActivity.this);
                 edittext1.setHint("Please Fill the value");
               
                 final Button btn_get1 = new Button(MainActivity.this);
                 btn_get1.setText("Delete");
                
                 layout.removeView(lin_layout1);
                
                    btn_get1.setOnClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                           
                        //    ((LinearLayout)layout.getParent()).removeView(lp);
                           
                            lin_layout1.removeView(btn_get1);
                            lin_layout1.removeView(edittext1);
                            lin_layout1.removeView(spinner1);
                           
                            allEds.remove(edittext1);
                           
                            allSpinner.remove(spinner1);
//                            int  ading = spinner.getId();
//                           
//                            String edit_value = edittext.getText().toString();
//                           
//                            Toast.makeText(getApplicationContext(), ""+ading+" "+edit_value, Toast.LENGTH_SHORT).show();
//                           
                        }
                    });
               
                    LayoutParams lp = new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT);
                   
                   
               
                    int ids = cr_value.getInt(cr_value.getColumnIndex("_id"));
               
                    String s_val = cr_value.getString(cr_value.getColumnIndex("spinner"));
                    String e_val = cr_value.getString(cr_value.getColumnIndex("qty"));
                   
                   
                    spinner1.setLayoutParams(lp);
                    edittext1.setLayoutParams(lp);
                    btn_get1.setLayoutParams(lp);
                    spinner1.setAdapter(dataAdapter);
                   
                    spinner1.setSelection(getIndex(spinner1, s_val));
                    edittext1.setText(e_val);
                   
                   // SelectSpinnerItemByValue(spinner1, s_val);
                   
                    Log.i("=======================id============",""+ids);
                   
                   
                   
                    spinner1.setId(i);
                    edittext1.setId(i);
                    btn_get1.setId(i);
//                   
                    allEds.add(edittext1);
                    allSpinner.add(spinner1);
                   
                   
                    lin_layout1.addView(spinner1);
                    lin_layout1.addView(edittext1);
                    lin_layout1.addView(btn_get1);
                    layout.addView(lin_layout1);
                   
                   
                i++;
               
            }
           
        }
        else
        {
            Toast.makeText(getApplicationContext(), "There is No Record in this Table", Toast.LENGTH_SHORT).show();
        }
       
    }
   
//    public static void SelectSpinnerItemByValue(Spinner spnr, String value)
//    {
//        SimpleCursorAdapter adapter = (SimpleCursorAdapter) spnr.getAdapter();
//        for (int position = 0; position < adapter.getCount(); position++)
//        {
//            if(adapter.getItemId(position) == value)
//            {
//                spnr.setSelection(position);
//                return;
//            }
//        }
//    }
//   
   
    private int getIndex(Spinner spinner1, String myString){

        int index = 0;

        for (int i=0;i<spinner1.getCount();i++){
            if (spinner1.getItemAtPosition(i).equals(myString)){
                index = i;
            }
        }
        return index;
 }
   
   
    public void jsonButton(View view)
    {
       
       
       
       
       
       
    }
   
   
    public class AsyncHttpTask extends AsyncTask<String, Void, Integer>
    {
        @Override
        protected Integer doInBackground(String... params)
        {
                InputStream inputStream = null;
                HttpURLConnection urlConnection = null;
                Integer result = 0;
            try
            {
                /* forming th java.net.URL object */
                URL url = new URL(params[0]);
                urlConnection = (HttpURLConnection) url.openConnection();
                /* optional request header */
                urlConnection.setRequestProperty("Content-Type", "application/json");
                /* optional request header */
                urlConnection.setRequestProperty("Accept", "application/json");
                /* for Get request */
                urlConnection.setRequestMethod("GET");
                int statusCode = urlConnection.getResponseCode();
                /* 200 represents HTTP OK */
                if (statusCode == 200) {
                inputStream = new BufferedInputStream(urlConnection.getInputStream());
                String response = convertInputStreamToString(inputStream);
                parseResult(response);
                result = 1; // Successful
                }else{
                result = 0; //"Failed to fetch data!";
                }
            }
            catch (Exception e)
            {
                Log.d("", e.getLocalizedMessage());
            }
            return result; //"Failed to fetch data!";
        }
        @SuppressWarnings("unchecked")
        @Override
        protected void onPostExecute(Integer result) {
        /* Download complete. Lets update UI */
        if(result == 1){
       
           
           

        }else{
        Log.e("", "Failed to fetch data!");
        }
        }
    }
    private String convertInputStreamToString(InputStream inputStream) throws IOException
    {
        BufferedReader bufferedReader = new BufferedReader( new InputStreamReader(inputStream));
        String line = "";
        String result = "";
        while((line = bufferedReader.readLine()) != null){
        result += line;
        }
        /* Close Stream */
        if(null!=inputStream){
        inputStream.close();
        }
        return result;
    }

        private void parseResult(String result)
        {
           
            String inse_delete = "DELETE FROM product";
            db.execSQL(inse_delete);
           
           
           
            try
            {
                JSONObject response = new JSONObject(result);
               
                JSONObject response1 = response.getJSONObject("message");
               
                String su_msg = response1.getString("success");
               
                if(su_msg.equals("true"))
                {
                    //JSONArray posts = response1.optJSONArray("data");
                   
                    JSONArray pose = response1.getJSONArray("data");
                   
                    productId = new String[pose.length()];
                    product = new String[pose.length()];
                    qty = new String[pose.length()];
                   
                    for(int i=0; i< pose.length();i++ )
                    {
                        //JSONObject post = posts.optJSONObject(i);
                        JSONObject post1 = pose.optJSONObject(i);
                        String d_productId= post1.getString("mktgproductallocationid");
                        String d_product = post1.optString("mktgproductallocationname");
                        String d_qty = post1.optString("quntity");
                       
                        Log.e("===================", ""+d_productId);
                       
                       
                       
                        productId[i] = ""+d_productId.toString();
                        product[i] = ""+d_product.toString();
                        qty[i] = ""+d_qty;
                       
                        list_productId.add(d_productId);
                        list_product.add(d_product);
                        list_qty.add(d_qty);
                       
                       
                        String inse_product = "insert into product(productid,product,qty) values('"+d_productId+"','"+d_product+"','"+d_qty+"')";
                       
                        db.execSQL(inse_product);
                       
                        Log.i("================inser proucet",""+inse_product);

                       
                    }
                }
                else
                {
                    String str1 = "There is no value";
                   
                }
           
            }
            catch (JSONException e)
            {
                e.printStackTrace();
            }
        }
   
   
   
   
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

   
}




activity_main.xml


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" >

    <LinearLayout
        android:id="@+id/LinearAdd"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="70"
        android:orientation="horizontal" >

        <Button
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.50"
            android:onClick="addButton"
            android:text="click to add" />

        <Button
            android:id="@+id/update_btn"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.50"
            android:onClick="updateButton"
            android:text="update" />

        <Button
            android:id="@+id/btn_jsonvalue"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.50"
            android:onClick="jsonButton"
            android:text="Json Value" />

    </LinearLayout>

    <ScrollView
        android:id="@+id/scrollView1"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="70" >

        <LinearLayout
            android:id="@+id/layout_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical" >

            <LinearLayout
                android:id="@+id/layout_horittal"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical" >

            </LinearLayout>

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical" >

                <Button
                    android:id="@+id/btn_save_all"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:onClick="saveButton"
                    android:text="Save" />

            </LinearLayout>

        </LinearLayout>
    </ScrollView>

</LinearLayout>



Results:


















 this one another























No comments:

Post a Comment