daynmic products listing
parent
6162833bba
commit
69ea8b7bd7
@ -0,0 +1,184 @@
|
||||
class FinalProductsModel {
|
||||
String id;
|
||||
String name;
|
||||
String namen;
|
||||
List<LocalizedNames> localizedNames;
|
||||
String shortDescription;
|
||||
String fullDescription;
|
||||
String fullDescriptionn;
|
||||
dynamic approvedRatingSum;
|
||||
dynamic approvedTotalReviews;
|
||||
String sku;
|
||||
bool isRx;
|
||||
dynamic rxMessage;
|
||||
dynamic rxMessagen;
|
||||
dynamic stockQuantity;
|
||||
String stockAvailability;
|
||||
String stockAvailabilityn;
|
||||
bool allowBackInStockSubscriptions;
|
||||
dynamic orderMinimumQuantity;
|
||||
dynamic orderMaximumQuantity;
|
||||
dynamic price;
|
||||
dynamic oldPrice;
|
||||
dynamic discountName;
|
||||
dynamic discountNamen;
|
||||
dynamic discountPercentage;
|
||||
dynamic displayOrder;
|
||||
List<dynamic> discountIds;
|
||||
List<dynamic> reviews;
|
||||
List<Images> images;
|
||||
|
||||
FinalProductsModel(
|
||||
{this.id,
|
||||
this.name,
|
||||
this.namen,
|
||||
this.localizedNames,
|
||||
this.shortDescription,
|
||||
this.fullDescription,
|
||||
this.fullDescriptionn,
|
||||
this.approvedRatingSum,
|
||||
this.approvedTotalReviews,
|
||||
this.sku,
|
||||
this.isRx,
|
||||
this.rxMessage,
|
||||
this.rxMessagen,
|
||||
this.stockQuantity,
|
||||
this.stockAvailability,
|
||||
this.stockAvailabilityn,
|
||||
this.allowBackInStockSubscriptions,
|
||||
this.orderMinimumQuantity,
|
||||
this.orderMaximumQuantity,
|
||||
this.price,
|
||||
this.oldPrice,
|
||||
this.discountName,
|
||||
this.discountNamen,
|
||||
this.discountPercentage,
|
||||
this.displayOrder,
|
||||
this.discountIds,
|
||||
this.reviews,
|
||||
this.images});
|
||||
|
||||
FinalProductsModel.fromJson(Map<String, dynamic> json) {
|
||||
id = json['id'];
|
||||
name = json['name'];
|
||||
if (json['images'] != null) {
|
||||
images = new List<Images>();
|
||||
json['images'].forEach((v) {
|
||||
images.add(new Images.fromJson(v));
|
||||
});
|
||||
}
|
||||
namen = json['namen'];
|
||||
if (json['localized_names'] != null) {
|
||||
localizedNames = new List<LocalizedNames>();
|
||||
json['localized_names'].forEach((v) {
|
||||
localizedNames.add(new LocalizedNames.fromJson(v));
|
||||
});
|
||||
}
|
||||
shortDescription = json['short_description'];
|
||||
fullDescription = json['full_description'];
|
||||
fullDescriptionn = json['full_descriptionn'];
|
||||
approvedRatingSum = json['approved_rating_sum'];
|
||||
approvedTotalReviews = json['approved_total_reviews'];
|
||||
sku = json['sku'];
|
||||
isRx = json['is_rx'];
|
||||
rxMessage = json['rx_message'];
|
||||
rxMessagen = json['rx_messagen'];
|
||||
stockQuantity = json['stock_quantity'];
|
||||
stockAvailability = json['stock_availability'];
|
||||
stockAvailabilityn = json['stock_availabilityn'];
|
||||
allowBackInStockSubscriptions = json['allow_back_in_stock_subscriptions'];
|
||||
orderMinimumQuantity = json['order_minimum_quantity'];
|
||||
orderMaximumQuantity = json['order_maximum_quantity'];
|
||||
price = json['price'];
|
||||
oldPrice = json['old_price'];
|
||||
discountName = json['discount_name'];
|
||||
discountNamen = json['discount_namen'];
|
||||
discountPercentage = json['discount_percentage'];
|
||||
displayOrder = json['display_order'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['id'] = this.id;
|
||||
data['name'] = this.name;
|
||||
data['namen'] = this.namen;
|
||||
if (this.localizedNames != null) {
|
||||
data['localized_names'] =
|
||||
this.localizedNames.map((v) => v.toJson()).toList();
|
||||
}
|
||||
data['short_description'] = this.shortDescription;
|
||||
data['full_description'] = this.fullDescription;
|
||||
data['full_descriptionn'] = this.fullDescriptionn;
|
||||
data['approved_rating_sum'] = this.approvedRatingSum;
|
||||
data['approved_total_reviews'] = this.approvedTotalReviews;
|
||||
data['sku'] = this.sku;
|
||||
data['is_rx'] = this.isRx;
|
||||
data['rx_message'] = this.rxMessage;
|
||||
data['rx_messagen'] = this.rxMessagen;
|
||||
data['stock_quantity'] = this.stockQuantity;
|
||||
data['stock_availability'] = this.stockAvailability;
|
||||
data['stock_availabilityn'] = this.stockAvailabilityn;
|
||||
data['allow_back_in_stock_subscriptions'] =
|
||||
this.allowBackInStockSubscriptions;
|
||||
data['order_minimum_quantity'] = this.orderMinimumQuantity;
|
||||
data['order_maximum_quantity'] = this.orderMaximumQuantity;
|
||||
data['price'] = this.price;
|
||||
data['old_price'] = this.oldPrice;
|
||||
data['discount_name'] = this.discountName;
|
||||
data['discount_namen'] = this.discountNamen;
|
||||
data['discount_percentage'] = this.discountPercentage;
|
||||
data['display_order'] = this.displayOrder;
|
||||
|
||||
if (this.images != null) {
|
||||
data['images'] = this.images.map((v) => v.toJson()).toList();
|
||||
}
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class LocalizedNames {
|
||||
int languageId;
|
||||
String localizedName;
|
||||
|
||||
LocalizedNames({this.languageId, this.localizedName});
|
||||
|
||||
LocalizedNames.fromJson(Map<String, dynamic> json) {
|
||||
languageId = json['language_id'];
|
||||
localizedName = json['localized_name'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['language_id'] = this.languageId;
|
||||
data['localized_name'] = this.localizedName;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class Images {
|
||||
int id;
|
||||
int position;
|
||||
String src;
|
||||
String thumb;
|
||||
String attachment;
|
||||
|
||||
Images({this.id, this.position, this.src, this.thumb, this.attachment});
|
||||
|
||||
Images.fromJson(Map<String, dynamic> json) {
|
||||
id = json['id'];
|
||||
position = json['position'];
|
||||
src = json['src'];
|
||||
thumb = json['thumb'];
|
||||
attachment = json['attachment'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['id'] = this.id;
|
||||
data['position'] = this.position;
|
||||
data['src'] = this.src;
|
||||
data['thumb'] = this.thumb;
|
||||
data['attachment'] = this.attachment;
|
||||
return data;
|
||||
}
|
||||
}
|
@ -0,0 +1,75 @@
|
||||
class SubCategoriesModel {
|
||||
String id;
|
||||
String name;
|
||||
String namen;
|
||||
List<LocalizedNames> localizedNames;
|
||||
String description;
|
||||
int parentCategoryId;
|
||||
int displayOrder;
|
||||
dynamic image;
|
||||
bool isLeaf;
|
||||
|
||||
SubCategoriesModel(
|
||||
{this.id,
|
||||
this.name,
|
||||
this.namen,
|
||||
this.localizedNames,
|
||||
this.description,
|
||||
this.parentCategoryId,
|
||||
this.displayOrder,
|
||||
this.image,
|
||||
this.isLeaf});
|
||||
|
||||
SubCategoriesModel.fromJson(Map<String, dynamic> json) {
|
||||
id = json['id'];
|
||||
name = json['name'];
|
||||
namen = json['namen'];
|
||||
if (json['localized_names'] != null) {
|
||||
localizedNames = new List<LocalizedNames>();
|
||||
json['localized_names'].forEach((v) {
|
||||
localizedNames.add(new LocalizedNames.fromJson(v));
|
||||
});
|
||||
}
|
||||
description = json['description'];
|
||||
parentCategoryId = json['parent_category_id'];
|
||||
displayOrder = json['display_order'];
|
||||
image = json['image'];
|
||||
isLeaf = json['is_leaf'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['id'] = this.id;
|
||||
data['name'] = this.name;
|
||||
data['namen'] = this.namen;
|
||||
if (this.localizedNames != null) {
|
||||
data['localized_names'] =
|
||||
this.localizedNames.map((v) => v.toJson()).toList();
|
||||
}
|
||||
data['description'] = this.description;
|
||||
data['parent_category_id'] = this.parentCategoryId;
|
||||
data['display_order'] = this.displayOrder;
|
||||
data['image'] = this.image;
|
||||
data['is_leaf'] = this.isLeaf;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class LocalizedNames {
|
||||
int languageId;
|
||||
String localizedName;
|
||||
|
||||
LocalizedNames({this.languageId, this.localizedName});
|
||||
|
||||
LocalizedNames.fromJson(Map<String, dynamic> json) {
|
||||
languageId = json['language_id'];
|
||||
localizedName = json['localized_name'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['language_id'] = this.languageId;
|
||||
data['localized_name'] = this.localizedName;
|
||||
return data;
|
||||
}
|
||||
}
|
@ -0,0 +1,562 @@
|
||||
class SubProductsModel {
|
||||
String id;
|
||||
bool visibleIndividually;
|
||||
String name;
|
||||
String namen;
|
||||
List<LocalizedNames> localizedNames;
|
||||
String shortDescription;
|
||||
String shortDescriptionn;
|
||||
String fullDescription;
|
||||
String fullDescriptionn;
|
||||
bool markasNew;
|
||||
bool showOnHomePage;
|
||||
dynamic metaKeywords;
|
||||
dynamic metaDescription;
|
||||
dynamic metaTitle;
|
||||
bool allowCustomerReviews;
|
||||
dynamic approvedRatingSum;
|
||||
dynamic notApprovedRatingSum;
|
||||
dynamic approvedTotalReviews;
|
||||
dynamic notApprovedTotalReviews;
|
||||
String sku;
|
||||
bool isRx;
|
||||
bool prescriptionRequired;
|
||||
dynamic rxMessage;
|
||||
dynamic rxMessagen;
|
||||
dynamic manufacturerPartNumber;
|
||||
dynamic gtin;
|
||||
bool isGiftCard;
|
||||
bool requireOtherProducts;
|
||||
bool automaticallyAddRequiredProducts;
|
||||
bool isDownload;
|
||||
bool unlimitedDownloads;
|
||||
dynamic maxNumberOfDownloads;
|
||||
dynamic downloadExpirationDays;
|
||||
bool hasSampleDownload;
|
||||
bool hasUserAgreement;
|
||||
bool isRecurring;
|
||||
dynamic recurringCycleLength;
|
||||
dynamic recurringTotalCycles;
|
||||
bool isRental;
|
||||
dynamic rentalPriceLength;
|
||||
bool isShipEnabled;
|
||||
bool isFreeShipping;
|
||||
bool shipSeparately;
|
||||
dynamic additionalShippingCharge;
|
||||
bool isTaxExempt;
|
||||
bool isTelecommunicationsOrBroadcastingOrElectronicServices;
|
||||
bool useMultipleWarehouses;
|
||||
dynamic manageInventoryMethodId;
|
||||
dynamic stockQuantity;
|
||||
String stockAvailability;
|
||||
String stockAvailabilityn;
|
||||
bool displayStockAvailability;
|
||||
bool displayStockQuantity;
|
||||
dynamic minStockQuantity;
|
||||
dynamic notifyAdminForQuantityBelow;
|
||||
bool allowBackInStockSubscriptions;
|
||||
dynamic orderMinimumQuantity;
|
||||
dynamic orderMaximumQuantity;
|
||||
dynamic allowedQuantities;
|
||||
bool allowAddingOnlyExistingAttributeCombinations;
|
||||
bool disableBuyButton;
|
||||
bool disableWishlistButton;
|
||||
bool availableForPreOrder;
|
||||
dynamic preOrderAvailabilityStartDateTimeUtc;
|
||||
bool callForPrice;
|
||||
dynamic price;
|
||||
dynamic oldPrice;
|
||||
dynamic productCost;
|
||||
dynamic specialPrice;
|
||||
dynamic specialPriceStartDateTimeUtc;
|
||||
dynamic specialPriceEndDateTimeUtc;
|
||||
bool customerEntersPrice;
|
||||
dynamic minimumCustomerEnteredPrice;
|
||||
dynamic maximumCustomerEnteredPrice;
|
||||
bool basepriceEnabled;
|
||||
dynamic basepriceAmount;
|
||||
dynamic basepriceBaseAmount;
|
||||
bool hasTierPrices;
|
||||
bool hasDiscountsApplied;
|
||||
dynamic discountName;
|
||||
dynamic discountNamen;
|
||||
dynamic discountDescription;
|
||||
dynamic discountDescriptionn;
|
||||
dynamic discountPercentage;
|
||||
String currency;
|
||||
String currencyn;
|
||||
double weight;
|
||||
dynamic length;
|
||||
dynamic width;
|
||||
dynamic height;
|
||||
dynamic availableStartDateTimeUtc;
|
||||
dynamic availableEndDateTimeUtc;
|
||||
dynamic displayOrder;
|
||||
bool published;
|
||||
bool deleted;
|
||||
String createdOnUtc;
|
||||
String updatedOnUtc;
|
||||
String productType;
|
||||
dynamic parentGroupedProductId;
|
||||
List<dynamic> roleIds;
|
||||
List<dynamic> discountIds;
|
||||
List<dynamic> storeIds;
|
||||
List<int> manufacturerIds;
|
||||
List<dynamic> reviews;
|
||||
List<Images> images;
|
||||
List<dynamic> attributes;
|
||||
List<Specifications> specifications;
|
||||
List<dynamic> associatedProductIds;
|
||||
List<dynamic> tags;
|
||||
dynamic vendorId;
|
||||
String seName;
|
||||
|
||||
SubProductsModel(
|
||||
{this.id,
|
||||
this.visibleIndividually,
|
||||
this.name,
|
||||
this.namen,
|
||||
this.localizedNames,
|
||||
this.shortDescription,
|
||||
this.shortDescriptionn,
|
||||
this.fullDescription,
|
||||
this.fullDescriptionn,
|
||||
this.markasNew,
|
||||
this.showOnHomePage,
|
||||
this.metaKeywords,
|
||||
this.metaDescription,
|
||||
this.metaTitle,
|
||||
this.allowCustomerReviews,
|
||||
this.approvedRatingSum,
|
||||
this.notApprovedRatingSum,
|
||||
this.approvedTotalReviews,
|
||||
this.notApprovedTotalReviews,
|
||||
this.sku,
|
||||
this.isRx,
|
||||
this.prescriptionRequired,
|
||||
this.rxMessage,
|
||||
this.rxMessagen,
|
||||
this.manufacturerPartNumber,
|
||||
this.gtin,
|
||||
this.isGiftCard,
|
||||
this.requireOtherProducts,
|
||||
this.automaticallyAddRequiredProducts,
|
||||
this.isDownload,
|
||||
this.unlimitedDownloads,
|
||||
this.maxNumberOfDownloads,
|
||||
this.downloadExpirationDays,
|
||||
this.hasSampleDownload,
|
||||
this.hasUserAgreement,
|
||||
this.isRecurring,
|
||||
this.recurringCycleLength,
|
||||
this.recurringTotalCycles,
|
||||
this.isRental,
|
||||
this.rentalPriceLength,
|
||||
this.isShipEnabled,
|
||||
this.isFreeShipping,
|
||||
this.shipSeparately,
|
||||
this.additionalShippingCharge,
|
||||
this.isTaxExempt,
|
||||
this.isTelecommunicationsOrBroadcastingOrElectronicServices,
|
||||
this.useMultipleWarehouses,
|
||||
this.manageInventoryMethodId,
|
||||
this.stockQuantity,
|
||||
this.stockAvailability,
|
||||
this.stockAvailabilityn,
|
||||
this.displayStockAvailability,
|
||||
this.displayStockQuantity,
|
||||
this.minStockQuantity,
|
||||
this.notifyAdminForQuantityBelow,
|
||||
this.allowBackInStockSubscriptions,
|
||||
this.orderMinimumQuantity,
|
||||
this.orderMaximumQuantity,
|
||||
this.allowedQuantities,
|
||||
this.allowAddingOnlyExistingAttributeCombinations,
|
||||
this.disableBuyButton,
|
||||
this.disableWishlistButton,
|
||||
this.availableForPreOrder,
|
||||
this.preOrderAvailabilityStartDateTimeUtc,
|
||||
this.callForPrice,
|
||||
this.price,
|
||||
this.oldPrice,
|
||||
this.productCost,
|
||||
this.specialPrice,
|
||||
this.specialPriceStartDateTimeUtc,
|
||||
this.specialPriceEndDateTimeUtc,
|
||||
this.customerEntersPrice,
|
||||
this.minimumCustomerEnteredPrice,
|
||||
this.maximumCustomerEnteredPrice,
|
||||
this.basepriceEnabled,
|
||||
this.basepriceAmount,
|
||||
this.basepriceBaseAmount,
|
||||
this.hasTierPrices,
|
||||
this.hasDiscountsApplied,
|
||||
this.discountName,
|
||||
this.discountNamen,
|
||||
this.discountDescription,
|
||||
this.discountDescriptionn,
|
||||
this.discountPercentage,
|
||||
this.currency,
|
||||
this.currencyn,
|
||||
this.weight,
|
||||
this.length,
|
||||
this.width,
|
||||
this.height,
|
||||
this.availableStartDateTimeUtc,
|
||||
this.availableEndDateTimeUtc,
|
||||
this.displayOrder,
|
||||
this.published,
|
||||
this.deleted,
|
||||
this.createdOnUtc,
|
||||
this.updatedOnUtc,
|
||||
this.productType,
|
||||
this.parentGroupedProductId,
|
||||
this.roleIds,
|
||||
this.discountIds,
|
||||
this.storeIds,
|
||||
this.manufacturerIds,
|
||||
this.reviews,
|
||||
this.images,
|
||||
this.attributes,
|
||||
this.specifications,
|
||||
this.associatedProductIds,
|
||||
this.tags,
|
||||
this.vendorId,
|
||||
this.seName});
|
||||
|
||||
SubProductsModel.fromJson(Map<String, dynamic> json) {
|
||||
id = json['id'];
|
||||
visibleIndividually = json['visible_individually'];
|
||||
name = json['name'];
|
||||
if (json['images'] != null) {
|
||||
images = new List<Images>();
|
||||
json['images'].forEach((v) {
|
||||
images.add(new Images.fromJson(v));
|
||||
});
|
||||
}
|
||||
namen = json['namen'];
|
||||
if (json['localized_names'] != null) {
|
||||
localizedNames = new List<LocalizedNames>();
|
||||
json['localized_names'].forEach((v) {
|
||||
localizedNames.add(new LocalizedNames.fromJson(v));
|
||||
});
|
||||
}
|
||||
shortDescription = json['short_description'];
|
||||
shortDescriptionn = json['short_descriptionn'];
|
||||
fullDescription = json['full_description'];
|
||||
fullDescriptionn = json['full_descriptionn'];
|
||||
markasNew = json['markas_new'];
|
||||
showOnHomePage = json['show_on_home_page'];
|
||||
metaKeywords = json['meta_keywords'];
|
||||
metaDescription = json['meta_description'];
|
||||
metaTitle = json['meta_title'];
|
||||
allowCustomerReviews = json['allow_customer_reviews'];
|
||||
approvedRatingSum = json['approved_rating_sum'];
|
||||
notApprovedRatingSum = json['not_approved_rating_sum'];
|
||||
approvedTotalReviews = json['approved_total_reviews'];
|
||||
notApprovedTotalReviews = json['not_approved_total_reviews'];
|
||||
sku = json['sku'];
|
||||
isRx = json['is_rx'];
|
||||
prescriptionRequired = json['prescription_required'];
|
||||
rxMessage = json['rx_message'];
|
||||
rxMessagen = json['rx_messagen'];
|
||||
manufacturerPartNumber = json['manufacturer_part_number'];
|
||||
gtin = json['gtin'];
|
||||
isGiftCard = json['is_gift_card'];
|
||||
requireOtherProducts = json['require_other_products'];
|
||||
automaticallyAddRequiredProducts =
|
||||
json['automatically_add_required_products'];
|
||||
isDownload = json['is_download'];
|
||||
unlimitedDownloads = json['unlimited_downloads'];
|
||||
maxNumberOfDownloads = json['max_number_of_downloads'];
|
||||
downloadExpirationDays = json['download_expiration_days'];
|
||||
hasSampleDownload = json['has_sample_download'];
|
||||
hasUserAgreement = json['has_user_agreement'];
|
||||
isRecurring = json['is_recurring'];
|
||||
recurringCycleLength = json['recurring_cycle_length'];
|
||||
recurringTotalCycles = json['recurring_total_cycles'];
|
||||
isRental = json['is_rental'];
|
||||
rentalPriceLength = json['rental_price_length'];
|
||||
isShipEnabled = json['is_ship_enabled'];
|
||||
isFreeShipping = json['is_free_shipping'];
|
||||
shipSeparately = json['ship_separately'];
|
||||
additionalShippingCharge = json['additional_shipping_charge'];
|
||||
isTaxExempt = json['is_tax_exempt'];
|
||||
isTelecommunicationsOrBroadcastingOrElectronicServices =
|
||||
json['is_telecommunications_or_broadcasting_or_electronic_services'];
|
||||
useMultipleWarehouses = json['use_multiple_warehouses'];
|
||||
manageInventoryMethodId = json['manage_inventory_method_id'];
|
||||
stockQuantity = json['stock_quantity'];
|
||||
stockAvailability = json['stock_availability'];
|
||||
stockAvailabilityn = json['stock_availabilityn'];
|
||||
displayStockAvailability = json['display_stock_availability'];
|
||||
displayStockQuantity = json['display_stock_quantity'];
|
||||
minStockQuantity = json['min_stock_quantity'];
|
||||
notifyAdminForQuantityBelow = json['notify_admin_for_quantity_below'];
|
||||
allowBackInStockSubscriptions = json['allow_back_in_stock_subscriptions'];
|
||||
orderMinimumQuantity = json['order_minimum_quantity'];
|
||||
orderMaximumQuantity = json['order_maximum_quantity'];
|
||||
allowedQuantities = json['allowed_quantities'];
|
||||
allowAddingOnlyExistingAttributeCombinations =
|
||||
json['allow_adding_only_existing_attribute_combinations'];
|
||||
disableBuyButton = json['disable_buy_button'];
|
||||
disableWishlistButton = json['disable_wishlist_button'];
|
||||
availableForPreOrder = json['available_for_pre_order'];
|
||||
preOrderAvailabilityStartDateTimeUtc =
|
||||
json['pre_order_availability_start_date_time_utc'];
|
||||
callForPrice = json['call_for_price'];
|
||||
price = json['price'];
|
||||
oldPrice = json['old_price'];
|
||||
productCost = json['product_cost'];
|
||||
specialPrice = json['special_price'];
|
||||
specialPriceStartDateTimeUtc = json['special_price_start_date_time_utc'];
|
||||
specialPriceEndDateTimeUtc = json['special_price_end_date_time_utc'];
|
||||
customerEntersPrice = json['customer_enters_price'];
|
||||
minimumCustomerEnteredPrice = json['minimum_customer_entered_price'];
|
||||
maximumCustomerEnteredPrice = json['maximum_customer_entered_price'];
|
||||
basepriceEnabled = json['baseprice_enabled'];
|
||||
basepriceAmount = json['baseprice_amount'];
|
||||
basepriceBaseAmount = json['baseprice_base_amount'];
|
||||
hasTierPrices = json['has_tier_prices'];
|
||||
hasDiscountsApplied = json['has_discounts_applied'];
|
||||
discountName = json['discount_name'];
|
||||
discountNamen = json['discount_namen'];
|
||||
discountDescription = json['discount_description'];
|
||||
discountDescriptionn = json['discount_Descriptionn'];
|
||||
discountPercentage = json['discount_percentage'];
|
||||
currency = json['currency'];
|
||||
currencyn = json['currencyn'];
|
||||
weight = json['weight'];
|
||||
length = json['length'];
|
||||
width = json['width'];
|
||||
height = json['height'];
|
||||
availableStartDateTimeUtc = json['available_start_date_time_utc'];
|
||||
availableEndDateTimeUtc = json['available_end_date_time_utc'];
|
||||
displayOrder = json['display_order'];
|
||||
published = json['published'];
|
||||
deleted = json['deleted'];
|
||||
createdOnUtc = json['created_on_utc'];
|
||||
updatedOnUtc = json['updated_on_utc'];
|
||||
productType = json['product_type'];
|
||||
parentGroupedProductId = json['parent_grouped_product_id'];
|
||||
|
||||
manufacturerIds = json['manufacturer_ids'].cast<int>();
|
||||
|
||||
if (json['specifications'] != null) {
|
||||
specifications = new List<Specifications>();
|
||||
json['specifications'].forEach((v) {
|
||||
specifications.add(new Specifications.fromJson(v));
|
||||
});
|
||||
}
|
||||
|
||||
vendorId = json['vendor_id'];
|
||||
seName = json['se_name'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['id'] = this.id;
|
||||
data['visible_individually'] = this.visibleIndividually;
|
||||
data['name'] = this.name;
|
||||
data['namen'] = this.namen;
|
||||
if (this.localizedNames != null) {
|
||||
data['localized_names'] =
|
||||
this.localizedNames.map((v) => v.toJson()).toList();
|
||||
}
|
||||
data['short_description'] = this.shortDescription;
|
||||
data['short_descriptionn'] = this.shortDescriptionn;
|
||||
data['full_description'] = this.fullDescription;
|
||||
data['full_descriptionn'] = this.fullDescriptionn;
|
||||
data['markas_new'] = this.markasNew;
|
||||
data['show_on_home_page'] = this.showOnHomePage;
|
||||
data['meta_keywords'] = this.metaKeywords;
|
||||
data['meta_description'] = this.metaDescription;
|
||||
data['meta_title'] = this.metaTitle;
|
||||
data['allow_customer_reviews'] = this.allowCustomerReviews;
|
||||
data['approved_rating_sum'] = this.approvedRatingSum;
|
||||
data['not_approved_rating_sum'] = this.notApprovedRatingSum;
|
||||
data['approved_total_reviews'] = this.approvedTotalReviews;
|
||||
data['not_approved_total_reviews'] = this.notApprovedTotalReviews;
|
||||
data['sku'] = this.sku;
|
||||
data['is_rx'] = this.isRx;
|
||||
data['prescription_required'] = this.prescriptionRequired;
|
||||
data['rx_message'] = this.rxMessage;
|
||||
data['rx_messagen'] = this.rxMessagen;
|
||||
data['manufacturer_part_number'] = this.manufacturerPartNumber;
|
||||
data['gtin'] = this.gtin;
|
||||
data['is_gift_card'] = this.isGiftCard;
|
||||
data['require_other_products'] = this.requireOtherProducts;
|
||||
data['automatically_add_required_products'] =
|
||||
this.automaticallyAddRequiredProducts;
|
||||
data['is_download'] = this.isDownload;
|
||||
data['unlimited_downloads'] = this.unlimitedDownloads;
|
||||
data['max_number_of_downloads'] = this.maxNumberOfDownloads;
|
||||
data['download_expiration_days'] = this.downloadExpirationDays;
|
||||
data['has_sample_download'] = this.hasSampleDownload;
|
||||
data['has_user_agreement'] = this.hasUserAgreement;
|
||||
data['is_recurring'] = this.isRecurring;
|
||||
data['recurring_cycle_length'] = this.recurringCycleLength;
|
||||
data['recurring_total_cycles'] = this.recurringTotalCycles;
|
||||
data['is_rental'] = this.isRental;
|
||||
data['rental_price_length'] = this.rentalPriceLength;
|
||||
data['is_ship_enabled'] = this.isShipEnabled;
|
||||
data['is_free_shipping'] = this.isFreeShipping;
|
||||
data['ship_separately'] = this.shipSeparately;
|
||||
data['additional_shipping_charge'] = this.additionalShippingCharge;
|
||||
data['is_tax_exempt'] = this.isTaxExempt;
|
||||
data['is_telecommunications_or_broadcasting_or_electronic_services'] =
|
||||
this.isTelecommunicationsOrBroadcastingOrElectronicServices;
|
||||
data['use_multiple_warehouses'] = this.useMultipleWarehouses;
|
||||
data['manage_inventory_method_id'] = this.manageInventoryMethodId;
|
||||
data['stock_quantity'] = this.stockQuantity;
|
||||
data['stock_availability'] = this.stockAvailability;
|
||||
data['stock_availabilityn'] = this.stockAvailabilityn;
|
||||
data['display_stock_availability'] = this.displayStockAvailability;
|
||||
data['display_stock_quantity'] = this.displayStockQuantity;
|
||||
data['min_stock_quantity'] = this.minStockQuantity;
|
||||
data['notify_admin_for_quantity_below'] = this.notifyAdminForQuantityBelow;
|
||||
data['allow_back_in_stock_subscriptions'] =
|
||||
this.allowBackInStockSubscriptions;
|
||||
data['order_minimum_quantity'] = this.orderMinimumQuantity;
|
||||
data['order_maximum_quantity'] = this.orderMaximumQuantity;
|
||||
data['allowed_quantities'] = this.allowedQuantities;
|
||||
data['allow_adding_only_existing_attribute_combinations'] =
|
||||
this.allowAddingOnlyExistingAttributeCombinations;
|
||||
data['disable_buy_button'] = this.disableBuyButton;
|
||||
data['disable_wishlist_button'] = this.disableWishlistButton;
|
||||
data['available_for_pre_order'] = this.availableForPreOrder;
|
||||
data['pre_order_availability_start_date_time_utc'] =
|
||||
this.preOrderAvailabilityStartDateTimeUtc;
|
||||
data['call_for_price'] = this.callForPrice;
|
||||
data['price'] = this.price;
|
||||
data['old_price'] = this.oldPrice;
|
||||
data['product_cost'] = this.productCost;
|
||||
data['special_price'] = this.specialPrice;
|
||||
data['special_price_start_date_time_utc'] =
|
||||
this.specialPriceStartDateTimeUtc;
|
||||
data['special_price_end_date_time_utc'] = this.specialPriceEndDateTimeUtc;
|
||||
data['customer_enters_price'] = this.customerEntersPrice;
|
||||
data['minimum_customer_entered_price'] = this.minimumCustomerEnteredPrice;
|
||||
data['maximum_customer_entered_price'] = this.maximumCustomerEnteredPrice;
|
||||
data['baseprice_enabled'] = this.basepriceEnabled;
|
||||
data['baseprice_amount'] = this.basepriceAmount;
|
||||
data['baseprice_base_amount'] = this.basepriceBaseAmount;
|
||||
data['has_tier_prices'] = this.hasTierPrices;
|
||||
data['has_discounts_applied'] = this.hasDiscountsApplied;
|
||||
data['discount_name'] = this.discountName;
|
||||
data['discount_namen'] = this.discountNamen;
|
||||
data['discount_description'] = this.discountDescription;
|
||||
data['discount_Descriptionn'] = this.discountDescriptionn;
|
||||
data['discount_percentage'] = this.discountPercentage;
|
||||
data['currency'] = this.currency;
|
||||
data['currencyn'] = this.currencyn;
|
||||
data['weight'] = this.weight;
|
||||
data['length'] = this.length;
|
||||
data['width'] = this.width;
|
||||
data['height'] = this.height;
|
||||
data['available_start_date_time_utc'] = this.availableStartDateTimeUtc;
|
||||
data['available_end_date_time_utc'] = this.availableEndDateTimeUtc;
|
||||
data['display_order'] = this.displayOrder;
|
||||
data['published'] = this.published;
|
||||
data['deleted'] = this.deleted;
|
||||
data['created_on_utc'] = this.createdOnUtc;
|
||||
data['updated_on_utc'] = this.updatedOnUtc;
|
||||
data['product_type'] = this.productType;
|
||||
data['parent_grouped_product_id'] = this.parentGroupedProductId;
|
||||
|
||||
data['manufacturer_ids'] = this.manufacturerIds;
|
||||
|
||||
if (this.specifications != null) {
|
||||
data['specifications'] =
|
||||
this.specifications.map((v) => v.toJson()).toList();
|
||||
}
|
||||
|
||||
data['vendor_id'] = this.vendorId;
|
||||
data['se_name'] = this.seName;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class LocalizedNames {
|
||||
int languageId;
|
||||
String localizedName;
|
||||
|
||||
LocalizedNames({this.languageId, this.localizedName});
|
||||
|
||||
LocalizedNames.fromJson(Map<String, dynamic> json) {
|
||||
languageId = json['language_id'];
|
||||
localizedName = json['localized_name'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['language_id'] = this.languageId;
|
||||
data['localized_name'] = this.localizedName;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class Images {
|
||||
int id;
|
||||
int position;
|
||||
String src;
|
||||
String thumb;
|
||||
String attachment;
|
||||
|
||||
Images({this.id, this.position, this.src, this.thumb, this.attachment});
|
||||
|
||||
Images.fromJson(Map<String, dynamic> json) {
|
||||
id = json['id'];
|
||||
position = json['position'];
|
||||
src = json['src'];
|
||||
thumb = json['thumb'];
|
||||
attachment = json['attachment'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['id'] = this.id;
|
||||
data['position'] = this.position;
|
||||
data['src'] = this.src;
|
||||
data['thumb'] = this.thumb;
|
||||
data['attachment'] = this.attachment;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class Specifications {
|
||||
int id;
|
||||
int displayOrder;
|
||||
String defaultValue;
|
||||
String defaultValuen;
|
||||
String name;
|
||||
String nameN;
|
||||
|
||||
Specifications(
|
||||
{this.id,
|
||||
this.displayOrder,
|
||||
this.defaultValue,
|
||||
this.defaultValuen,
|
||||
this.name,
|
||||
this.nameN});
|
||||
|
||||
Specifications.fromJson(Map<String, dynamic> json) {
|
||||
id = json['id'];
|
||||
displayOrder = json['display_order'];
|
||||
defaultValue = json['default_value'];
|
||||
defaultValuen = json['default_valuen'];
|
||||
name = json['name'];
|
||||
nameN = json['nameN'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['id'] = this.id;
|
||||
data['display_order'] = this.displayOrder;
|
||||
data['default_value'] = this.defaultValue;
|
||||
data['default_valuen'] = this.defaultValuen;
|
||||
data['name'] = this.name;
|
||||
data['nameN'] = this.nameN;
|
||||
return data;
|
||||
}
|
||||
}
|
@ -0,0 +1,510 @@
|
||||
import 'package:diplomaticquarterapp/core/viewModels/pharmacy_categorise_view_model.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/data_display/text.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/others/StarRating.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/others/app_scaffold_pharmacy_widget.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/others/network_base_view.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
import 'base/base_view.dart';
|
||||
|
||||
class FinalProductsPage extends StatelessWidget {
|
||||
String id;
|
||||
FinalProductsPage({this.id});
|
||||
String categoriseName = "Personal Care";
|
||||
bool styleOne = true;
|
||||
bool styleTwo = false;
|
||||
Icon styleIcon = Icon(
|
||||
Icons.widgets_sharp,
|
||||
color: Colors.blue,
|
||||
size: 29.0,
|
||||
);
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return BaseView<PharmacyCategoriseViewModel>(
|
||||
onModelReady: (model) => model.getFinalProducts(i: id),
|
||||
builder: (BuildContext context, PharmacyCategoriseViewModel model,
|
||||
Widget child) =>
|
||||
PharmacyAppScaffold(
|
||||
appBarTitle: 'Products',
|
||||
isBottomBar: false,
|
||||
isShowAppBar: true,
|
||||
backgroundColor: Colors.white,
|
||||
isShowDecPage: false,
|
||||
baseViewModel: model,
|
||||
body: Container(
|
||||
height: MediaQuery.of(context).size.height * 1.87,
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
//Expanded widget heree if nassery
|
||||
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.all(8.0),
|
||||
child: Texts(
|
||||
'Products',
|
||||
fontWeight: FontWeight.w600,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
Container(
|
||||
height: 44.0,
|
||||
child: VerticalDivider(
|
||||
color: Colors.black45,
|
||||
thickness: 1.0,
|
||||
//width: 0.3,
|
||||
// indent: 0.0,
|
||||
),
|
||||
),
|
||||
Padding(
|
||||
padding: EdgeInsets.all(8.0),
|
||||
child: InkWell(
|
||||
child: styleIcon,
|
||||
onTap: () {
|
||||
if (styleOne == true) {
|
||||
styleOne = false;
|
||||
styleTwo = true;
|
||||
styleIcon = Icon(
|
||||
Icons.auto_awesome_mosaic,
|
||||
color: Colors.blue,
|
||||
size: 29.0,
|
||||
);
|
||||
} else {
|
||||
styleOne = true;
|
||||
styleTwo = false;
|
||||
styleIcon = Icon(
|
||||
Icons.widgets_sharp,
|
||||
color: Colors.blue,
|
||||
size: 29.0,
|
||||
);
|
||||
}
|
||||
},
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
Divider(
|
||||
thickness: 1.0,
|
||||
color: Colors.grey.shade400,
|
||||
),
|
||||
styleOne == true
|
||||
? Expanded(
|
||||
child: Container(
|
||||
height: MediaQuery.of(context).size.height * 1.90,
|
||||
child: GridView.builder(
|
||||
gridDelegate:
|
||||
SliverGridDelegateWithFixedCrossAxisCount(
|
||||
crossAxisCount: 2,
|
||||
crossAxisSpacing: 0.5,
|
||||
mainAxisSpacing: 2.0,
|
||||
childAspectRatio: 1.0,
|
||||
),
|
||||
itemCount: model.finalProducts.length,
|
||||
itemBuilder: (BuildContext context, int index) {
|
||||
return NetworkBaseView(
|
||||
baseViewModel: model,
|
||||
child: Card(
|
||||
color: model.finalProducts[index]
|
||||
.discountName !=
|
||||
null
|
||||
? Color(0xffFFFF00)
|
||||
: Colors.white,
|
||||
elevation: 0,
|
||||
shape: Border(
|
||||
right: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
left: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
bottom: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
top: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
),
|
||||
margin: EdgeInsets.symmetric(
|
||||
horizontal: 8,
|
||||
vertical: 4,
|
||||
),
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.only(
|
||||
topLeft: Radius.circular(110.0),
|
||||
),
|
||||
color: Colors.white,
|
||||
),
|
||||
padding: EdgeInsets.symmetric(
|
||||
horizontal: 0),
|
||||
width: MediaQuery.of(context)
|
||||
.size
|
||||
.width /
|
||||
3,
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
Stack(
|
||||
children: [
|
||||
Container(
|
||||
margin: EdgeInsets.fromLTRB(
|
||||
0, 16, 0, 0),
|
||||
alignment: Alignment.center,
|
||||
child: Image.network(
|
||||
model.finalProducts[index]
|
||||
.images.isNotEmpty
|
||||
? model
|
||||
.finalProducts[
|
||||
index]
|
||||
.images[0]
|
||||
.thumb
|
||||
: 'https://upload.wikimedia.org/wikipedia/commons/thumb/6/6c/No_image_3x4.svg/1200px-No_image_3x4.svg.png',
|
||||
fit: BoxFit.cover,
|
||||
height: 80,
|
||||
),
|
||||
),
|
||||
Container(
|
||||
width: model
|
||||
.finalProducts[
|
||||
index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? MediaQuery.of(context)
|
||||
.size
|
||||
.width /
|
||||
2.8
|
||||
: 0,
|
||||
padding: EdgeInsets.all(4),
|
||||
decoration: BoxDecoration(
|
||||
color: Color(0xffb23838),
|
||||
borderRadius:
|
||||
BorderRadius.only(
|
||||
topLeft: Radius
|
||||
.circular(6)),
|
||||
),
|
||||
child: Texts(
|
||||
model.finalProducts[index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? model
|
||||
.finalProducts[
|
||||
index]
|
||||
.rxMessage
|
||||
: "",
|
||||
color: Colors.white,
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w600,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(
|
||||
horizontal: 6,
|
||||
vertical: 0,
|
||||
),
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
if (model
|
||||
.finalProducts[
|
||||
index]
|
||||
.discountName !=
|
||||
null)
|
||||
Container(
|
||||
width: double.infinity,
|
||||
height: 13.0,
|
||||
decoration:
|
||||
BoxDecoration(
|
||||
color:
|
||||
Color(0xff5AB145),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts(
|
||||
model
|
||||
.finalProducts[
|
||||
index]
|
||||
.discountName,
|
||||
regular: true,
|
||||
color: Colors.white,
|
||||
fontSize: 10.4,
|
||||
),
|
||||
),
|
||||
),
|
||||
Texts(
|
||||
model.finalProducts[index]
|
||||
.name,
|
||||
regular: true,
|
||||
fontSize: 12,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
),
|
||||
Padding(
|
||||
padding:
|
||||
const EdgeInsets.only(
|
||||
top: 4,
|
||||
bottom: 4),
|
||||
child: Texts(
|
||||
"SAR ${model.finalProducts[index].price}",
|
||||
bold: true,
|
||||
fontSize: 14,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
StarRating(
|
||||
totalAverage: model
|
||||
.finalProducts[
|
||||
index]
|
||||
.approvedRatingSum >
|
||||
0
|
||||
? (model.finalProducts[index].approvedRatingSum
|
||||
.toDouble() /
|
||||
model
|
||||
.finalProducts[index]
|
||||
.approvedRatingSum
|
||||
.toDouble())
|
||||
.toDouble()
|
||||
: 0,
|
||||
forceStars: true),
|
||||
Texts(
|
||||
"(${model.finalProducts[index].approvedTotalReviews})",
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
)
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
));
|
||||
},
|
||||
),
|
||||
),
|
||||
)
|
||||
: Expanded(
|
||||
child: Container(
|
||||
child: ListView.builder(
|
||||
itemCount: model.finalProducts.length,
|
||||
itemBuilder:
|
||||
(BuildContext context, int index) {
|
||||
return Card(
|
||||
// color:
|
||||
// model.products[index].discountName !=
|
||||
// null
|
||||
// ? Color(0xffFFFF00)
|
||||
// : Colors.white,
|
||||
child: Row(
|
||||
children: [
|
||||
Stack(
|
||||
children: [
|
||||
Column(
|
||||
children: [
|
||||
if (model.finalProducts[index]
|
||||
.discountName !=
|
||||
null)
|
||||
Container(
|
||||
decoration:
|
||||
BoxDecoration(),
|
||||
child: Padding(
|
||||
padding:
|
||||
EdgeInsets.only(
|
||||
left: 9.0,
|
||||
top: 8.0,
|
||||
right: 10.0,
|
||||
),
|
||||
child: Container(
|
||||
color: Colors.yellow,
|
||||
height: 25.0,
|
||||
width: 70.0,
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'offer'
|
||||
.toUpperCase(),
|
||||
color: Colors.red,
|
||||
fontSize: 13.0,
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w900,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
transform:
|
||||
new Matrix4.rotationZ(
|
||||
6.15099),
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.fromLTRB(
|
||||
0, 0, 0, 0),
|
||||
alignment: Alignment.center,
|
||||
child: Image.network(
|
||||
model.finalProducts[index]
|
||||
.images[index].thumb,
|
||||
fit: BoxFit.cover,
|
||||
height: 80,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Column(
|
||||
children: [
|
||||
Container(
|
||||
width: model
|
||||
.finalProducts[
|
||||
index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? MediaQuery.of(context)
|
||||
.size
|
||||
.width /
|
||||
5
|
||||
: 0,
|
||||
padding: EdgeInsets.all(4),
|
||||
decoration: BoxDecoration(
|
||||
color: Color(0xffb23838),
|
||||
borderRadius:
|
||||
BorderRadius.only(
|
||||
topLeft: Radius
|
||||
.circular(6)),
|
||||
),
|
||||
child: Texts(
|
||||
model.finalProducts[index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? model
|
||||
.finalProducts[
|
||||
index]
|
||||
.rxMessage
|
||||
: "",
|
||||
color: Colors.white,
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(
|
||||
horizontal: 6,
|
||||
vertical: 0,
|
||||
),
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
if (model.finalProducts[index]
|
||||
.discountName !=
|
||||
null)
|
||||
Container(
|
||||
width: 250.0,
|
||||
height: 18.5,
|
||||
decoration: BoxDecoration(
|
||||
color: Color(0xff5AB145),
|
||||
),
|
||||
child: Padding(
|
||||
padding:
|
||||
EdgeInsets.symmetric(
|
||||
horizontal: 5.5,
|
||||
),
|
||||
child: Texts(
|
||||
model
|
||||
.finalProducts[
|
||||
index]
|
||||
.discountName,
|
||||
regular: true,
|
||||
color: Colors.white,
|
||||
fontSize: 11.4,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 4.0,
|
||||
),
|
||||
Texts(
|
||||
model.finalProducts[index]
|
||||
.name,
|
||||
regular: true,
|
||||
fontSize: 12,
|
||||
fontWeight: FontWeight.w400,
|
||||
),
|
||||
SizedBox(
|
||||
height: 8.0,
|
||||
),
|
||||
Padding(
|
||||
padding:
|
||||
const EdgeInsets.only(
|
||||
top: 4, bottom: 4),
|
||||
child: Texts(
|
||||
"SAR ${model.finalProducts[index].price}",
|
||||
bold: true,
|
||||
fontSize: 14,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
StarRating(
|
||||
totalAverage: model
|
||||
.finalProducts[
|
||||
index]
|
||||
.approvedRatingSum >
|
||||
0
|
||||
? (model
|
||||
.finalProducts[
|
||||
index]
|
||||
.approvedRatingSum
|
||||
.toDouble() /
|
||||
model
|
||||
.finalProducts[
|
||||
index]
|
||||
.approvedRatingSum
|
||||
.toDouble())
|
||||
.toDouble()
|
||||
: 0,
|
||||
forceStars: true),
|
||||
Texts(
|
||||
"(${model.finalProducts[index].approvedTotalReviews})",
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
)
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
));
|
||||
}
|
||||
}
|
@ -0,0 +1,688 @@
|
||||
import 'package:diplomaticquarterapp/core/viewModels/pharmacy_categorise_view_model.dart';
|
||||
import 'package:diplomaticquarterapp/core/viewModels/project_view_model.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/data_display/text.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/others/StarRating.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/others/app_scaffold_pharmacy_widget.dart';
|
||||
import 'package:diplomaticquarterapp/widgets/others/network_base_view.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
import 'base/base_view.dart';
|
||||
import 'final_products_page.dart';
|
||||
|
||||
class SubCategorisePage extends StatelessWidget {
|
||||
String parentId;
|
||||
String id;
|
||||
String title;
|
||||
SubCategorisePage({this.id, this.title, this.parentId});
|
||||
|
||||
String categoriseName = "Personal Care";
|
||||
bool styleOne = true;
|
||||
bool styleTwo = false;
|
||||
Icon styleIcon = Icon(
|
||||
Icons.widgets_sharp,
|
||||
color: Colors.blue,
|
||||
size: 29.0,
|
||||
);
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
ProjectViewModel projectProvider = Provider.of(context);
|
||||
return BaseView<PharmacyCategoriseViewModel>(
|
||||
onModelReady: (model) => model.getSubCategorise(i: id),
|
||||
builder: (BuildContext context, PharmacyCategoriseViewModel model,
|
||||
Widget child) =>
|
||||
PharmacyAppScaffold(
|
||||
appBarTitle: title,
|
||||
isBottomBar: false,
|
||||
isShowAppBar: true,
|
||||
backgroundColor: Colors.white,
|
||||
isShowDecPage: false,
|
||||
baseViewModel: model,
|
||||
body: SingleChildScrollView(
|
||||
child: Container(
|
||||
height: MediaQuery.of(context).size.height * 2.97,
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
child: Image.network(
|
||||
parentId == '1'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089188_personal-care_2.png'
|
||||
: parentId == '2'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089189_skin-care_2.png'
|
||||
: parentId == '3'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089190_health-care_2.png'
|
||||
: parentId == '4'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089191_sexual-health_2.png'
|
||||
: parentId == '5'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089192_beauty_2.png'
|
||||
: parentId == '6'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089193_baby-child_2.png'
|
||||
: parentId == '7'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089194_vitamins-supplements_2.png'
|
||||
: parentId == '8'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089195_diet-nutrition_2.png'
|
||||
: parentId == '9'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089196_household_2.png'
|
||||
: parentId ==
|
||||
'10'
|
||||
? 'https://uat.hmgwebservices.com/epharmacy/content/images/thumbs/0089197_home-care-appliances_2.png'
|
||||
: '',
|
||||
fit: BoxFit.fill,
|
||||
height: 160.0,
|
||||
width: double.infinity),
|
||||
),
|
||||
if (model.subCategorise.length >= 8)
|
||||
Column(
|
||||
children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.all(10.0),
|
||||
child: Container(
|
||||
child: Texts(model.categoriseParent.length >= 8
|
||||
? 'View All Categories'
|
||||
: ''),
|
||||
),
|
||||
),
|
||||
Divider(
|
||||
thickness: 1.0,
|
||||
color: Colors.grey.shade400,
|
||||
),
|
||||
],
|
||||
),
|
||||
|
||||
//Expanded widget heree if nassery
|
||||
Padding(
|
||||
padding: EdgeInsets.only(top: 35.0),
|
||||
child: Container(
|
||||
height: MediaQuery.of(context).size.height * 0.2,
|
||||
child: Center(
|
||||
child: ListView.builder(
|
||||
scrollDirection: Axis.horizontal,
|
||||
itemCount: model.subCategorise.length,
|
||||
itemBuilder: (BuildContext context, int index) {
|
||||
return Padding(
|
||||
padding:
|
||||
EdgeInsets.symmetric(horizontal: 8.0),
|
||||
child: InkWell(
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.center,
|
||||
children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.symmetric(
|
||||
horizontal: 13.0),
|
||||
child: Container(
|
||||
height: 60.0,
|
||||
width: 65.0,
|
||||
decoration: BoxDecoration(
|
||||
shape: BoxShape.circle,
|
||||
color: Colors.orange.shade200
|
||||
.withOpacity(0.45),
|
||||
),
|
||||
child: Center(
|
||||
child: Icon(
|
||||
Icons.apps_sharp,
|
||||
size: 32.0,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
Container(
|
||||
width: MediaQuery.of(context)
|
||||
.size
|
||||
.width *
|
||||
0.17,
|
||||
height: MediaQuery.of(context)
|
||||
.size
|
||||
.height *
|
||||
0.10,
|
||||
child: Center(
|
||||
child: Texts(
|
||||
model.subCategorise[index].name,
|
||||
fontSize: 14,
|
||||
fontWeight: FontWeight.w600,
|
||||
maxLines: 2,
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
onTap: () {
|
||||
Navigator.push(
|
||||
context,
|
||||
MaterialPageRoute(
|
||||
builder: (context) =>
|
||||
FinalProductsPage(
|
||||
id: model.subCategorise[index].id,
|
||||
),
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
);
|
||||
}),
|
||||
),
|
||||
),
|
||||
),
|
||||
|
||||
Divider(
|
||||
thickness: 1.0,
|
||||
color: Colors.grey.shade400,
|
||||
),
|
||||
Padding(
|
||||
padding: EdgeInsets.symmetric(horizontal: 8.0),
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Row(
|
||||
children: [
|
||||
Icon(Icons.wrap_text),
|
||||
SizedBox(
|
||||
width: 10.0,
|
||||
),
|
||||
Texts('Refine'),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
Container(
|
||||
height: 44.0,
|
||||
child: VerticalDivider(
|
||||
color: Colors.black45,
|
||||
thickness: 1.0,
|
||||
//width: 0.3,
|
||||
// indent: 0.0,
|
||||
),
|
||||
),
|
||||
Padding(
|
||||
padding: EdgeInsets.all(8.0),
|
||||
child: InkWell(
|
||||
child: styleIcon,
|
||||
onTap: () {
|
||||
if (styleOne == true) {
|
||||
styleOne = false;
|
||||
styleTwo = true;
|
||||
styleIcon = Icon(
|
||||
Icons.auto_awesome_mosaic,
|
||||
color: Colors.blue,
|
||||
size: 29.0,
|
||||
);
|
||||
} else {
|
||||
styleOne = true;
|
||||
styleTwo = false;
|
||||
styleIcon = Icon(
|
||||
Icons.widgets_sharp,
|
||||
color: Colors.blue,
|
||||
size: 29.0,
|
||||
);
|
||||
}
|
||||
},
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
Divider(
|
||||
thickness: 1.0,
|
||||
color: Colors.grey.shade400,
|
||||
),
|
||||
styleOne == true
|
||||
? Container(
|
||||
height: MediaQuery.of(context).size.height * 1.85,
|
||||
child: GridView.builder(
|
||||
physics: NeverScrollableScrollPhysics(),
|
||||
gridDelegate:
|
||||
SliverGridDelegateWithFixedCrossAxisCount(
|
||||
crossAxisCount: 2,
|
||||
crossAxisSpacing: 0.5,
|
||||
mainAxisSpacing: 2.0,
|
||||
childAspectRatio: 1.0,
|
||||
),
|
||||
itemCount: model.subProducts.length,
|
||||
itemBuilder: (BuildContext context, int index) {
|
||||
return NetworkBaseView(
|
||||
baseViewModel: model,
|
||||
child: Card(
|
||||
color: model.subProducts[index]
|
||||
.discountName !=
|
||||
null
|
||||
? Color(0xffFFFF00)
|
||||
: Colors.white,
|
||||
elevation: 0,
|
||||
shape: Border(
|
||||
right: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
left: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
bottom: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
top: BorderSide(
|
||||
color: Colors.grey.shade300,
|
||||
width: 1,
|
||||
),
|
||||
),
|
||||
margin: EdgeInsets.symmetric(
|
||||
horizontal: 8,
|
||||
vertical: 4,
|
||||
),
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.only(
|
||||
topLeft: Radius.circular(110.0),
|
||||
),
|
||||
color: Colors.white,
|
||||
),
|
||||
padding: EdgeInsets.symmetric(
|
||||
horizontal: 0),
|
||||
width: MediaQuery.of(context)
|
||||
.size
|
||||
.width /
|
||||
3,
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
Stack(
|
||||
children: [
|
||||
if (model.subProducts[index]
|
||||
.discountName !=
|
||||
null)
|
||||
RotatedBox(
|
||||
quarterTurns: 4,
|
||||
child: Container(
|
||||
decoration:
|
||||
BoxDecoration(),
|
||||
child: Padding(
|
||||
padding:
|
||||
EdgeInsets.only(
|
||||
right: 5.0,
|
||||
top: 20.0,
|
||||
bottom: 5.0,
|
||||
),
|
||||
child: Texts(
|
||||
'offer'
|
||||
.toUpperCase(),
|
||||
color: Colors.red,
|
||||
fontSize: 13.0,
|
||||
fontWeight:
|
||||
FontWeight.w900,
|
||||
),
|
||||
),
|
||||
transform: new Matrix4
|
||||
.rotationZ(
|
||||
5.837200),
|
||||
),
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.fromLTRB(
|
||||
0, 16, 0, 0),
|
||||
alignment: Alignment.center,
|
||||
child: Image.network(
|
||||
model.subProducts[index]
|
||||
.images.isNotEmpty
|
||||
? model
|
||||
.subProducts[
|
||||
index]
|
||||
.images[0]
|
||||
.thumb
|
||||
: 'https://upload.wikimedia.org/wikipedia/commons/thumb/6/6c/No_image_3x4.svg/1200px-No_image_3x4.svg.png',
|
||||
fit: BoxFit.cover,
|
||||
height: 80,
|
||||
),
|
||||
),
|
||||
Container(
|
||||
width: model
|
||||
.subProducts[
|
||||
index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? MediaQuery.of(context)
|
||||
.size
|
||||
.width /
|
||||
5
|
||||
: 0,
|
||||
padding: EdgeInsets.all(4),
|
||||
decoration: BoxDecoration(
|
||||
color: Color(0xffb23838),
|
||||
borderRadius:
|
||||
BorderRadius.only(
|
||||
topLeft: Radius
|
||||
.circular(6)),
|
||||
),
|
||||
child: Texts(
|
||||
model.subProducts[index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? model
|
||||
.subProducts[
|
||||
index]
|
||||
.rxMessage
|
||||
: "",
|
||||
color: Colors.white,
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(
|
||||
horizontal: 6,
|
||||
vertical: 0,
|
||||
),
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
if (model.subProducts[index]
|
||||
.discountName !=
|
||||
null)
|
||||
Container(
|
||||
width: double.infinity,
|
||||
height: 13.0,
|
||||
decoration:
|
||||
BoxDecoration(
|
||||
color:
|
||||
Color(0xff5AB145),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts(
|
||||
model
|
||||
.subProducts[
|
||||
index]
|
||||
.discountName,
|
||||
regular: true,
|
||||
color: Colors.white,
|
||||
fontSize: 10.4,
|
||||
),
|
||||
),
|
||||
),
|
||||
Texts(
|
||||
model.subProducts[index]
|
||||
.name,
|
||||
regular: true,
|
||||
fontSize: 12,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
),
|
||||
Padding(
|
||||
padding:
|
||||
const EdgeInsets.only(
|
||||
top: 4,
|
||||
bottom: 4),
|
||||
child: Texts(
|
||||
"SAR ${model.subProducts[index].price}",
|
||||
bold: true,
|
||||
fontSize: 14,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
StarRating(
|
||||
totalAverage: model
|
||||
.subProducts[
|
||||
index]
|
||||
.approvedRatingSum >
|
||||
0
|
||||
? (model.subProducts[index].approvedRatingSum
|
||||
.toDouble() /
|
||||
model
|
||||
.subProducts[index]
|
||||
.approvedRatingSum
|
||||
.toDouble())
|
||||
.toDouble()
|
||||
: 0,
|
||||
forceStars: true),
|
||||
Texts(
|
||||
"(${model.subProducts[index].approvedTotalReviews})",
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
)
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
));
|
||||
},
|
||||
),
|
||||
)
|
||||
: Expanded(
|
||||
child: Container(
|
||||
child: ListView.builder(
|
||||
itemCount: model.subProducts.length,
|
||||
itemBuilder:
|
||||
(BuildContext context, int index) {
|
||||
return Card(
|
||||
// color:
|
||||
// model.products[index].discountName !=
|
||||
// null
|
||||
// ? Color(0xffFFFF00)
|
||||
// : Colors.white,
|
||||
child: Row(
|
||||
children: [
|
||||
Stack(
|
||||
children: [
|
||||
Column(
|
||||
children: [
|
||||
if (model.subProducts[index]
|
||||
.discountName !=
|
||||
null)
|
||||
Container(
|
||||
decoration:
|
||||
BoxDecoration(),
|
||||
child: Padding(
|
||||
padding:
|
||||
EdgeInsets.only(
|
||||
left: 9.0,
|
||||
top: 8.0,
|
||||
right: 10.0,
|
||||
),
|
||||
child: Container(
|
||||
color:
|
||||
Colors.yellow,
|
||||
height: 25.0,
|
||||
width: 70.0,
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'offer'
|
||||
.toUpperCase(),
|
||||
color:
|
||||
Colors.red,
|
||||
fontSize: 13.0,
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w900,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
transform: new Matrix4
|
||||
.rotationZ(6.15099),
|
||||
),
|
||||
Container(
|
||||
margin:
|
||||
EdgeInsets.fromLTRB(
|
||||
0, 0, 0, 0),
|
||||
alignment:
|
||||
Alignment.center,
|
||||
child: Image.network(
|
||||
model
|
||||
.subProducts[index]
|
||||
.images[index]
|
||||
.thumb,
|
||||
fit: BoxFit.cover,
|
||||
height: 80,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Column(
|
||||
children: [
|
||||
Container(
|
||||
width: model
|
||||
.subProducts[
|
||||
index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? MediaQuery.of(
|
||||
context)
|
||||
.size
|
||||
.width /
|
||||
5
|
||||
: 0,
|
||||
padding:
|
||||
EdgeInsets.all(4),
|
||||
decoration: BoxDecoration(
|
||||
color:
|
||||
Color(0xffb23838),
|
||||
borderRadius:
|
||||
BorderRadius.only(
|
||||
topLeft: Radius
|
||||
.circular(
|
||||
6)),
|
||||
),
|
||||
child: Texts(
|
||||
model.subProducts[index]
|
||||
.rxMessage !=
|
||||
null
|
||||
? model
|
||||
.subProducts[
|
||||
index]
|
||||
.rxMessage
|
||||
: "",
|
||||
color: Colors.white,
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(
|
||||
horizontal: 6,
|
||||
vertical: 0,
|
||||
),
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
if (model.subProducts[index]
|
||||
.discountName !=
|
||||
null)
|
||||
Container(
|
||||
width: 250.0,
|
||||
height: 18.5,
|
||||
decoration: BoxDecoration(
|
||||
color:
|
||||
Color(0xff5AB145),
|
||||
),
|
||||
child: Padding(
|
||||
padding: EdgeInsets
|
||||
.symmetric(
|
||||
horizontal: 5.5,
|
||||
),
|
||||
child: Texts(
|
||||
model
|
||||
.subProducts[
|
||||
index]
|
||||
.discountName,
|
||||
regular: true,
|
||||
color: Colors.white,
|
||||
fontSize: 11.4,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 4.0,
|
||||
),
|
||||
Texts(
|
||||
projectProvider.isArabic
|
||||
? model
|
||||
.subProducts[index]
|
||||
.name
|
||||
: model
|
||||
.subProducts[index]
|
||||
.namen,
|
||||
regular: true,
|
||||
fontSize: 12,
|
||||
fontWeight: FontWeight.w400,
|
||||
),
|
||||
SizedBox(
|
||||
height: 8.0,
|
||||
),
|
||||
Padding(
|
||||
padding:
|
||||
const EdgeInsets.only(
|
||||
top: 4, bottom: 4),
|
||||
child: Texts(
|
||||
"SAR ${model.subProducts[index].price}",
|
||||
bold: true,
|
||||
fontSize: 14,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
StarRating(
|
||||
totalAverage: model
|
||||
.subProducts[
|
||||
index]
|
||||
.approvedRatingSum >
|
||||
0
|
||||
? (model
|
||||
.subProducts[
|
||||
index]
|
||||
.approvedRatingSum
|
||||
.toDouble() /
|
||||
model
|
||||
.subProducts[
|
||||
index]
|
||||
.approvedRatingSum
|
||||
.toDouble())
|
||||
.toDouble()
|
||||
: 0,
|
||||
forceStars: true),
|
||||
Texts(
|
||||
"(${model.subProducts[index].approvedTotalReviews})",
|
||||
regular: true,
|
||||
fontSize: 10,
|
||||
fontWeight:
|
||||
FontWeight.w400,
|
||||
)
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
));
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue