diff options
-rw-r--r-- | interchange/ord.hxx | 5 | ||||
-rw-r--r-- | ord.cxx | 25 |
2 files changed, 29 insertions, 1 deletions
diff --git a/interchange/ord.hxx b/interchange/ord.hxx index 7405c55..a0cb885 100644 --- a/interchange/ord.hxx +++ b/interchange/ord.hxx @@ -47,17 +47,20 @@ namespace QInterchange { double totalCost() const { return m_totalCost; } void setProfile(QString const& profile); public slots: -// void remove(unsigned int const& indices); + void remove(const QString &name, + const QString &nextPage); void checkout(const Member& member); signals: void rowCountChanged(); void subtotalChanged(); void shippingChanged(); void totalCostChanged(); + void removed(const QString &response); void gotTransaction(QString const& response); protected: QHash<int, QByteArray> roleNames() const Q_DECL_OVERRIDE; + void emitRemoval(const QString &response); void emitTransaction(QString const& response); private: @@ -6,6 +6,7 @@ namespace QInterchange { static Ord* ord; + static char *item_name, *next_page; static char* order_profile; static char *fname, *lname, *address1, *address2, *city, *state, *zip, *phone_day, *email; @@ -88,6 +89,25 @@ namespace QInterchange { if (this->profile != profile) this->profile = profile; } + void Ord::remove(const QString &name, const QString &nextPage) + { + item_name = (char *)malloc(name.size() + 1); + strcpy(item_name, name.toLatin1().constData()); + if (nextPage.isEmpty()) + next_page = nullptr; + else { + next_page = (char *)malloc(nextPage.size() + 1); + strcpy(next_page, nextPage.toLatin1().constData()); + } + interchange_ord_remove(item_name, next_page, + [](interchange_response *response) { + free(item_name); + if (next_page) free(next_page); + ord->emitRemoval(QString{response->data}); + interchange_free_response(response); + }); + } + void Ord::checkout(const Member& member) { order_profile = (char*)malloc(profile.size() + 1); @@ -140,6 +160,11 @@ namespace QInterchange { }); } + void Ord::emitRemoval(const QString &response) + { + emit removed(response); + } + void Ord::emitTransaction(QString const& response) { emit gotTransaction(response); |