Возникают проблемы с отображением всех значений в массиве объектов - PullRequest
0 голосов
/ 26 января 2019

Я работаю над использованием облачного кода для интеграции платежей Stripe в Parse.com и использованием Back4App для моего приложения для Android.Я пишу облачный код в javascript, и у меня возникают некоторые проблемы с отображением всех моих запрашиваемых результатов из корзины покупок.

На данный момент я просто пытаюсь извлечь каждый элемент CartItem и распечатать его имя элемента.Но в конце концов я пытаюсь обновить количество каждой позиции в базе данных, когда пользователь нажал кнопку «Купить».

Например:

  • user1 имеет элементы корзины: элемент A с количеством 2 за 10 долларов США и элемент B с количеством 2 за 8 долларов США.

  • user2 имеет позиции корзины: itemA с количеством 2 за 10 долларов США.

  • В базе данных parse.com отображается элемент A с общим количеством заказов 4 и элемент B с общим количеством заказовиз 2.

Я уже создал свою базу данных на parse.com и написал код Java для своего приложения, но я не понимаю, как писать облачный код и проходить циклыкаждая корзина.

Извините, если код плохой.Я в значительной степени учу себя программировать, а javascript совершенно новый для меня.Если бы вы могли указать мне правильное направление, я уверен, что я пойму все остальное.Спасибо.

Прямо сейчас, в моей корзине для пользователя1 у меня есть cartItems [стейк, карри].Но когда я запускаю облачный код, он отображает только карри, а не стейк.Я хочу, чтобы он отображал все элементы в корзине

. Я настроил его с помощью кнопки из CartActivity.java, которая отправляет данные в paymentActivity.java.А внутри paymentActivity.java я обрабатываю облачный код.

CartActivity.java

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;

public class CartActivity extends AppCompatActivity {

    ArrayList<String> myCartItems;
    ArrayList<String> myCartItemQuantity;
    ArrayList<String> myCartItemPrice;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_cart);

        displayCart();

    }

    private void displayCart() {
        // recieving data from MainActivity.class
        myCartItems = getIntent().getExtras().getStringArrayList("cartItems");
         myCartItemQuantity = getIntent().getExtras().getStringArrayList("itemQuantities");
        myCartItemPrice = getIntent().getExtras().getStringArrayList("itemPrices");

        Log.i("myCart ", "items: " + String.valueOf(myCartItems) + "\n" +
                "itemPrices: " + String.valueOf(myCartItemPrice) + "\n" +
                "itemQuantity: " + String.valueOf(myCartItemQuantity));

        LinearLayout linearLayoutVert = findViewById(R.id.linearLayout);
        for (int i = 0; i < myCartItems.size(); i++) {
            LinearLayout linearLayoutHor = new LinearLayout(getApplicationContext());
            linearLayoutHor.setOrientation(LinearLayout.HORIZONTAL);
            linearLayoutVert.addView(linearLayoutHor);

            TextView itemQuantity = new TextView(getApplicationContext());
            TextView item = new TextView(getApplicationContext());
            TextView itemPrice = new TextView(getApplicationContext());

            linearLayoutHor.addView(itemQuantity);
            linearLayoutHor.addView(item);
            linearLayoutHor.addView(itemPrice);

            itemQuantity.setText(myCartItemQuantity.get(i));
            item.setText(myCartItems.get(i));
            itemPrice.setText(myCartItemPrice.get(i));

            //ImageView Setup
            ImageView imageView = new ImageView(this);
            imageView.setImageResource(R.drawable.ic_trash);
            linearLayoutHor.addView(imageView);

        }
    }



public void toPaymentGateway(View view) {
        Intent paymentIntent = new Intent(getApplicationContext(), paymentActivity.class);
        paymentIntent.putExtra("cartItems", myCartItems);
        paymentIntent.putExtra("cartItemPrice", myCartItemPrice);
        paymentIntent.putExtra("cartItemQuantity", myCartItemQuantity);
        startActivity(paymentIntent);
    }

}

paymentActivity.java

package com.example.a1994m.doorstepsdelivery;

import android.app.ProgressDialog;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import com.parse.FunctionCallback;
import com.parse.Parse;
import com.parse.ParseCloud;
import com.parse.ParseException;
import com.parse.ParseUser;
import com.stripe.android.Stripe;
import com.stripe.android.TokenCallback;
import com.stripe.android.model.Card;
import com.stripe.android.model.Token;

import java.util.ArrayList;
import java.util.HashMap;

import static com.example.a1994m.doorstepsdelivery.TestStripe.BACK4PAPP_API;
import static com.example.a1994m.doorstepsdelivery.TestStripe.CLIENT_KEY;

public class paymentActivity extends AppCompatActivity {

    ArrayList<String> myCartItems;
    ArrayList<String> myCartItemQuantity;
    ArrayList<String> myCartItemPrice ;
    ParseUser currentUser = ParseUser.getCurrentUser();

    public static final String PUBLISHABLE_KEY = "_________";
    public static final String APPLICATION_ID = "____________";
    public static final String CLIENT_KEY = "_____________";
    public static final String BACK4PAPP_API = "https://parseapi.back4app.com/";
    private Card card;
    private ProgressDialog progress;
    private Button purchase;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_payment);

        // Connect to Your Back4app Account
        Parse.initialize(new Parse.Configuration.Builder(this)
                .applicationId(APPLICATION_ID)
                .clientKey(CLIENT_KEY)
                .server(BACK4PAPP_API).build());
        Parse.setLogLevel(Parse.LOG_LEVEL_VERBOSE);

//         Create a demo test credit Card
//         You can pass the payment form data to create a Real Credit card
//         But you need to implement youself.

        card = new Card(
                "344776435490016", //card number
                05, //expMonth
                2021,//expYear
                "216"//cvc
        );
        progress = new ProgressDialog(this);
        purchase = (Button) findViewById(R.id.purchase);
        purchase.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
//                buy();
                charge();
                Log.i("redirecting...", "BUTTON HAS BEEN CLICKED");
            }
        });

        // recieving data from CartActivity.class
         myCartItems = getIntent().getExtras().getStringArrayList("cartItems");
         myCartItemQuantity = getIntent().getExtras().getStringArrayList("cartItemQuantity");
         myCartItemPrice = getIntent().getExtras().getStringArrayList("cartItemPrice");

        Log.i("PaymentGateItems ", "items: " + String.valueOf(myCartItems) + "\n" +
                "itemPrices: " + String.valueOf(myCartItemPrice) + "\n" +
                "itemQuantity: " + String.valueOf(myCartItemQuantity));
    }

//    public void placeOrder(View view){
//
//        Intent stripeIntent = new Intent(getApplicationContext(), TestStripe.class);
//        startActivity(stripeIntent);
//    }

//    private void buy(){
//        boolean validation = card.validateCard();
//        if(validation){
//            startProgress("Validating Credit Card");
//            new Stripe(this).createToken(
//                    card,
//                    PUBLISHABLE_KEY,
//                    new TokenCallback() {
//                        @Override
//                        public void onError(Exception error) {
//                            Log.d("Stripe",error.toString());
//                        }
//
//                        @Override
//                        public void onSuccess(Token token) {
//                            finishProgress();
//                            charge(token);
//                        }
//                    });
//        } else if (!card.validateNumber()) {
//            Log.d("Stripe","The card number that you entered is invalid");
//        } else if (!card.validateExpiryDate()) {
//            Log.d("Stripe","The expiration date that you entered is invalid");
//        } else if (!card.validateCVC()) {
//            Log.d("Stripe","The CVC code that you entered is invalid");
//        } else {
//            Log.d("Stripe","The card details that you entered are invalid");
//        }
//    }

//    private void charge(Token cardToken){
//        HashMap<String, Object> params = new HashMap<String, Object>();
//
//        Log.i("items: ", String.valueOf(myCartItems));
//
//        params.put("quantity", myCartItemQuantity);
//        params.put("price", myCartItemPrice);
//        params.put("ItemName", myCartItems);
////        params.put("ItemName", "Pancake");
//        params.put("cardToken", cardToken.getId());
//        params.put("name",currentUser.getUsername());
////        params.put("name","Dominic Wong");
//        params.put("email",currentUser.getEmail());
////        params.put("email","dominwong4@gmail.com");
//        params.put("address","HIHI"); // needs input from billing address on card
//        params.put("zip","99999"); // needs input from billing address on card
//        params.put("city_state","CA"); // needs input from billing addresss on card
//        startProgress("Purchasing Item");
//        ParseCloud.callFunctionInBackground("purchaseItem", params, new FunctionCallback<Object>() {
//            public void done(Object response, ParseException e) {
//                finishProgress();
//                if (e == null) {
//                    Log.d("Cloud Response", "There were no exceptions! " + response.toString());
//                    Toast.makeText(getApplicationContext(),
//                            "Item Purchased Successfully ",
//                            Toast.LENGTH_LONG).show();
//                } else {
//                    Log.d("Cloud Response", "Exception: " + e);
//                    Toast.makeText(getApplicationContext(),
//                            e.getMessage().toString(),
//                            Toast.LENGTH_LONG).show();
//                }
//            }
//        });
//    }

    private void charge(){
        HashMap<String, Object> params = new HashMap<String, Object>();

        Log.i("items: ", String.valueOf(myCartItems));

        params.put("quantity", myCartItemQuantity);
        params.put("price", myCartItemPrice);
        params.put("ItemName", myCartItems);
//        params.put("ItemName", "Pancake");
//        params.put("cardToken", cardToken.getId());
        params.put("name",currentUser.getUsername());
//        params.put("name","Dominic Wong");
        params.put("email",currentUser.getEmail());
//        params.put("email","dominwong4@gmail.com");
        params.put("address","HIHI"); // needs input from billing address on card
        params.put("zip","99999"); // needs input from billing address on card
        params.put("city_state","CA"); // needs input from billing addresss on card
        startProgress("Purchasing Item");
        ParseCloud.callFunctionInBackground("purchaseItem", params, new FunctionCallback<Object>() {
            public void done(Object response, ParseException e) {
                finishProgress();
                if (e == null) {
                    Log.d("Cloud Response", "There were no exceptions! " + response.toString());
                    Toast.makeText(getApplicationContext(),
                            "Item Purchased Successfully ",
                            Toast.LENGTH_LONG).show();
                } else {
                    Log.d("Cloud Response", "Exception: " + e);
                    Toast.makeText(getApplicationContext(),
                            e.getMessage().toString(),
                            Toast.LENGTH_LONG).show();
                }
            }
        });
    }

    private void startProgress(String title){
        progress.setTitle(title);
        progress.setMessage("Please Wait");
        progress.show();
    }

    private void finishProgress(){
        progress.dismiss();
    }
}

Код облака:

var Stripe = require("stripe")("sk_test_rU8GCiz0tkNB02ZbcsXP3b2a");
Parse.Cloud.define("purchaseItem", function (request, response) {
    var item, order;
    var total = 0;

    var CartItems = request.params.ItemName;
    var CartPrice = request.params.price;
    var CartItemQuantity = request.params.quantity;

    var cartQuery = new Parse.Query('Item');

    for(var i=0; i<CartItems.length; i++){

        cartQuery.equalTo('ItemName', CartItems[i]);

        cartQuery.find()
            .then(function (results) {
                for (var result of results) {
                    response.success("got the items " + 
                    result.get("ItemName"));
                }
            })
            .catch(function (error) {
                response.error("could not get the items " + error);
            });
    }
});

1 Ответ

0 голосов
/ 28 января 2019

Вы должны звонить response.success только один раз. Последующие звонки будут игнорироваться. Вы можете попробовать что-то вроде этого.

cartQuery.find()
        .then(function (results) {
            var items = [];
            for (var result of results) {
                items.push(result.get("ItemName"));

            }
            response.success(JSON.stringify(items));
        })
        .catch(function (error) {
            response.error("could not get the items " + error);
        });

Это ответит элементами в виде массива. например, ["steak", "curry"] Затем вы должны обработать это на стороне клиента. например, используя JSONArray

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...