Webiant Logo Webiant Logo
  1. No results found.

    Try your search with a different keyword or use * as a wildcard.

InstallationService.cs

using System.Globalization;
using System.Text;
using Microsoft.Extensions.DependencyInjection;
using Nop.Core;
using Nop.Core.Domain;
using Nop.Core.Domain.Affiliates;
using Nop.Core.Domain.Blogs;
using Nop.Core.Domain.Catalog;
using Nop.Core.Domain.Cms;
using Nop.Core.Domain.Common;
using Nop.Core.Domain.Customers;
using Nop.Core.Domain.Directory;
using Nop.Core.Domain.Discounts;
using Nop.Core.Domain.Forums;
using Nop.Core.Domain.Gdpr;
using Nop.Core.Domain.Localization;
using Nop.Core.Domain.Logging;
using Nop.Core.Domain.Media;
using Nop.Core.Domain.Messages;
using Nop.Core.Domain.News;
using Nop.Core.Domain.Orders;
using Nop.Core.Domain.Payments;
using Nop.Core.Domain.Polls;
using Nop.Core.Domain.ScheduleTasks;
using Nop.Core.Domain.Security;
using Nop.Core.Domain.Seo;
using Nop.Core.Domain.Shipping;
using Nop.Core.Domain.Stores;
using Nop.Core.Domain.Tax;
using Nop.Core.Domain.Topics;
using Nop.Core.Domain.Vendors;
using Nop.Core.Http;
using Nop.Core.Infrastructure;
using Nop.Core.Security;
using Nop.Data;
using Nop.Services.Blogs;
using Nop.Services.Catalog;
using Nop.Services.Common;
using Nop.Services.Configuration;
using Nop.Services.Customers;
using Nop.Services.ExportImport;
using Nop.Services.Helpers;
using Nop.Services.Localization;
using Nop.Services.Media;
using Nop.Services.News;
using Nop.Services.Seo;

namespace Nop.Services.Installation
{
    /// 
    /// Installation service
    /// 
    public partial class InstallationService : IInstallationService
    {
        #region Fields

        protected readonly INopDataProvider _dataProvider;
        protected readonly INopFileProvider _fileProvider;
        protected readonly IRepository _activityLogTypeRepository;
        protected readonly IRepository
_addressRepository; protected readonly IRepository _categoryRepository; protected readonly IRepository _categoryTemplateRepository; protected readonly IRepository _countryRepository; protected readonly IRepository _currencyRepository; protected readonly IRepository _customerRepository; protected readonly IRepository _customerRoleRepository; protected readonly IRepository _deliveryDateRepository; protected readonly IRepository _emailAccountRepository; protected readonly IRepository _languageRepository; protected readonly IRepository _manufacturerRepository; protected readonly IRepository _manufacturerTemplateRepository; protected readonly IRepository _measureDimensionRepository; protected readonly IRepository _measureWeightRepository; protected readonly IRepository _productRepository; protected readonly IRepository _productAttributeRepository; protected readonly IRepository _productAvailabilityRangeRepository; protected readonly IRepository _productTagRepository; protected readonly IRepository _productTemplateRepository; protected readonly IRepository _specificationAttributeRepository; protected readonly IRepository _specificationAttributeOptionRepository; protected readonly IRepository _stateProvinceRepository; protected readonly IRepository _storeRepository; protected readonly IRepository _taxCategoryRepository; protected readonly IRepository _topicTemplateRepository; protected readonly IRepository _urlRecordRepository; protected readonly IWebHelper _webHelper; #endregion #region Ctor public InstallationService(INopDataProvider dataProvider, INopFileProvider fileProvider, IRepository activityLogTypeRepository, IRepository
addressRepository, IRepository categoryRepository, IRepository categoryTemplateRepository, IRepository countryRepository, IRepository currencyRepository, IRepository customerRepository, IRepository customerRoleRepository, IRepository deliveryDateRepository, IRepository emailAccountRepository, IRepository languageRepository, IRepository manufacturerRepository, IRepository manufacturerTemplateRepository, IRepository measureDimensionRepository, IRepository measureWeightRepository, IRepository productRepository, IRepository productAttributeRepository, IRepository productAvailabilityRangeRepository, IRepository productTagRepository, IRepository productTemplateRepository, IRepository specificationAttributeRepository, IRepository specificationAttributeOptionRepository, IRepository stateProvinceRepository, IRepository storeRepository, IRepository taxCategoryRepository, IRepository topicTemplateRepository, IRepository urlRecordRepository, IWebHelper webHelper) { _dataProvider = dataProvider; _fileProvider = fileProvider; _activityLogTypeRepository = activityLogTypeRepository; _addressRepository = addressRepository; _categoryRepository = categoryRepository; _categoryTemplateRepository = categoryTemplateRepository; _countryRepository = countryRepository; _currencyRepository = currencyRepository; _customerRepository = customerRepository; _customerRoleRepository = customerRoleRepository; _deliveryDateRepository = deliveryDateRepository; _emailAccountRepository = emailAccountRepository; _languageRepository = languageRepository; _manufacturerRepository = manufacturerRepository; _manufacturerTemplateRepository = manufacturerTemplateRepository; _measureDimensionRepository = measureDimensionRepository; _measureWeightRepository = measureWeightRepository; _productAttributeRepository = productAttributeRepository; _productAvailabilityRangeRepository = productAvailabilityRangeRepository; _productRepository = productRepository; _productTagRepository = productTagRepository; _productTemplateRepository = productTemplateRepository; _specificationAttributeRepository = specificationAttributeRepository; _specificationAttributeOptionRepository = specificationAttributeOptionRepository; _stateProvinceRepository = stateProvinceRepository; _storeRepository = storeRepository; _taxCategoryRepository = taxCategoryRepository; _topicTemplateRepository = topicTemplateRepository; _urlRecordRepository = urlRecordRepository; _webHelper = webHelper; } #endregion #region Utilities /// A task that represents the asynchronous operation protected virtual async Task InsertInstallationDataAsync(T entity) where T : BaseEntity { return await _dataProvider.InsertEntityAsync(entity); } /// A task that represents the asynchronous operation protected virtual async Task InsertInstallationDataAsync(params T[] entities) where T : BaseEntity { await _dataProvider.BulkInsertEntitiesAsync(entities); } /// A task that represents the asynchronous operation protected virtual async Task InsertInstallationDataAsync(IList entities) where T : BaseEntity { if (!entities.Any()) return; await InsertInstallationDataAsync(entities.ToArray()); } /// A task that represents the asynchronous operation protected virtual async Task UpdateInstallationDataAsync(T entity) where T : BaseEntity { await _dataProvider.UpdateEntityAsync(entity); } /// A task that represents the asynchronous operation protected virtual async Task UpdateInstallationDataAsync(IList entities) where T : BaseEntity { if (!entities.Any()) return; foreach (var entity in entities) await _dataProvider.UpdateEntityAsync(entity); } /// A task that represents the asynchronous operation protected virtual async Task GetSpecificationAttributeOptionIdAsync(string specAttributeName, string specAttributeOptionName) { var specificationAttribute = await _specificationAttributeRepository.Table .SingleAsync(sa => sa.Name == specAttributeName); var specificationAttributeOption = await _specificationAttributeOptionRepository.Table .SingleAsync(sao => sao.Name == specAttributeOptionName && sao.SpecificationAttributeId == specificationAttribute.Id); return specificationAttributeOption.Id; } /// /// /// /// /// /// /// /// A task that represents the asynchronous operation /// The task result contains the identifier of inserted picture /// protected virtual async Task InsertProductPictureAsync(Product product, string fileName, int displayOrder = 1) { var pictureService = EngineContext.Current.Resolve(); var sampleImagesPath = GetSamplesPath(); var pic = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, fileName)), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(product.Name)); await InsertInstallationDataAsync( new ProductPicture { ProductId = product.Id, PictureId = pic.Id, DisplayOrder = displayOrder }); return pic.Id; } /// A task that represents the asynchronous operation protected virtual async Task ValidateSeNameAsync(T entity, string seName) where T : BaseEntity { //duplicate of ValidateSeName method of \Nop.Services\Seo\UrlRecordService.cs (we cannot inject it here) ArgumentNullException.ThrowIfNull(entity); //validation var okChars = "abcdefghijklmnopqrstuvwxyz1234567890 _-"; seName = seName.Trim().ToLowerInvariant(); var sb = new StringBuilder(); foreach (var c in seName.ToCharArray()) { var c2 = c.ToString(); if (okChars.Contains(c2)) sb.Append(c2); } seName = sb.ToString(); seName = seName.Replace(" ", "-"); while (seName.Contains("--")) seName = seName.Replace("--", "-"); while (seName.Contains("__")) seName = seName.Replace("__", "_"); //max length seName = CommonHelper.EnsureMaximumLength(seName, NopSeoDefaults.SearchEngineNameLength); //ensure this seName is not reserved yet var i = 2; var tempSeName = seName; while (true) { //check whether such slug already exists (and that is not the current entity) var query = from ur in _urlRecordRepository.Table where tempSeName != null && ur.Slug == tempSeName select ur; var urlRecord = await query.FirstOrDefaultAsync(); var entityName = entity.GetType().Name; var reserved = urlRecord != null && !(urlRecord.EntityId == entity.Id && urlRecord.EntityName.Equals(entityName, StringComparison.InvariantCultureIgnoreCase)); if (!reserved) break; tempSeName = $"{seName}-{i}"; i++; } seName = tempSeName; return seName; } protected virtual string GetSamplesPath() { return _fileProvider.GetAbsolutePath(NopInstallationDefaults.SampleImagesPath); } /// A task that represents the asynchronous operation protected virtual async Task InstallStoresAsync() { var storeUrl = _webHelper.GetStoreLocation(); var stores = new List { new() { Name = "Your store name", DefaultTitle = "Your store", DefaultMetaKeywords = string.Empty, DefaultMetaDescription = string.Empty, HomepageTitle = "Home page title", HomepageDescription = "Home page description", Url = storeUrl, SslEnabled = _webHelper.IsCurrentConnectionSecured(), Hosts = "yourstore.com,www.yourstore.com", DisplayOrder = 1, //should we set some default company info? CompanyName = "Your company name", CompanyAddress = "your company country, state, zip, street, etc", CompanyPhoneNumber = "(123) 456-78901", CompanyVat = null } }; await InsertInstallationDataAsync(stores); } /// A task that represents the asynchronous operation protected virtual async Task InstallMeasuresAsync(RegionInfo regionInfo) { var isMetric = regionInfo?.IsMetric ?? false; var measureDimensions = new List { new() { Name = "inch(es)", SystemKeyword = "inches", Ratio = isMetric ? 39.3701M : 1M, DisplayOrder = isMetric ? 1 : 0 }, new() { Name = "feet", SystemKeyword = "feet", Ratio = isMetric ? 3.28084M : 0.08333333M, DisplayOrder = isMetric ? 1 : 0 }, new() { Name = "meter(s)", SystemKeyword = "meters", Ratio = isMetric ? 1M : 0.0254M, DisplayOrder = isMetric ? 0 : 1 }, new() { Name = "millimetre(s)", SystemKeyword = "millimetres", Ratio = isMetric ? 1000M : 25.4M, DisplayOrder = isMetric ? 0 : 1 } }; await InsertInstallationDataAsync(measureDimensions); var measureWeights = new List { new() { Name = "ounce(s)", SystemKeyword = "ounce", Ratio = isMetric ? 35.274M : 16M, DisplayOrder = isMetric ? 1 : 0 }, new() { Name = "lb(s)", SystemKeyword = "lb", Ratio = isMetric ? 2.20462M : 1M, DisplayOrder = isMetric ? 1 : 0 }, new() { Name = "kg(s)", SystemKeyword = "kg", Ratio = isMetric ? 1M : 0.45359237M, DisplayOrder = isMetric ? 0 : 1 }, new() { Name = "gram(s)", SystemKeyword = "grams", Ratio = isMetric ? 1000M : 453.59237M, DisplayOrder = isMetric ? 0 : 1 } }; await InsertInstallationDataAsync(measureWeights); } /// A task that represents the asynchronous operation protected virtual async Task InstallTaxCategoriesAsync() { var taxCategories = new List { new() {Name = "Books", DisplayOrder = 1}, new() {Name = "Electronics & Software", DisplayOrder = 5}, new() {Name = "Downloadable Products", DisplayOrder = 10}, new() {Name = "Jewelry", DisplayOrder = 15}, new() {Name = "Apparel", DisplayOrder = 20} }; await InsertInstallationDataAsync(taxCategories); } /// A task that represents the asynchronous operation protected virtual async Task InstallLanguagesAsync((string languagePackDownloadLink, int languagePackProgress) languagePackInfo, CultureInfo cultureInfo, RegionInfo regionInfo) { var localizationService = EngineContext.Current.Resolve(); var defaultCulture = new CultureInfo(NopCommonDefaults.DefaultLanguageCulture); var defaultLanguage = new Language { Name = defaultCulture.TwoLetterISOLanguageName.ToUpperInvariant(), LanguageCulture = defaultCulture.Name, UniqueSeoCode = defaultCulture.TwoLetterISOLanguageName, FlagImageFileName = $"{defaultCulture.Name.ToLowerInvariant()[^2..]}.png", Rtl = defaultCulture.TextInfo.IsRightToLeft, Published = true, DisplayOrder = 1 }; await InsertInstallationDataAsync(defaultLanguage); //Install locale resources for default culture var directoryPath = _fileProvider.MapPath(NopInstallationDefaults.LocalizationResourcesPath); var pattern = $"*.{NopInstallationDefaults.LocalizationResourcesFileExtension}"; foreach (var filePath in _fileProvider.EnumerateFiles(directoryPath, pattern)) { using var streamReader = new StreamReader(filePath); await localizationService.ImportResourcesFromXmlAsync(defaultLanguage, streamReader); } if (cultureInfo == null || regionInfo == null || cultureInfo.Name == NopCommonDefaults.DefaultLanguageCulture) return; var language = new Language { Name = cultureInfo.TwoLetterISOLanguageName.ToUpperInvariant(), LanguageCulture = cultureInfo.Name, UniqueSeoCode = cultureInfo.TwoLetterISOLanguageName, FlagImageFileName = $"{regionInfo.TwoLetterISORegionName.ToLowerInvariant()}.png", Rtl = cultureInfo.TextInfo.IsRightToLeft, Published = true, DisplayOrder = 2 }; await InsertInstallationDataAsync(language); if (string.IsNullOrEmpty(languagePackInfo.languagePackDownloadLink)) return; //download and import language pack try { var httpClientFactory = EngineContext.Current.Resolve(); var httpClient = httpClientFactory.CreateClient(NopHttpDefaults.DefaultHttpClient); await using var stream = await httpClient.GetStreamAsync(languagePackInfo.languagePackDownloadLink); using var streamReader = new StreamReader(stream); await localizationService.ImportResourcesFromXmlAsync(language, streamReader); //set this language as default language.DisplayOrder = 0; await UpdateInstallationDataAsync(language); //save progress for showing in admin panel (only for first start) await InsertInstallationDataAsync(new GenericAttribute { EntityId = language.Id, Key = NopCommonDefaults.LanguagePackProgressAttribute, KeyGroup = nameof(Language), Value = languagePackInfo.languagePackProgress.ToString(), StoreId = 0, CreatedOrUpdatedDateUTC = DateTime.UtcNow }); } catch { } } /// A task that represents the asynchronous operation protected virtual async Task InstallCurrenciesAsync(CultureInfo cultureInfo, RegionInfo regionInfo) { //set some currencies with a rate against the USD var defaultCurrencies = new List() { "USD", "AUD", "GBP", "CAD", "CNY", "EUR", "HKD", "JPY", "RUB", "SEK", "INR" }; var currencies = new List { new() { Name = "US Dollar", CurrencyCode = "USD", Rate = 1, DisplayLocale = "en-US", CustomFormatting = string.Empty, Published = true, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Australian Dollar", CurrencyCode = "AUD", Rate = 1.34M, DisplayLocale = "en-AU", CustomFormatting = string.Empty, Published = false, DisplayOrder = 2, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "British Pound", CurrencyCode = "GBP", Rate = 0.75M, DisplayLocale = "en-GB", CustomFormatting = string.Empty, Published = false, DisplayOrder = 3, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Canadian Dollar", CurrencyCode = "CAD", Rate = 1.32M, DisplayLocale = "en-CA", CustomFormatting = string.Empty, Published = false, DisplayOrder = 4, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Chinese Yuan Renminbi", CurrencyCode = "CNY", Rate = 6.43M, DisplayLocale = "zh-CN", CustomFormatting = string.Empty, Published = false, DisplayOrder = 5, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Euro", CurrencyCode = "EUR", Rate = 0.86M, DisplayLocale = string.Empty, CustomFormatting = $"{"\u20ac"}0.00", //euro symbol Published = false, DisplayOrder = 6, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Hong Kong Dollar", CurrencyCode = "HKD", Rate = 7.84M, DisplayLocale = "zh-HK", CustomFormatting = string.Empty, Published = false, DisplayOrder = 7, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Japanese Yen", CurrencyCode = "JPY", Rate = 110.45M, DisplayLocale = "ja-JP", CustomFormatting = string.Empty, Published = false, DisplayOrder = 8, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Russian Rouble", CurrencyCode = "RUB", Rate = 63.25M, DisplayLocale = "ru-RU", CustomFormatting = string.Empty, Published = false, DisplayOrder = 9, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }, new() { Name = "Swedish Krona", CurrencyCode = "SEK", Rate = 8.80M, DisplayLocale = "sv-SE", CustomFormatting = string.Empty, Published = false, DisplayOrder = 10, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding1 }, new() { Name = "Indian Rupee", CurrencyCode = "INR", Rate = 68.03M, DisplayLocale = "en-IN", CustomFormatting = string.Empty, Published = false, DisplayOrder = 12, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 } }; //set additional currency if (cultureInfo != null && regionInfo != null) { if (!defaultCurrencies.Contains(regionInfo.ISOCurrencySymbol)) { currencies.Add(new Currency { Name = regionInfo.CurrencyEnglishName, CurrencyCode = regionInfo.ISOCurrencySymbol, Rate = 1, DisplayLocale = cultureInfo.Name, CustomFormatting = string.Empty, Published = true, DisplayOrder = 0, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, RoundingType = RoundingType.Rounding001 }); } foreach (var currency in currencies.Where(currency => currency.CurrencyCode == regionInfo.ISOCurrencySymbol)) { currency.Published = true; currency.DisplayOrder = 0; } } await InsertInstallationDataAsync(currencies); } /// A task that represents the asynchronous operation protected virtual async Task InstallCountriesAndStatesAsync() { var countries = ISO3166.GetCollection().Select(country => new Country { Name = country.Name, AllowsBilling = true, AllowsShipping = true, TwoLetterIsoCode = country.Alpha2, ThreeLetterIsoCode = country.Alpha3, NumericIsoCode = country.NumericCode, SubjectToVat = country.SubjectToVat, DisplayOrder = country.NumericCode == 840 ? 1 : 100, Published = true }).ToList(); await InsertInstallationDataAsync(countries.ToArray()); //Import states for all countries var directoryPath = _fileProvider.MapPath(NopInstallationDefaults.LocalizationResourcesPath); var pattern = "*.txt"; //we use different scope to prevent creating wrong settings in DI, because the settings data not exists yet var serviceScopeFactory = EngineContext.Current.Resolve(); using var scope = serviceScopeFactory.CreateScope(); var importManager = EngineContext.Current.Resolve(scope); foreach (var filePath in _fileProvider.EnumerateFiles(directoryPath, pattern)) { await using var stream = new FileStream(filePath, FileMode.Open); await importManager.ImportStatesFromTxtAsync(stream, false); } } /// A task that represents the asynchronous operation protected virtual async Task InstallShippingMethodsAsync() { var shippingMethods = new List { new() { Name = "Ground", Description = "Shipping by land transport", DisplayOrder = 1 }, new() { Name = "Next Day Air", Description = "The one day air shipping", DisplayOrder = 2 }, new() { Name = "2nd Day Air", Description = "The two day air shipping", DisplayOrder = 3 } }; await InsertInstallationDataAsync(shippingMethods); } /// A task that represents the asynchronous operation protected virtual async Task InstallDeliveryDatesAsync() { var deliveryDates = new List { new() { Name = "1-2 days", DisplayOrder = 1 }, new() { Name = "3-5 days", DisplayOrder = 5 }, new() { Name = "1 week", DisplayOrder = 10 } }; await InsertInstallationDataAsync(deliveryDates); } /// A task that represents the asynchronous operation protected virtual async Task InstallProductAvailabilityRangesAsync() { var productAvailabilityRanges = new List { new() { Name = "2-4 days", DisplayOrder = 1 }, new() { Name = "7-10 days", DisplayOrder = 2 }, new() { Name = "2 weeks", DisplayOrder = 3 } }; await InsertInstallationDataAsync(productAvailabilityRanges); } /// A task that represents the asynchronous operation protected virtual async Task InstallSampleCustomersAsync() { var crRegistered = await _customerRoleRepository.Table .FirstOrDefaultAsync(customerRole => customerRole.SystemName == NopCustomerDefaults.RegisteredRoleName); ArgumentNullException.ThrowIfNull(crRegistered); //default store var defaultStore = await _storeRepository.Table.FirstOrDefaultAsync() ?? throw new Exception("No default store could be loaded"); var storeId = defaultStore.Id; //second user var secondUserEmail = "steve_gates@nopCommerce.com"; var secondUser = new Customer { CustomerGuid = Guid.NewGuid(), Email = secondUserEmail, Username = secondUserEmail, Active = true, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; var defaultSecondUserAddress = await InsertInstallationDataAsync( new Address { FirstName = "Steve", LastName = "Gates", PhoneNumber = "87654321", Email = secondUserEmail, FaxNumber = string.Empty, Company = "Steve Company", Address1 = "750 Bel Air Rd.", Address2 = string.Empty, City = "Los Angeles", StateProvinceId = _stateProvinceRepository.Table.FirstOrDefault(sp => sp.Name == "California")?.Id, CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "USA")?.Id, ZipPostalCode = "90077", CreatedOnUtc = DateTime.UtcNow }); secondUser.BillingAddressId = defaultSecondUserAddress.Id; secondUser.ShippingAddressId = defaultSecondUserAddress.Id; secondUser.FirstName = defaultSecondUserAddress.FirstName; secondUser.LastName = defaultSecondUserAddress.LastName; await InsertInstallationDataAsync(secondUser); await InsertInstallationDataAsync(new CustomerAddressMapping { CustomerId = secondUser.Id, AddressId = defaultSecondUserAddress.Id }); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerId = secondUser.Id, CustomerRoleId = crRegistered.Id }); //set customer password await InsertInstallationDataAsync(new CustomerPassword { CustomerId = secondUser.Id, Password = "123456", PasswordFormat = PasswordFormat.Clear, PasswordSalt = string.Empty, CreatedOnUtc = DateTime.UtcNow }); //third user var thirdUserEmail = "arthur_holmes@nopCommerce.com"; var thirdUser = new Customer { CustomerGuid = Guid.NewGuid(), Email = thirdUserEmail, Username = thirdUserEmail, Active = true, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; var defaultThirdUserAddress = await InsertInstallationDataAsync( new Address { FirstName = "Arthur", LastName = "Holmes", PhoneNumber = "111222333", Email = thirdUserEmail, FaxNumber = string.Empty, Company = "Holmes Company", Address1 = "221B Baker Street", Address2 = string.Empty, City = "London", CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "GBR")?.Id, ZipPostalCode = "NW1 6XE", CreatedOnUtc = DateTime.UtcNow }); thirdUser.BillingAddressId = defaultThirdUserAddress.Id; thirdUser.ShippingAddressId = defaultThirdUserAddress.Id; thirdUser.FirstName = defaultThirdUserAddress.FirstName; thirdUser.LastName = defaultThirdUserAddress.LastName; await InsertInstallationDataAsync(thirdUser); await InsertInstallationDataAsync(new CustomerAddressMapping { CustomerId = thirdUser.Id, AddressId = defaultThirdUserAddress.Id }); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerId = thirdUser.Id, CustomerRoleId = crRegistered.Id }); //set customer password await InsertInstallationDataAsync(new CustomerPassword { CustomerId = thirdUser.Id, Password = "123456", PasswordFormat = PasswordFormat.Clear, PasswordSalt = string.Empty, CreatedOnUtc = DateTime.UtcNow }); //fourth user var fourthUserEmail = "james_pan@nopCommerce.com"; var fourthUser = new Customer { CustomerGuid = Guid.NewGuid(), Email = fourthUserEmail, Username = fourthUserEmail, Active = true, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; var defaultFourthUserAddress = await InsertInstallationDataAsync( new Address { FirstName = "James", LastName = "Pan", PhoneNumber = "369258147", Email = fourthUserEmail, FaxNumber = string.Empty, Company = "Pan Company", Address1 = "St Katharine’s West 16", Address2 = string.Empty, City = "St Andrews", CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "GBR")?.Id, ZipPostalCode = "KY16 9AX", CreatedOnUtc = DateTime.UtcNow }); fourthUser.BillingAddressId = defaultFourthUserAddress.Id; fourthUser.ShippingAddressId = defaultFourthUserAddress.Id; fourthUser.FirstName = defaultFourthUserAddress.FirstName; fourthUser.LastName = defaultFourthUserAddress.LastName; await InsertInstallationDataAsync(fourthUser); await InsertInstallationDataAsync(new CustomerAddressMapping { CustomerId = fourthUser.Id, AddressId = defaultFourthUserAddress.Id }); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerId = fourthUser.Id, CustomerRoleId = crRegistered.Id }); //set customer password await InsertInstallationDataAsync(new CustomerPassword { CustomerId = fourthUser.Id, Password = "123456", PasswordFormat = PasswordFormat.Clear, PasswordSalt = string.Empty, CreatedOnUtc = DateTime.UtcNow }); //fifth user var fifthUserEmail = "brenda_lindgren@nopCommerce.com"; var fifthUser = new Customer { CustomerGuid = Guid.NewGuid(), Email = fifthUserEmail, Username = fifthUserEmail, Active = true, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; var defaultFifthUserAddress = await InsertInstallationDataAsync( new Address { FirstName = "Brenda", LastName = "Lindgren", PhoneNumber = "14785236", Email = fifthUserEmail, FaxNumber = string.Empty, Company = "Brenda Company", Address1 = "1249 Tongass Avenue, Suite B", Address2 = string.Empty, City = "Ketchikan", StateProvinceId = _stateProvinceRepository.Table.FirstOrDefault(sp => sp.Name == "Alaska")?.Id, CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "USA")?.Id, ZipPostalCode = "99901", CreatedOnUtc = DateTime.UtcNow }); fifthUser.BillingAddressId = defaultFifthUserAddress.Id; fifthUser.ShippingAddressId = defaultFifthUserAddress.Id; fifthUser.FirstName = defaultFifthUserAddress.FirstName; fifthUser.LastName = defaultFifthUserAddress.LastName; await InsertInstallationDataAsync(fifthUser); await InsertInstallationDataAsync(new CustomerAddressMapping { CustomerId = fifthUser.Id, AddressId = defaultFifthUserAddress.Id }); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerId = fifthUser.Id, CustomerRoleId = crRegistered.Id }); //set customer password await InsertInstallationDataAsync(new CustomerPassword { CustomerId = fifthUser.Id, Password = "123456", PasswordFormat = PasswordFormat.Clear, PasswordSalt = string.Empty, CreatedOnUtc = DateTime.UtcNow }); //sixth user var sixthUserEmail = "victoria_victoria@nopCommerce.com"; var sixthUser = new Customer { CustomerGuid = Guid.NewGuid(), Email = sixthUserEmail, Username = sixthUserEmail, Active = true, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; var defaultSixthUserAddress = await InsertInstallationDataAsync( new Address { FirstName = "Victoria", LastName = "Terces", PhoneNumber = "45612378", Email = sixthUserEmail, FaxNumber = string.Empty, Company = "Terces Company", Address1 = "201 1st Avenue South", Address2 = string.Empty, City = "Saskatoon", StateProvinceId = (await _stateProvinceRepository.Table.FirstOrDefaultAsync(sp => sp.Name == "Saskatchewan"))?.Id, CountryId = (await _countryRepository.Table.FirstOrDefaultAsync(c => c.ThreeLetterIsoCode == "CAN"))?.Id, ZipPostalCode = "S7K 1J9", CreatedOnUtc = DateTime.UtcNow }); sixthUser.BillingAddressId = defaultSixthUserAddress.Id; sixthUser.ShippingAddressId = defaultSixthUserAddress.Id; sixthUser.FirstName = defaultSixthUserAddress.FirstName; sixthUser.LastName = defaultSixthUserAddress.LastName; await InsertInstallationDataAsync(sixthUser); await InsertInstallationDataAsync(new CustomerAddressMapping { CustomerId = sixthUser.Id, AddressId = defaultSixthUserAddress.Id }); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerId = sixthUser.Id, CustomerRoleId = crRegistered.Id }); //set customer password await InsertInstallationDataAsync(new CustomerPassword { CustomerId = sixthUser.Id, Password = "123456", PasswordFormat = PasswordFormat.Clear, PasswordSalt = string.Empty, CreatedOnUtc = DateTime.UtcNow }); } /// A task that represents the asynchronous operation protected virtual async Task InstallCustomersAndUsersAsync(string defaultUserEmail, string defaultUserPassword) { var crAdministrators = new CustomerRole { Name = "Administrators", Active = true, IsSystemRole = true, SystemName = NopCustomerDefaults.AdministratorsRoleName }; var crForumModerators = new CustomerRole { Name = "Forum Moderators", Active = true, IsSystemRole = true, SystemName = NopCustomerDefaults.ForumModeratorsRoleName }; var crRegistered = new CustomerRole { Name = "Registered", Active = true, IsSystemRole = true, SystemName = NopCustomerDefaults.RegisteredRoleName }; var crGuests = new CustomerRole { Name = "Guests", Active = true, IsSystemRole = true, SystemName = NopCustomerDefaults.GuestsRoleName }; var crVendors = new CustomerRole { Name = "Vendors", Active = true, IsSystemRole = true, SystemName = NopCustomerDefaults.VendorsRoleName }; var customerRoles = new List { crAdministrators, crForumModerators, crRegistered, crGuests, crVendors }; await InsertInstallationDataAsync(customerRoles); //default store var defaultStore = await _storeRepository.Table.FirstOrDefaultAsync() ?? throw new Exception("No default store could be loaded"); var storeId = defaultStore.Id; //admin user var adminUser = new Customer { CustomerGuid = Guid.NewGuid(), Email = defaultUserEmail, Username = defaultUserEmail, Active = true, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; var defaultAdminUserAddress = await InsertInstallationDataAsync( new Address { FirstName = "John", LastName = "Smith", PhoneNumber = "12345678", Email = defaultUserEmail, FaxNumber = string.Empty, Company = "Nop Solutions Ltd", Address1 = "21 West 52nd Street", Address2 = string.Empty, City = "New York", StateProvinceId = _stateProvinceRepository.Table.FirstOrDefault(sp => sp.Name == "New York")?.Id, CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "USA")?.Id, ZipPostalCode = "10021", CreatedOnUtc = DateTime.UtcNow }); adminUser.BillingAddressId = defaultAdminUserAddress.Id; adminUser.ShippingAddressId = defaultAdminUserAddress.Id; adminUser.FirstName = defaultAdminUserAddress.FirstName; adminUser.LastName = defaultAdminUserAddress.LastName; await InsertInstallationDataAsync(adminUser); await InsertInstallationDataAsync(new CustomerAddressMapping { CustomerId = adminUser.Id, AddressId = defaultAdminUserAddress.Id }); await InsertInstallationDataAsync( new CustomerCustomerRoleMapping { CustomerId = adminUser.Id, CustomerRoleId = crAdministrators.Id }, new CustomerCustomerRoleMapping { CustomerId = adminUser.Id, CustomerRoleId = crForumModerators.Id }, new CustomerCustomerRoleMapping { CustomerId = adminUser.Id, CustomerRoleId = crRegistered.Id }); //set hashed admin password var customerRegistrationService = EngineContext.Current.Resolve(); await customerRegistrationService.ChangePasswordAsync(new ChangePasswordRequest(defaultUserEmail, false, PasswordFormat.Hashed, defaultUserPassword, null, NopCustomerServicesDefaults.DefaultHashedPasswordFormat)); //search engine (crawler) built-in user var searchEngineUser = new Customer { Email = "builtin@search_engine_record.com", CustomerGuid = Guid.NewGuid(), AdminComment = "Built-in system guest record used for requests from search engines.", Active = true, IsSystemAccount = true, SystemName = NopCustomerDefaults.SearchEngineCustomerName, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; await InsertInstallationDataAsync(searchEngineUser); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerRoleId = crGuests.Id, CustomerId = searchEngineUser.Id }); //built-in user for background tasks var backgroundTaskUser = new Customer { Email = "builtin@background-task-record.com", CustomerGuid = Guid.NewGuid(), AdminComment = "Built-in system record used for background tasks.", Active = true, IsSystemAccount = true, SystemName = NopCustomerDefaults.BackgroundTaskCustomerName, CreatedOnUtc = DateTime.UtcNow, LastActivityDateUtc = DateTime.UtcNow, RegisteredInStoreId = storeId }; await InsertInstallationDataAsync(backgroundTaskUser); await InsertInstallationDataAsync(new CustomerCustomerRoleMapping { CustomerId = backgroundTaskUser.Id, CustomerRoleId = crGuests.Id }); } /// A task that represents the asynchronous operation protected virtual async Task InstallOrdersAsync() { static Address cloneAddress(Address address) { var addr = new Address { FirstName = address.FirstName, LastName = address.LastName, Email = address.Email, Company = address.Company, CountryId = address.CountryId, StateProvinceId = address.StateProvinceId, County = address.County, City = address.City, Address1 = address.Address1, Address2 = address.Address2, ZipPostalCode = address.ZipPostalCode, PhoneNumber = address.PhoneNumber, FaxNumber = address.FaxNumber, CustomAttributes = address.CustomAttributes, CreatedOnUtc = address.CreatedOnUtc }; return addr; } //default store var defaultStore = await _storeRepository.Table.FirstOrDefaultAsync() ?? throw new Exception("No default store could be loaded"); //first order var firstCustomer = await _customerRepository.Table.FirstAsync(c => c.Email == "steve_gates@nopCommerce.com"); var firstCustomerBillingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(firstCustomer.BillingAddressId))); var firstCustomerShippingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(firstCustomer.ShippingAddressId))); var firstOrder = new Order { StoreId = defaultStore.Id, OrderGuid = Guid.NewGuid(), CustomerId = firstCustomer.Id, CustomerLanguageId = _languageRepository.Table.First().Id, CustomerIp = "127.0.0.1", OrderSubtotalInclTax = 1855M, OrderSubtotalExclTax = 1855M, OrderSubTotalDiscountInclTax = decimal.Zero, OrderSubTotalDiscountExclTax = decimal.Zero, OrderShippingInclTax = decimal.Zero, OrderShippingExclTax = decimal.Zero, PaymentMethodAdditionalFeeInclTax = decimal.Zero, PaymentMethodAdditionalFeeExclTax = decimal.Zero, TaxRates = "0:0;", OrderTax = decimal.Zero, OrderTotal = 1855M, RefundedAmount = decimal.Zero, OrderDiscount = decimal.Zero, CheckoutAttributeDescription = string.Empty, CheckoutAttributesXml = string.Empty, CustomerCurrencyCode = "USD", CurrencyRate = 1M, AffiliateId = 0, OrderStatus = OrderStatus.Processing, AllowStoringCreditCardNumber = false, CardType = string.Empty, CardName = string.Empty, CardNumber = string.Empty, MaskedCreditCardNumber = string.Empty, CardCvv2 = string.Empty, CardExpirationMonth = string.Empty, CardExpirationYear = string.Empty, PaymentMethodSystemName = "Payments.CheckMoneyOrder", AuthorizationTransactionId = string.Empty, AuthorizationTransactionCode = string.Empty, AuthorizationTransactionResult = string.Empty, CaptureTransactionId = string.Empty, CaptureTransactionResult = string.Empty, SubscriptionTransactionId = string.Empty, PaymentStatus = PaymentStatus.Paid, PaidDateUtc = DateTime.UtcNow, BillingAddressId = firstCustomerBillingAddress.Id, ShippingAddressId = firstCustomerShippingAddress.Id, ShippingStatus = ShippingStatus.NotYetShipped, ShippingMethod = "Ground", PickupInStore = false, ShippingRateComputationMethodSystemName = "Shipping.FixedByWeightByTotal", CustomValuesXml = string.Empty, VatNumber = string.Empty, CreatedOnUtc = DateTime.UtcNow, CustomOrderNumber = string.Empty }; await InsertInstallationDataAsync(firstOrder); firstOrder.CustomOrderNumber = firstOrder.Id.ToString(); await UpdateInstallationDataAsync(firstOrder); //item Apple iCam var firstOrderItem1 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = firstOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Apple iCam").Id, UnitPriceInclTax = 1300M, UnitPriceExclTax = 1300M, PriceInclTax = 1300M, PriceExclTax = 1300M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(firstOrderItem1); //item Leica T Mirrorless Digital Camera var firstOrderItem2 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = firstOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Leica T Mirrorless Digital Camera").Id, UnitPriceInclTax = 530M, UnitPriceExclTax = 530M, PriceInclTax = 530M, PriceExclTax = 530M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(firstOrderItem2); //item $25 Virtual Gift Card var firstOrderItem3 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = firstOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "$25 Virtual Gift Card").Id, UnitPriceInclTax = 25M, UnitPriceExclTax = 25M, PriceInclTax = 25M, PriceExclTax = 25M, OriginalProductCost = decimal.Zero, AttributeDescription = "From: Steve Gates <steve_gates@nopCommerce.com>
For: Brenda Lindgren <brenda_lindgren@nopCommerce.com>", AttributesXml = "Brenda Lindgrenbrenda_lindgren@nopCommerce.comSteve Gatessteve_gates@gmail.com", Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(firstOrderItem3); var firstOrderGiftcard = new GiftCard { GiftCardType = GiftCardType.Virtual, PurchasedWithOrderItemId = firstOrderItem3.Id, Amount = 25M, IsGiftCardActivated = false, GiftCardCouponCode = string.Empty, RecipientName = "Brenda Lindgren", RecipientEmail = "brenda_lindgren@nopCommerce.com", SenderName = "Steve Gates", SenderEmail = "steve_gates@nopCommerce.com", Message = string.Empty, IsRecipientNotified = false, CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(firstOrderGiftcard); //order notes await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order placed", OrderId = firstOrder.Id }); await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order paid", OrderId = firstOrder.Id }); //second order var secondCustomer = await _customerRepository.Table.FirstAsync(c => c.Email == "arthur_holmes@nopCommerce.com"); var secondCustomerBillingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(secondCustomer.BillingAddressId))); var secondCustomerShippingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(secondCustomer.ShippingAddressId))); var secondOrder = new Order { StoreId = defaultStore.Id, OrderGuid = Guid.NewGuid(), CustomerId = secondCustomer.Id, CustomerLanguageId = _languageRepository.Table.First().Id, CustomerIp = "127.0.0.1", OrderSubtotalInclTax = 2460M, OrderSubtotalExclTax = 2460M, OrderSubTotalDiscountInclTax = decimal.Zero, OrderSubTotalDiscountExclTax = decimal.Zero, OrderShippingInclTax = decimal.Zero, OrderShippingExclTax = decimal.Zero, PaymentMethodAdditionalFeeInclTax = decimal.Zero, PaymentMethodAdditionalFeeExclTax = decimal.Zero, TaxRates = "0:0;", OrderTax = decimal.Zero, OrderTotal = 2460M, RefundedAmount = decimal.Zero, OrderDiscount = decimal.Zero, CheckoutAttributeDescription = string.Empty, CheckoutAttributesXml = string.Empty, CustomerCurrencyCode = "USD", CurrencyRate = 1M, AffiliateId = 0, OrderStatus = OrderStatus.Pending, AllowStoringCreditCardNumber = false, CardType = string.Empty, CardName = string.Empty, CardNumber = string.Empty, MaskedCreditCardNumber = string.Empty, CardCvv2 = string.Empty, CardExpirationMonth = string.Empty, CardExpirationYear = string.Empty, PaymentMethodSystemName = "Payments.CheckMoneyOrder", AuthorizationTransactionId = string.Empty, AuthorizationTransactionCode = string.Empty, AuthorizationTransactionResult = string.Empty, CaptureTransactionId = string.Empty, CaptureTransactionResult = string.Empty, SubscriptionTransactionId = string.Empty, PaymentStatus = PaymentStatus.Pending, PaidDateUtc = null, BillingAddressId = secondCustomerBillingAddress.Id, ShippingAddressId = secondCustomerShippingAddress.Id, ShippingStatus = ShippingStatus.NotYetShipped, ShippingMethod = "Next Day Air", PickupInStore = false, ShippingRateComputationMethodSystemName = "Shipping.FixedByWeightByTotal", CustomValuesXml = string.Empty, VatNumber = string.Empty, CreatedOnUtc = DateTime.UtcNow, CustomOrderNumber = string.Empty }; await InsertInstallationDataAsync(secondOrder); secondOrder.CustomOrderNumber = secondOrder.Id.ToString(); await UpdateInstallationDataAsync(secondOrder); //order notes await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order placed", OrderId = secondOrder.Id }); //item Vintage Style Engagement Ring var secondOrderItem1 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = secondOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Vintage Style Engagement Ring").Id, UnitPriceInclTax = 2100M, UnitPriceExclTax = 2100M, PriceInclTax = 2100M, PriceExclTax = 2100M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(secondOrderItem1); //item Flower Girl Bracelet var secondOrderItem2 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = secondOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Flower Girl Bracelet").Id, UnitPriceInclTax = 360M, UnitPriceExclTax = 360M, PriceInclTax = 360M, PriceExclTax = 360M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(secondOrderItem2); //third order var thirdCustomer = await _customerRepository.Table.FirstAsync(c => c.Email == "james_pan@nopCommerce.com"); var thirdCustomerBillingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(thirdCustomer.BillingAddressId))); var thirdOrder = new Order { StoreId = defaultStore.Id, OrderGuid = Guid.NewGuid(), CustomerId = thirdCustomer.Id, CustomerLanguageId = (await _languageRepository.Table.FirstAsync()).Id, CustomerIp = "127.0.0.1", OrderSubtotalInclTax = 8.80M, OrderSubtotalExclTax = 8.80M, OrderSubTotalDiscountInclTax = decimal.Zero, OrderSubTotalDiscountExclTax = decimal.Zero, OrderShippingInclTax = decimal.Zero, OrderShippingExclTax = decimal.Zero, PaymentMethodAdditionalFeeInclTax = decimal.Zero, PaymentMethodAdditionalFeeExclTax = decimal.Zero, TaxRates = "0:0;", OrderTax = decimal.Zero, OrderTotal = 8.80M, RefundedAmount = decimal.Zero, OrderDiscount = decimal.Zero, CheckoutAttributeDescription = string.Empty, CheckoutAttributesXml = string.Empty, CustomerCurrencyCode = "USD", CurrencyRate = 1M, AffiliateId = 0, OrderStatus = OrderStatus.Pending, AllowStoringCreditCardNumber = false, CardType = string.Empty, CardName = string.Empty, CardNumber = string.Empty, MaskedCreditCardNumber = string.Empty, CardCvv2 = string.Empty, CardExpirationMonth = string.Empty, CardExpirationYear = string.Empty, PaymentMethodSystemName = "Payments.CheckMoneyOrder", AuthorizationTransactionId = string.Empty, AuthorizationTransactionCode = string.Empty, AuthorizationTransactionResult = string.Empty, CaptureTransactionId = string.Empty, CaptureTransactionResult = string.Empty, SubscriptionTransactionId = string.Empty, PaymentStatus = PaymentStatus.Pending, PaidDateUtc = null, BillingAddressId = thirdCustomerBillingAddress.Id, ShippingStatus = ShippingStatus.ShippingNotRequired, ShippingMethod = string.Empty, PickupInStore = false, ShippingRateComputationMethodSystemName = string.Empty, CustomValuesXml = string.Empty, VatNumber = string.Empty, CreatedOnUtc = DateTime.UtcNow, CustomOrderNumber = string.Empty }; await InsertInstallationDataAsync(thirdOrder); thirdOrder.CustomOrderNumber = thirdOrder.Id.ToString(); await UpdateInstallationDataAsync(thirdOrder); //order notes await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order placed", OrderId = thirdOrder.Id }); //item If You Wait var thirdOrderItem1 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = thirdOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "If You Wait (donation)").Id, UnitPriceInclTax = 3M, UnitPriceExclTax = 3M, PriceInclTax = 3M, PriceExclTax = 3M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(thirdOrderItem1); //item Night Visions var thirdOrderItem2 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = thirdOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Night Visions").Id, UnitPriceInclTax = 2.8M, UnitPriceExclTax = 2.8M, PriceInclTax = 2.8M, PriceExclTax = 2.8M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(thirdOrderItem2); //item Science & Faith var thirdOrderItem3 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = thirdOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Science & Faith").Id, UnitPriceInclTax = 3M, UnitPriceExclTax = 3M, PriceInclTax = 3M, PriceExclTax = 3M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(thirdOrderItem3); //fourth order var fourthCustomer = await _customerRepository.Table.FirstAsync(c => c.Email == "brenda_lindgren@nopCommerce.com"); var fourthCustomerBillingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(fourthCustomer.BillingAddressId))); var fourthCustomerShippingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(fourthCustomer.ShippingAddressId))); var fourthCustomerPickupAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(fourthCustomer.ShippingAddressId))); var fourthOrder = new Order { StoreId = defaultStore.Id, OrderGuid = Guid.NewGuid(), CustomerId = fourthCustomer.Id, CustomerLanguageId = _languageRepository.Table.First().Id, CustomerIp = "127.0.0.1", OrderSubtotalInclTax = 102M, OrderSubtotalExclTax = 102M, OrderSubTotalDiscountInclTax = decimal.Zero, OrderSubTotalDiscountExclTax = decimal.Zero, OrderShippingInclTax = decimal.Zero, OrderShippingExclTax = decimal.Zero, PaymentMethodAdditionalFeeInclTax = decimal.Zero, PaymentMethodAdditionalFeeExclTax = decimal.Zero, TaxRates = "0:0;", OrderTax = decimal.Zero, OrderTotal = 102M, RefundedAmount = decimal.Zero, OrderDiscount = decimal.Zero, CheckoutAttributeDescription = string.Empty, CheckoutAttributesXml = string.Empty, CustomerCurrencyCode = "USD", CurrencyRate = 1M, AffiliateId = 0, OrderStatus = OrderStatus.Processing, AllowStoringCreditCardNumber = false, CardType = string.Empty, CardName = string.Empty, CardNumber = string.Empty, MaskedCreditCardNumber = string.Empty, CardCvv2 = string.Empty, CardExpirationMonth = string.Empty, CardExpirationYear = string.Empty, PaymentMethodSystemName = "Payments.CheckMoneyOrder", AuthorizationTransactionId = string.Empty, AuthorizationTransactionCode = string.Empty, AuthorizationTransactionResult = string.Empty, CaptureTransactionId = string.Empty, CaptureTransactionResult = string.Empty, SubscriptionTransactionId = string.Empty, PaymentStatus = PaymentStatus.Paid, PaidDateUtc = DateTime.UtcNow, BillingAddressId = fourthCustomerBillingAddress.Id, ShippingAddressId = fourthCustomerShippingAddress.Id, ShippingStatus = ShippingStatus.Shipped, ShippingMethod = "Pickup in store", PickupInStore = true, PickupAddressId = fourthCustomerPickupAddress.Id, ShippingRateComputationMethodSystemName = "Pickup.PickupInStore", CustomValuesXml = string.Empty, VatNumber = string.Empty, CreatedOnUtc = DateTime.UtcNow, CustomOrderNumber = string.Empty }; await InsertInstallationDataAsync(fourthOrder); fourthOrder.CustomOrderNumber = fourthOrder.Id.ToString(); await UpdateInstallationDataAsync(fourthOrder); //order notes await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order placed", OrderId = fourthOrder.Id }); await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order paid", OrderId = fourthOrder.Id }); await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order shipped", OrderId = fourthOrder.Id }); //item Pride and Prejudice var fourthOrderItem1 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = fourthOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Pride and Prejudice").Id, UnitPriceInclTax = 24M, UnitPriceExclTax = 24M, PriceInclTax = 24M, PriceExclTax = 24M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(fourthOrderItem1); //item First Prize Pies var fourthOrderItem2 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = fourthOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "First Prize Pies").Id, UnitPriceInclTax = 51M, UnitPriceExclTax = 51M, PriceInclTax = 51M, PriceExclTax = 51M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(fourthOrderItem2); //item Fahrenheit 451 by Ray Bradbury var fourthOrderItem3 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = fourthOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Fahrenheit 451 by Ray Bradbury").Id, UnitPriceInclTax = 27M, UnitPriceExclTax = 27M, PriceInclTax = 27M, PriceExclTax = 27M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(fourthOrderItem3); //shipments //shipment 1 var fourthOrderShipment1 = new Shipment { OrderId = fourthOrder.Id, TrackingNumber = string.Empty, TotalWeight = 4M, ReadyForPickupDateUtc = DateTime.UtcNow, DeliveryDateUtc = DateTime.UtcNow, AdminComment = string.Empty, CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(fourthOrderShipment1); var fourthOrderShipment1Item1 = new ShipmentItem { OrderItemId = fourthOrderItem1.Id, Quantity = 1, WarehouseId = 0, ShipmentId = fourthOrderShipment1.Id }; await InsertInstallationDataAsync(fourthOrderShipment1Item1); var fourthOrderShipment1Item2 = new ShipmentItem { OrderItemId = fourthOrderItem2.Id, Quantity = 1, WarehouseId = 0, ShipmentId = fourthOrderShipment1.Id }; await InsertInstallationDataAsync(fourthOrderShipment1Item2); //shipment 2 var fourthOrderShipment2 = new Shipment { OrderId = fourthOrder.Id, TrackingNumber = string.Empty, TotalWeight = 2M, ReadyForPickupDateUtc = DateTime.UtcNow, DeliveryDateUtc = DateTime.UtcNow, AdminComment = string.Empty, CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(fourthOrderShipment2); var fourthOrderShipment2Item1 = new ShipmentItem { OrderItemId = fourthOrderItem3.Id, Quantity = 1, WarehouseId = 0, ShipmentId = fourthOrderShipment2.Id }; await InsertInstallationDataAsync(fourthOrderShipment2Item1); //fifth order var fifthCustomer = _customerRepository.Table.First(c => c.Email == "victoria_victoria@nopCommerce.com"); var fifthCustomerBillingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(fifthCustomer.BillingAddressId))); var fifthCustomerShippingAddress = await InsertInstallationDataAsync(cloneAddress(await _addressRepository.GetByIdAsync(fifthCustomer.ShippingAddressId))); var fifthOrder = new Order { StoreId = defaultStore.Id, OrderGuid = Guid.NewGuid(), CustomerId = fifthCustomer.Id, CustomerLanguageId = _languageRepository.Table.First().Id, CustomerIp = "127.0.0.1", OrderSubtotalInclTax = 43.50M, OrderSubtotalExclTax = 43.50M, OrderSubTotalDiscountInclTax = decimal.Zero, OrderSubTotalDiscountExclTax = decimal.Zero, OrderShippingInclTax = decimal.Zero, OrderShippingExclTax = decimal.Zero, PaymentMethodAdditionalFeeInclTax = decimal.Zero, PaymentMethodAdditionalFeeExclTax = decimal.Zero, TaxRates = "0:0;", OrderTax = decimal.Zero, OrderTotal = 43.50M, RefundedAmount = decimal.Zero, OrderDiscount = decimal.Zero, CheckoutAttributeDescription = string.Empty, CheckoutAttributesXml = string.Empty, CustomerCurrencyCode = "USD", CurrencyRate = 1M, AffiliateId = 0, OrderStatus = OrderStatus.Complete, AllowStoringCreditCardNumber = false, CardType = string.Empty, CardName = string.Empty, CardNumber = string.Empty, MaskedCreditCardNumber = string.Empty, CardCvv2 = string.Empty, CardExpirationMonth = string.Empty, CardExpirationYear = string.Empty, PaymentMethodSystemName = "Payments.CheckMoneyOrder", AuthorizationTransactionId = string.Empty, AuthorizationTransactionCode = string.Empty, AuthorizationTransactionResult = string.Empty, CaptureTransactionId = string.Empty, CaptureTransactionResult = string.Empty, SubscriptionTransactionId = string.Empty, PaymentStatus = PaymentStatus.Paid, PaidDateUtc = DateTime.UtcNow, BillingAddressId = fifthCustomerBillingAddress.Id, ShippingAddressId = fifthCustomerShippingAddress.Id, ShippingStatus = ShippingStatus.Delivered, ShippingMethod = "Ground", PickupInStore = false, ShippingRateComputationMethodSystemName = "Shipping.FixedByWeightByTotal", CustomValuesXml = string.Empty, VatNumber = string.Empty, CreatedOnUtc = DateTime.UtcNow, CustomOrderNumber = string.Empty }; await InsertInstallationDataAsync(fifthOrder); fifthOrder.CustomOrderNumber = fifthOrder.Id.ToString(); await UpdateInstallationDataAsync(fifthOrder); //order notes await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order placed", OrderId = fifthOrder.Id }); await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order paid", OrderId = fifthOrder.Id }); await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order shipped", OrderId = fifthOrder.Id }); await InsertInstallationDataAsync(new OrderNote { CreatedOnUtc = DateTime.UtcNow, Note = "Order delivered", OrderId = fifthOrder.Id }); //item Levi's 511 Jeans var fifthOrderItem1 = new OrderItem { OrderItemGuid = Guid.NewGuid(), OrderId = fifthOrder.Id, ProductId = _productRepository.Table.First(p => p.Name == "Levi's 511 Jeans").Id, UnitPriceInclTax = 43.50M, UnitPriceExclTax = 43.50M, PriceInclTax = 43.50M, PriceExclTax = 43.50M, OriginalProductCost = decimal.Zero, AttributeDescription = string.Empty, AttributesXml = string.Empty, Quantity = 1, DiscountAmountInclTax = decimal.Zero, DiscountAmountExclTax = decimal.Zero, DownloadCount = 0, IsDownloadActivated = false, LicenseDownloadId = 0, ItemWeight = null, RentalStartDateUtc = null, RentalEndDateUtc = null }; await InsertInstallationDataAsync(fifthOrderItem1); //shipment 1 var fifthOrderShipment1 = new Shipment { OrderId = fifthOrder.Id, TrackingNumber = string.Empty, TotalWeight = 2M, ShippedDateUtc = DateTime.UtcNow, DeliveryDateUtc = DateTime.UtcNow, AdminComment = string.Empty, CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(fifthOrderShipment1); var fifthOrderShipment1Item1 = new ShipmentItem { OrderItemId = fifthOrderItem1.Id, Quantity = 1, WarehouseId = 0, ShipmentId = fifthOrderShipment1.Id }; await InsertInstallationDataAsync(fifthOrderShipment1Item1); } /// A task that represents the asynchronous operation protected virtual async Task InstallActivityLogAsync(string defaultUserEmail) { //default customer/user var defaultCustomer = _customerRepository.Table.FirstOrDefault(x => x.Email == defaultUserEmail) ?? throw new Exception("Cannot load default customer"); await InsertInstallationDataAsync(new ActivityLog { ActivityLogTypeId = _activityLogTypeRepository.Table.FirstOrDefault(alt => alt.SystemKeyword == "EditCategory")?.Id ?? throw new Exception("Cannot load LogType: EditCategory"), Comment = "Edited a category ('Computers')", CreatedOnUtc = DateTime.UtcNow, CustomerId = defaultCustomer.Id, IpAddress = "127.0.0.1" }); await InsertInstallationDataAsync(new ActivityLog { ActivityLogTypeId = _activityLogTypeRepository.Table.FirstOrDefault(alt => alt.SystemKeyword == "EditDiscount")?.Id ?? throw new Exception("Cannot load LogType: EditDiscount"), Comment = "Edited a discount ('Sample discount with coupon code')", CreatedOnUtc = DateTime.UtcNow, CustomerId = defaultCustomer.Id, IpAddress = "127.0.0.1" }); await InsertInstallationDataAsync(new ActivityLog { ActivityLogTypeId = _activityLogTypeRepository.Table.FirstOrDefault(alt => alt.SystemKeyword == "EditSpecAttribute")?.Id ?? throw new Exception("Cannot load LogType: EditSpecAttribute"), Comment = "Edited a specification attribute ('CPU Type')", CreatedOnUtc = DateTime.UtcNow, CustomerId = defaultCustomer.Id, IpAddress = "127.0.0.1" }); await InsertInstallationDataAsync(new ActivityLog { ActivityLogTypeId = _activityLogTypeRepository.Table.FirstOrDefault(alt => alt.SystemKeyword == "AddNewProductAttribute")?.Id ?? throw new Exception("Cannot load LogType: AddNewProductAttribute"), Comment = "Added a new product attribute ('Some attribute')", CreatedOnUtc = DateTime.UtcNow, CustomerId = defaultCustomer.Id, IpAddress = "127.0.0.1" }); await InsertInstallationDataAsync(new ActivityLog { ActivityLogTypeId = _activityLogTypeRepository.Table.FirstOrDefault(alt => alt.SystemKeyword == "DeleteGiftCard")?.Id ?? throw new Exception("Cannot load LogType: DeleteGiftCard"), Comment = "Deleted a gift card ('bdbbc0ef-be57')", CreatedOnUtc = DateTime.UtcNow, CustomerId = defaultCustomer.Id, IpAddress = "127.0.0.1" }); } /// A task that represents the asynchronous operation protected virtual async Task InstallSearchTermsAsync() { //default store var defaultStore = _storeRepository.Table.FirstOrDefault() ?? throw new Exception("No default store could be loaded"); await InsertInstallationDataAsync(new SearchTerm { Count = 34, Keyword = "computer", StoreId = defaultStore.Id }); await InsertInstallationDataAsync(new SearchTerm { Count = 30, Keyword = "camera", StoreId = defaultStore.Id }); await InsertInstallationDataAsync(new SearchTerm { Count = 27, Keyword = "jewelry", StoreId = defaultStore.Id }); await InsertInstallationDataAsync(new SearchTerm { Count = 26, Keyword = "shoes", StoreId = defaultStore.Id }); await InsertInstallationDataAsync(new SearchTerm { Count = 19, Keyword = "jeans", StoreId = defaultStore.Id }); await InsertInstallationDataAsync(new SearchTerm { Count = 10, Keyword = "gift", StoreId = defaultStore.Id }); } /// A task that represents the asynchronous operation protected virtual async Task InstallEmailAccountsAsync() { var emailAccounts = new List { new() { Email = "test@mail.com", DisplayName = "Store name", Host = "smtp.mail.com", Port = 25, Username = "123", Password = "123", EnableSsl = false } }; await InsertInstallationDataAsync(emailAccounts); } /// A task that represents the asynchronous operation protected virtual async Task InstallMessageTemplatesAsync() { var eaGeneral = _emailAccountRepository.Table.FirstOrDefault() ?? throw new Exception("Default email account cannot be loaded"); var messageTemplates = new List { new() { Name = MessageTemplateSystemNames.BLOG_COMMENT_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New blog comment.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}A new blog comment has been created for blog post \"%BlogComment.BlogPostTitle%\".{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.BACK_IN_STOCK_NOTIFICATION, Subject = "%Store.Name%. Back in stock notification", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%,{Environment.NewLine}
{Environment.NewLine}Product %BackInStockSubscription.ProductName% is in stock.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CUSTOMER_EMAIL_VALIDATION_MESSAGE, Subject = "%Store.Name%. Email validation", Body = $"%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}To activate your account click here.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Store.Name%{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CUSTOMER_EMAIL_REVALIDATION_MESSAGE, Subject = "%Store.Name%. Email validation", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%!{Environment.NewLine}
{Environment.NewLine}To validate your new email address click here.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Store.Name%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.PRIVATE_MESSAGE_NOTIFICATION, Subject = "%Store.Name%. You have received a new private message", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}You have received a new private message.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CUSTOMER_PASSWORD_RECOVERY_MESSAGE, Subject = "%Store.Name%. Password recovery", Body = $"%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}To change your password click here.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Store.Name%{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CUSTOMER_WELCOME_MESSAGE, Subject = "Welcome to %Store.Name%", Body = $"We welcome you to %Store.Name%.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}You can now take part in the various services we have to offer you. Some of these services include:{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Permanent Cart - Any products added to your online cart remain there until you remove them, or check them out.{Environment.NewLine}
{Environment.NewLine}Address Book - We can now deliver your products to another address other than yours! This is perfect to send birthday gifts direct to the birthday-person themselves.{Environment.NewLine}
{Environment.NewLine}Order History - View your history of purchases that you have made with us.{Environment.NewLine}
{Environment.NewLine}Products Reviews - Share your opinions on products with our other customers.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}For help with any of our online services, please email the store-owner: %Store.Email%.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Note: This email address was provided on our registration page. If you own the email and did not register on our site, please send an email to %Store.Email%.{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_FORUM_POST_MESSAGE, Subject = "%Store.Name%. New Post Notification.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}A new post has been created in the topic \"%Forums.TopicName%\" at \"%Forums.ForumName%\" forum.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Click here for more info.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Post author: %Forums.PostAuthor%{Environment.NewLine}
{Environment.NewLine}Post body: %Forums.PostBody%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_FORUM_TOPIC_MESSAGE, Subject = "%Store.Name%. New Topic Notification.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}A new topic \"%Forums.TopicName%\" has been created at \"%Forums.ForumName%\" forum.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Click here for more info.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.GIFT_CARD_NOTIFICATION, Subject = "%GiftCard.SenderName% has sent you a gift card for %Store.Name%", Body = $"

{Environment.NewLine}You have received a gift card for %Store.Name%{Environment.NewLine}

{Environment.NewLine}

{Environment.NewLine}Dear %GiftCard.RecipientName%,{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%GiftCard.SenderName% (%GiftCard.SenderEmail%) has sent you a %GiftCard.Amount% gift card for %Store.Name%{Environment.NewLine}

{Environment.NewLine}

{Environment.NewLine}Your gift card code is %GiftCard.CouponCode%{Environment.NewLine}

{Environment.NewLine}

{Environment.NewLine}%GiftCard.Message%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CUSTOMER_REGISTERED_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New customer registration", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}A new customer registered with your store. Below are the customer's details:{Environment.NewLine}
{Environment.NewLine}Full name: %Customer.FullName%{Environment.NewLine}
{Environment.NewLine}Email: %Customer.Email%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_RETURN_REQUEST_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New return request.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Customer.FullName% has just submitted a new return request. Details are below:{Environment.NewLine}
{Environment.NewLine}Request ID: %ReturnRequest.CustomNumber%{Environment.NewLine}
{Environment.NewLine}Product: %ReturnRequest.Product.Quantity% x Product: %ReturnRequest.Product.Name%{Environment.NewLine}
{Environment.NewLine}Reason for return: %ReturnRequest.Reason%{Environment.NewLine}
{Environment.NewLine}Requested action: %ReturnRequest.RequestedAction%{Environment.NewLine}
{Environment.NewLine}Customer comments:{Environment.NewLine}
{Environment.NewLine}%ReturnRequest.CustomerComment%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.DELETE_CUSTOMER_REQUEST_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New request to delete customer (GDPR)", Body = $"%Customer.Email% has requested account deletion. You can consider this in the admin area.", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_RETURN_REQUEST_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. New return request.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%!{Environment.NewLine}
{Environment.NewLine}You have just submitted a new return request. Details are below:{Environment.NewLine}
{Environment.NewLine}Request ID: %ReturnRequest.CustomNumber%{Environment.NewLine}
{Environment.NewLine}Product: %ReturnRequest.Product.Quantity% x Product: %ReturnRequest.Product.Name%{Environment.NewLine}
{Environment.NewLine}Reason for return: %ReturnRequest.Reason%{Environment.NewLine}
{Environment.NewLine}Requested action: %ReturnRequest.RequestedAction%{Environment.NewLine}
{Environment.NewLine}Customer comments:{Environment.NewLine}
{Environment.NewLine}%ReturnRequest.CustomerComment%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEWS_COMMENT_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New news comment.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}A new news comment has been created for news \"%NewsComment.NewsTitle%\".{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEWSLETTER_SUBSCRIPTION_ACTIVATION_MESSAGE, Subject = "%Store.Name%. Subscription activation message.", Body = $"

{Environment.NewLine}Click here to confirm your subscription to our list.{Environment.NewLine}

{Environment.NewLine}

{Environment.NewLine}If you received this email by mistake, simply delete it.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEWSLETTER_SUBSCRIPTION_DEACTIVATION_MESSAGE, Subject = "%Store.Name%. Subscription deactivation message.", Body = $"

{Environment.NewLine}Click here to unsubscribe from our newsletter.{Environment.NewLine}

{Environment.NewLine}

{Environment.NewLine}If you received this email by mistake, simply delete it.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_VAT_SUBMITTED_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New VAT number is submitted.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Customer.FullName% (%Customer.Email%) has just submitted a new VAT number. Details are below:{Environment.NewLine}
{Environment.NewLine}VAT number: %Customer.VatNumber%{Environment.NewLine}
{Environment.NewLine}VAT number status: %Customer.VatNumberStatus%{Environment.NewLine}
{Environment.NewLine}Received name: %VatValidationResult.Name%{Environment.NewLine}
{Environment.NewLine}Received address: %VatValidationResult.Address%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_CANCELLED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Your order cancelled", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Your order has been cancelled. Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PROCESSING_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Your order is processing", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Your order is processing. Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_COMPLETED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Your order completed", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Your order has been completed. Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.SHIPMENT_DELIVERED_CUSTOMER_NOTIFICATION, Subject = "Your order from %Store.Name% has been %if (!%Order.IsCompletelyDelivered%) partially endif%delivered.", Body = $"

{Environment.NewLine} %Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Good news! Your order has been %if (!%Order.IsCompletelyDelivered%) partially endif%delivered.{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% Delivered Products:{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Shipment.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PLACED_CUSTOMER_NOTIFICATION, Subject = "Order receipt from %Store.Name%.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Thanks for buying from %Store.Name%. Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PLACED_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Purchase Receipt for Order #%Order.OrderNumber%", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Order.CustomerFullName% (%Order.CustomerEmail%) has just placed an order from your store. Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.SHIPMENT_SENT_CUSTOMER_NOTIFICATION, Subject = "Your order from %Store.Name% has been %if (!%Order.IsCompletelyShipped%) partially endif%shipped.", Body = $"

{Environment.NewLine} %Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%!,{Environment.NewLine}
{Environment.NewLine}Good news! Your order has been %if (!%Order.IsCompletelyShipped%) partially endif%shipped.{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% Shipped Products:{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Shipment.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.SHIPMENT_READY_FOR_PICKUP_CUSTOMER_NOTIFICATION, Subject = "Your order from %Store.Name% has been %if (!%Order.IsCompletelyReadyForPickup%) partially endif%ready for pickup.", Body = $"

{Environment.NewLine} %Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%!,{Environment.NewLine}
{Environment.NewLine}Good news! Your order has been %if (!%Order.IsCompletelyReadyForPickup%) partially endif%ready for pickup.{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% Products ready for pickup:{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Shipment.Product(s)%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.PRODUCT_REVIEW_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New product review.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}A new product review has been written for product \"%ProductReview.ProductName%\".{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.PRODUCT_REVIEW_REPLY_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Product review reply.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%,{Environment.NewLine}
{Environment.NewLine}You received a reply from the store administration to your review for product \"%ProductReview.ProductName%\".{Environment.NewLine}

{Environment.NewLine}", IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.QUANTITY_BELOW_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Quantity below notification. %Product.Name%", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Product.Name% (ID: %Product.ID%) low quantity.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Quantity: %Product.StockQuantity%{Environment.NewLine}
{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.QUANTITY_BELOW_ATTRIBUTE_COMBINATION_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Quantity below notification. %Product.Name%", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Product.Name% (ID: %Product.ID%) low quantity.{Environment.NewLine}
{Environment.NewLine}%AttributeCombination.Formatted%{Environment.NewLine}
{Environment.NewLine}Quantity: %AttributeCombination.StockQuantity%{Environment.NewLine}
{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.RETURN_REQUEST_STATUS_CHANGED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Return request status was changed.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%,{Environment.NewLine}
{Environment.NewLine}Your return request #%ReturnRequest.CustomNumber% status has been changed.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.EMAIL_A_FRIEND_MESSAGE, Subject = "%Store.Name%. Referred Item", Body = $"

{Environment.NewLine} %Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%EmailAFriend.Email% was shopping on %Store.Name% and wanted to share the following item with you.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Product.Name%{Environment.NewLine}
{Environment.NewLine}%Product.ShortDescription%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}For more info click here{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%EmailAFriend.PersonalMessage%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Store.Name%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.WISHLIST_TO_FRIEND_MESSAGE, Subject = "%Store.Name%. Wishlist", Body = $"

{Environment.NewLine} %Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Wishlist.Email% was shopping on %Store.Name% and wanted to share a wishlist with you.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}For more info click here{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Wishlist.PersonalMessage%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Store.Name%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_ORDER_NOTE_ADDED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. New order note has been added", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%,{Environment.NewLine}
{Environment.NewLine}New order note has been added to your account:{Environment.NewLine}
{Environment.NewLine}\"%Order.NewNoteText%\".{Environment.NewLine}
{Environment.NewLine}%Order.OrderURLForCustomer%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.RECURRING_PAYMENT_CANCELLED_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Recurring payment cancelled", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%RecurringPayment.CancelAfterFailedPayment%) The last payment for the recurring payment ID=%RecurringPayment.ID% failed, so it was cancelled. endif% %if (!%RecurringPayment.CancelAfterFailedPayment%) %Customer.FullName% (%Customer.Email%) has just cancelled a recurring payment ID=%RecurringPayment.ID%. endif%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.RECURRING_PAYMENT_CANCELLED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Recurring payment cancelled", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%,{Environment.NewLine}
{Environment.NewLine}%if (%RecurringPayment.CancelAfterFailedPayment%) It appears your credit card didn't go through for this recurring payment (%Order.OrderURLForCustomer%){Environment.NewLine}
{Environment.NewLine}So your subscription has been cancelled. endif% %if (!%RecurringPayment.CancelAfterFailedPayment%) The recurring payment ID=%RecurringPayment.ID% was cancelled. endif%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.RECURRING_PAYMENT_FAILED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Last recurring payment failed", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Customer.FullName%,{Environment.NewLine}
{Environment.NewLine}It appears your credit card didn't go through for this recurring payment (%Order.OrderURLForCustomer%){Environment.NewLine}
%if (%RecurringPayment.RecurringPaymentType% == \"Manual\") {Environment.NewLine}You can recharge balance and manually retry payment or cancel it on the order history page. endif% %if (%RecurringPayment.RecurringPaymentType% == \"Automatic\") {Environment.NewLine}You can recharge balance and wait, we will try to make the payment again, or you can cancel it on the order history page. endif%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PLACED_VENDOR_NOTIFICATION, Subject = "%Store.Name%. Order placed", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Customer.FullName% (%Customer.Email%) has just placed an order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PLACED_AFFILIATE_NOTIFICATION, Subject = "%Store.Name%. Order placed", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Customer.FullName% (%Customer.Email%) has just placed an order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_REFUNDED_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Order #%Order.OrderNumber% refunded", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Thanks for buying from %Store.Name%. Order #%Order.OrderNumber% has been has been refunded. Please allow 7-14 days for the refund to be reflected in your account.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Amount refunded: %Order.AmountRefunded%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_REFUNDED_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Order #%Order.OrderNumber% refunded", Body = $"%Store.Name%. Order #%Order.OrderNumber% refunded', N'{Environment.NewLine}

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order #%Order.OrderNumber% has been just refunded{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Amount refunded: %Order.AmountRefunded%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PAID_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Order #%Order.OrderNumber% paid", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order #%Order.OrderNumber% has been just paid{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PAID_CUSTOMER_NOTIFICATION, Subject = "%Store.Name%. Order #%Order.OrderNumber% paid", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Hello %Order.CustomerFullName%,{Environment.NewLine}
{Environment.NewLine}Thanks for buying from %Store.Name%. Order #%Order.OrderNumber% has been just paid. Below is the summary of the order.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Order Details: %Order.OrderURLForCustomer%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Billing Address{Environment.NewLine}
{Environment.NewLine}%Order.BillingFirstName% %Order.BillingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.BillingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.BillingCity% %Order.BillingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.BillingStateProvince% %Order.BillingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%if (%Order.Shippable%) Shipping Address{Environment.NewLine}
{Environment.NewLine}%Order.ShippingFirstName% %Order.ShippingLastName%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress1%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingAddress2%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingCity% %Order.ShippingZipPostalCode%{Environment.NewLine}
{Environment.NewLine}%Order.ShippingStateProvince% %Order.ShippingCountry%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Shipping Method: %Order.ShippingMethod%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine} endif% %Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PAID_VENDOR_NOTIFICATION, Subject = "%Store.Name%. Order #%Order.OrderNumber% paid", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order #%Order.OrderNumber% has been just paid.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.ORDER_PAID_AFFILIATE_NOTIFICATION, Subject = "%Store.Name%. Order #%Order.OrderNumber% paid", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order #%Order.OrderNumber% has been just paid.{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Order Number: %Order.OrderNumber%{Environment.NewLine}
{Environment.NewLine}Date Ordered: %Order.CreatedOn%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Order.Product(s)%{Environment.NewLine}

{Environment.NewLine}", //this template is disabled by default IsActive = false, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.NEW_VENDOR_ACCOUNT_APPLY_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. New vendor account submitted.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}%Customer.FullName% (%Customer.Email%) has just submitted for a vendor account. Details are below:{Environment.NewLine}
{Environment.NewLine}Vendor name: %Vendor.Name%{Environment.NewLine}
{Environment.NewLine}Vendor email: %Vendor.Email%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}You can activate it in admin area.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.VENDOR_INFORMATION_CHANGE_STORE_OWNER_NOTIFICATION, Subject = "%Store.Name%. Vendor information change.", Body = $"

{Environment.NewLine}%Store.Name%{Environment.NewLine}
{Environment.NewLine}
{Environment.NewLine}Vendor %Vendor.Name% (%Vendor.Email%) has just changed information about itself.{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CONTACT_US_MESSAGE, Subject = "%Store.Name%. Contact us", Body = $"

{Environment.NewLine}%ContactUs.Body%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id }, new() { Name = MessageTemplateSystemNames.CONTACT_VENDOR_MESSAGE, Subject = "%Store.Name%. Contact us", Body = $"

{Environment.NewLine}%ContactUs.Body%{Environment.NewLine}

{Environment.NewLine}", IsActive = true, EmailAccountId = eaGeneral.Id } }; await InsertInstallationDataAsync(messageTemplates); } /// A task that represents the asynchronous operation protected virtual async Task InstallTopicsAsync() { var defaultTopicTemplate = _topicTemplateRepository.Table.FirstOrDefault(tt => tt.Name == "Default template") ?? throw new Exception("Topic template cannot be loaded"); var topics = new List { new() { SystemName = "AboutUs", IncludeInSitemap = false, IsPasswordProtected = false, IncludeInFooterColumn1 = true, DisplayOrder = 20, Published = true, Title = "About us", Body = "

Put your "About Us" information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "CheckoutAsGuestOrRegister", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = string.Empty, Body = "

Register and save time!
Register with us for future convenience:

  • Fast and easy check out
  • Easy access to your order history and status
", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "ConditionsOfUse", IncludeInSitemap = false, IsPasswordProtected = false, IncludeInFooterColumn1 = true, DisplayOrder = 15, Published = true, Title = "Conditions of Use", Body = "

Put your conditions of use information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "ContactUs", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = string.Empty, Body = "

Put your contact information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "ForumWelcomeMessage", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = "Forums", Body = "

Put your welcome message here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "HomepageText", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = "Welcome to our store", Body = "

Online shopping is the process consumers go through to purchase products or services over the Internet. You can edit this in the admin site.

If you have questions, see the Documentation, or post in the Forums at nopCommerce.com

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "LoginRegistrationInfo", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = "About login / registration", Body = "

Put your login / registration information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "PrivacyInfo", IncludeInSitemap = false, IsPasswordProtected = false, IncludeInFooterColumn1 = true, DisplayOrder = 10, Published = true, Title = "Privacy notice", Body = "

Put your privacy policy information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "PageNotFound", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = string.Empty, Body = "

The page you requested was not found, and we have a fine guess why.

  • If you typed the URL directly, please make sure the spelling is correct.
  • The page no longer exists. In this case, we profusely apologize for the inconvenience and for any damage this may cause.
", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "ShippingInfo", IncludeInSitemap = false, IsPasswordProtected = false, IncludeInFooterColumn1 = true, DisplayOrder = 5, Published = true, Title = "Shipping & returns", Body = "

Put your shipping & returns information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "ApplyVendor", IncludeInSitemap = false, IsPasswordProtected = false, DisplayOrder = 1, Published = true, Title = string.Empty, Body = "

Put your apply vendor instructions here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id }, new() { SystemName = "VendorTermsOfService", IncludeInSitemap = false, IsPasswordProtected = false, IncludeInFooterColumn1 = false, DisplayOrder = 1, Published = true, Title = "Terms of services for vendors", Body = "

Put your terms of service information here. You can edit this in the admin site.

", TopicTemplateId = defaultTopicTemplate.Id } }; await InsertInstallationDataAsync(topics); //search engine names foreach (var topic in topics) { await InsertInstallationDataAsync(new UrlRecord { EntityId = topic.Id, EntityName = nameof(Topic), LanguageId = 0, IsActive = true, Slug = await ValidateSeNameAsync(topic, !string.IsNullOrEmpty(topic.Title) ? topic.Title : topic.SystemName) }); } } /// A task that represents the asynchronous operation protected virtual async Task InstallSettingsAsync(RegionInfo regionInfo) { var isMetric = regionInfo?.IsMetric ?? false; var country = regionInfo?.TwoLetterISORegionName ?? string.Empty; var isGermany = country == "DE"; var isEurope = ISO3166.FromCountryCode(country)?.SubjectToVat ?? false; var settingService = EngineContext.Current.Resolve(); await settingService.SaveSettingAsync(new PdfSettings { LogoPictureId = 0, LetterPageSizeEnabled = false, RenderOrderNotes = true, FontFamily = "FreeSerif", InvoiceFooterTextColumn1 = null, InvoiceFooterTextColumn2 = null }); await settingService.SaveSettingAsync(new SitemapSettings { SitemapEnabled = true, SitemapPageSize = 200, SitemapIncludeCategories = true, SitemapIncludeManufacturers = true, SitemapIncludeProducts = false, SitemapIncludeProductTags = false, SitemapIncludeBlogPosts = true, SitemapIncludeNews = false, SitemapIncludeTopics = true }); await settingService.SaveSettingAsync(new SitemapXmlSettings { SitemapXmlEnabled = true, SitemapXmlIncludeBlogPosts = true, SitemapXmlIncludeCategories = true, SitemapXmlIncludeManufacturers = true, SitemapXmlIncludeNews = true, SitemapXmlIncludeProducts = true, SitemapXmlIncludeProductTags = true, SitemapXmlIncludeCustomUrls = true, SitemapXmlIncludeTopics = true, RebuildSitemapXmlAfterHours = 2 * 24, SitemapBuildOperationDelay = 60 }); await settingService.SaveSettingAsync(new CommonSettings { UseSystemEmailForContactUsForm = true, DisplayJavaScriptDisabledWarning = false, Log404Errors = true, BreadcrumbDelimiter = "/", BbcodeEditorOpenLinksInNewWindow = false, PopupForTermsOfServiceLinks = true, JqueryMigrateScriptLoggingActive = false, UseResponseCompression = true, FaviconAndAppIconsHeadCode = "", EnableHtmlMinification = true, RestartTimeout = NopCommonDefaults.RestartTimeout, HeaderCustomHtml = string.Empty, FooterCustomHtml = string.Empty }); await settingService.SaveSettingAsync(new SeoSettings { PageTitleSeparator = ". ", PageTitleSeoAdjustment = PageTitleSeoAdjustment.PagenameAfterStorename, GenerateProductMetaDescription = true, ConvertNonWesternChars = false, AllowUnicodeCharsInUrls = true, CanonicalUrlsEnabled = false, QueryStringInCanonicalUrlsEnabled = false, WwwRequirement = WwwRequirement.NoMatter, TwitterMetaTags = true, OpenGraphMetaTags = true, MicrodataEnabled = true, ReservedUrlRecordSlugs = NopSeoDefaults.ReservedUrlRecordSlugs, CustomHeadTags = string.Empty }); await settingService.SaveSettingAsync(new AdminAreaSettings { DefaultGridPageSize = 15, PopupGridPageSize = 7, GridPageSizes = "7, 15, 20, 50, 100", RichEditorAdditionalSettings = null, RichEditorAllowJavaScript = false, RichEditorAllowStyleTag = false, UseRichEditorForCustomerEmails = false, UseRichEditorInMessageTemplates = false, CheckLicense = true, UseIsoDateFormatInJsonResult = true, ShowDocumentationReferenceLinks = true }); await settingService.SaveSettingAsync(new ProductEditorSettings { Weight = true, Dimensions = true, ProductAttributes = true, SpecificationAttributes = true, PAngV = isGermany }); await settingService.SaveSettingAsync(new GdprSettings { DeleteInactiveCustomersAfterMonths = 36, GdprEnabled = false, LogPrivacyPolicyConsent = true, LogNewsletterConsent = true, LogUserProfileChanges = true }); await settingService.SaveSettingAsync(new CatalogSettings { AllowViewUnpublishedProductPage = true, DisplayDiscontinuedMessageForUnpublishedProducts = true, PublishBackProductWhenCancellingOrders = false, ShowSkuOnProductDetailsPage = true, ShowSkuOnCatalogPages = false, ShowManufacturerPartNumber = false, ShowGtin = false, ShowFreeShippingNotification = true, ShowShortDescriptionOnCatalogPages = false, AllowProductSorting = true, AllowProductViewModeChanging = true, DefaultViewMode = "grid", ShowProductsFromSubcategories = false, ShowCategoryProductNumber = false, ShowCategoryProductNumberIncludingSubcategories = false, CategoryBreadcrumbEnabled = true, ShowShareButton = true, PageShareCode = "
", ProductReviewsMustBeApproved = false, OneReviewPerProductFromCustomer = false, DefaultProductRatingValue = 5, AllowAnonymousUsersToReviewProduct = false, ProductReviewPossibleOnlyAfterPurchasing = false, NotifyStoreOwnerAboutNewProductReviews = false, NotifyCustomerAboutProductReviewReply = false, EmailAFriendEnabled = true, AllowAnonymousUsersToEmailAFriend = false, RecentlyViewedProductsNumber = 3, RecentlyViewedProductsEnabled = true, NewProductsEnabled = true, NewProductsPageSize = 6, NewProductsAllowCustomersToSelectPageSize = true, NewProductsPageSizeOptions = "6, 3, 9", CompareProductsEnabled = true, CompareProductsNumber = 4, ProductSearchAutoCompleteEnabled = true, ProductSearchEnabled = true, ProductSearchAutoCompleteNumberOfProducts = 10, ShowLinkToAllResultInSearchAutoComplete = false, ProductSearchTermMinimumLength = 3, ShowProductImagesInSearchAutoComplete = false, ShowBestsellersOnHomepage = false, NumberOfBestsellersOnHomepage = 4, SearchPageProductsPerPage = 6, SearchPageAllowCustomersToSelectPageSize = true, SearchPagePageSizeOptions = "6, 3, 9, 18", SearchPagePriceRangeFiltering = true, SearchPageManuallyPriceRange = true, SearchPagePriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, SearchPagePriceTo = NopCatalogDefaults.DefaultPriceRangeTo, ProductsAlsoPurchasedEnabled = true, ProductsAlsoPurchasedNumber = 4, AjaxProcessAttributeChange = true, NumberOfProductTags = 15, ProductsByTagPageSize = 6, IncludeShortDescriptionInCompareProducts = false, IncludeFullDescriptionInCompareProducts = false, IncludeFeaturedProductsInNormalLists = false, UseLinksInRequiredProductWarnings = true, DisplayTierPricesWithDiscounts = true, IgnoreDiscounts = false, IgnoreFeaturedProducts = false, IgnoreAcl = true, IgnoreStoreLimitations = true, CacheProductPrices = false, ProductsByTagAllowCustomersToSelectPageSize = true, ProductsByTagPageSizeOptions = "6, 3, 9, 18", ProductsByTagPriceRangeFiltering = true, ProductsByTagManuallyPriceRange = true, ProductsByTagPriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, ProductsByTagPriceTo = NopCatalogDefaults.DefaultPriceRangeTo, MaximumBackInStockSubscriptions = 200, ManufacturersBlockItemsToDisplay = 2, DisplayTaxShippingInfoFooter = isGermany, DisplayTaxShippingInfoProductDetailsPage = isGermany, DisplayTaxShippingInfoProductBoxes = isGermany, DisplayTaxShippingInfoShoppingCart = isGermany, DisplayTaxShippingInfoWishlist = isGermany, DisplayTaxShippingInfoOrderDetailsPage = isGermany, DefaultCategoryPageSizeOptions = "6, 3, 9", DefaultCategoryPageSize = 6, DefaultManufacturerPageSizeOptions = "6, 3, 9", DefaultManufacturerPageSize = 6, ShowProductReviewsTabOnAccountPage = true, ProductReviewsPageSizeOnAccountPage = 10, ProductReviewsSortByCreatedDateAscending = false, ExportImportProductAttributes = true, ExportImportProductSpecificationAttributes = true, ExportImportUseDropdownlistsForAssociatedEntities = true, ExportImportProductsCountInOneFile = 500, ExportImportSplitProductsFile = false, ExportImportRelatedEntitiesByName = true, CountDisplayedYearsDatePicker = 1, UseAjaxLoadMenu = false, UseAjaxCatalogProductsLoading = true, EnableManufacturerFiltering = true, EnablePriceRangeFiltering = true, EnableSpecificationAttributeFiltering = true, DisplayFromPrices = false, AttributeValueOutOfStockDisplayType = AttributeValueOutOfStockDisplayType.AlwaysDisplay, AllowCustomersToSearchWithCategoryName = false, AllowCustomersToSearchWithManufacturerName = false, DisplayAllPicturesOnCatalogPages = false, ProductUrlStructureTypeId = (int)ProductUrlStructureType.Product, ActiveSearchProviderSystemName = string.Empty, UseStandardSearchWhenSearchProviderThrowsException = true }); await settingService.SaveSettingAsync(new LocalizationSettings { DefaultAdminLanguageId = _languageRepository.Table .Single(l => l.LanguageCulture == NopCommonDefaults.DefaultLanguageCulture).Id, UseImagesForLanguageSelection = false, SeoFriendlyUrlsForLanguagesEnabled = false, AutomaticallyDetectLanguage = false, LoadAllLocaleRecordsOnStartup = true, LoadAllLocalizedPropertiesOnStartup = true, LoadAllUrlRecordsOnStartup = false, IgnoreRtlPropertyForAdminArea = false }); await settingService.SaveSettingAsync(new CustomerSettings { UsernamesEnabled = false, CheckUsernameAvailabilityEnabled = false, AllowUsersToChangeUsernames = false, DefaultPasswordFormat = PasswordFormat.Hashed, HashedPasswordFormat = NopCustomerServicesDefaults.DefaultHashedPasswordFormat, PasswordMinLength = 6, PasswordMaxLength = 64, PasswordRequireDigit = false, PasswordRequireLowercase = false, PasswordRequireNonAlphanumeric = false, PasswordRequireUppercase = false, UnduplicatedPasswordsNumber = 4, PasswordRecoveryLinkDaysValid = 7, PasswordLifetime = 90, FailedPasswordAllowedAttempts = 0, FailedPasswordLockoutMinutes = 30, RequiredReLoginAfterPasswordChange = false, UserRegistrationType = UserRegistrationType.Standard, AllowCustomersToUploadAvatars = false, AvatarMaximumSizeBytes = 20000, DefaultAvatarEnabled = true, ShowCustomersLocation = false, ShowCustomersJoinDate = false, AllowViewingProfiles = false, NotifyNewCustomerRegistration = false, HideDownloadableProductsTab = false, HideBackInStockSubscriptionsTab = false, DownloadableProductsValidateUser = false, CustomerNameFormat = CustomerNameFormat.ShowFirstName, FirstNameEnabled = true, FirstNameRequired = true, LastNameEnabled = true, LastNameRequired = true, GenderEnabled = true, NeutralGenderEnabled = false, DateOfBirthEnabled = false, DateOfBirthRequired = false, DateOfBirthMinimumAge = null, CompanyEnabled = true, StreetAddressEnabled = false, StreetAddress2Enabled = false, ZipPostalCodeEnabled = false, CityEnabled = false, CountyEnabled = false, CountyRequired = false, CountryEnabled = false, CountryRequired = false, StateProvinceEnabled = false, StateProvinceRequired = false, PhoneEnabled = false, FaxEnabled = false, AcceptPrivacyPolicyEnabled = false, NewsletterEnabled = true, NewsletterTickedByDefault = true, HideNewsletterBlock = false, NewsletterBlockAllowToUnsubscribe = false, OnlineCustomerMinutes = 20, StoreLastVisitedPage = false, StoreIpAddresses = true, LastActivityMinutes = 15, SuffixDeletedCustomers = false, EnteringEmailTwice = false, RequireRegistrationForDownloadableProducts = false, AllowCustomersToCheckGiftCardBalance = false, DeleteGuestTaskOlderThanMinutes = 1440, PhoneNumberValidationEnabled = false, PhoneNumberValidationUseRegex = false, PhoneNumberValidationRule = "^[0-9]{1,14}?$", DefaultCountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == regionInfo.ThreeLetterISORegionName)?.Id }); await settingService.SaveSettingAsync(new MultiFactorAuthenticationSettings { ForceMultifactorAuthentication = false }); await settingService.SaveSettingAsync(new AddressSettings { CompanyEnabled = true, StreetAddressEnabled = true, StreetAddressRequired = true, StreetAddress2Enabled = true, ZipPostalCodeEnabled = true, ZipPostalCodeRequired = true, CityEnabled = true, CityRequired = true, CountyEnabled = false, CountyRequired = false, CountryEnabled = true, StateProvinceEnabled = true, PhoneEnabled = true, PhoneRequired = true, FaxEnabled = true, DefaultCountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == regionInfo.ThreeLetterISORegionName)?.Id }); await settingService.SaveSettingAsync(new MediaSettings { AvatarPictureSize = 120, ProductThumbPictureSize = 415, ProductDetailsPictureSize = 550, ProductThumbPictureSizeOnProductDetailsPage = 100, AssociatedProductPictureSize = 220, CategoryThumbPictureSize = 450, ManufacturerThumbPictureSize = 420, VendorThumbPictureSize = 450, CartThumbPictureSize = 80, OrderThumbPictureSize = 80, MiniCartThumbPictureSize = 70, AutoCompleteSearchThumbPictureSize = 20, ImageSquarePictureSize = 32, MaximumImageSize = 1980, DefaultPictureZoomEnabled = false, AllowSVGUploads = false, DefaultImageQuality = 80, MultipleThumbDirectories = false, ImportProductImagesUsingHash = true, AzureCacheControlHeader = string.Empty, UseAbsoluteImagePath = true, VideoIframeAllow = "fullscreen", VideoIframeWidth = 300, VideoIframeHeight = 150 }); await settingService.SaveSettingAsync(new StoreInformationSettings { StoreClosed = false, DefaultStoreTheme = "DefaultClean", AllowCustomerToSelectTheme = false, DisplayEuCookieLawWarning = isEurope, FacebookLink = "https://www.facebook.com/nopCommerce", TwitterLink = "https://twitter.com/nopCommerce", YoutubeLink = "https://www.youtube.com/user/nopCommerce", InstagramLink = "https://www.instagram.com/nopcommerce_official", HidePoweredByNopCommerce = false }); await settingService.SaveSettingAsync(new ExternalAuthenticationSettings { RequireEmailValidation = false, LogErrors = false, AllowCustomersToRemoveAssociations = true }); await settingService.SaveSettingAsync(new RewardPointsSettings { Enabled = true, ExchangeRate = 1, PointsForRegistration = 0, RegistrationPointsValidity = 30, PointsForPurchases_Amount = 10, PointsForPurchases_Points = 1, MinOrderTotalToAwardPoints = 0, MaximumRewardPointsToUsePerOrder = 0, MaximumRedeemedRate = 0, PurchasesPointsValidity = 45, ActivationDelay = 0, ActivationDelayPeriodId = 0, DisplayHowMuchWillBeEarned = true, PointsAccumulatedForAllStores = true, PageSize = 10 }); var primaryCurrency = "USD"; await settingService.SaveSettingAsync(new CurrencySettings { DisplayCurrencyLabel = false, PrimaryStoreCurrencyId = _currencyRepository.Table.Single(c => c.CurrencyCode == primaryCurrency).Id, PrimaryExchangeRateCurrencyId = _currencyRepository.Table.Single(c => c.CurrencyCode == primaryCurrency).Id, ActiveExchangeRateProviderSystemName = "CurrencyExchange.ECB", AutoUpdateEnabled = false }); var baseDimension = isMetric ? "meters" : "inches"; var baseWeight = isMetric ? "kg" : "lb"; await settingService.SaveSettingAsync(new MeasureSettings { BaseDimensionId = _measureDimensionRepository.Table.Single(m => m.SystemKeyword == baseDimension).Id, BaseWeightId = _measureWeightRepository.Table.Single(m => m.SystemKeyword == baseWeight).Id }); await settingService.SaveSettingAsync(new MessageTemplatesSettings { CaseInvariantReplacement = false, Color1 = "#b9babe", Color2 = "#ebecee", Color3 = "#dde2e6" }); await settingService.SaveSettingAsync(new ShoppingCartSettings { DisplayCartAfterAddingProduct = false, DisplayWishlistAfterAddingProduct = false, MaximumShoppingCartItems = 1000, MaximumWishlistItems = 1000, AllowOutOfStockItemsToBeAddedToWishlist = false, MoveItemsFromWishlistToCart = true, CartsSharedBetweenStores = false, ShowProductImagesOnShoppingCart = true, ShowProductImagesOnWishList = true, ShowDiscountBox = true, ShowGiftCardBox = true, CrossSellsNumber = 4, EmailWishlistEnabled = true, AllowAnonymousUsersToEmailWishlist = false, MiniShoppingCartEnabled = true, ShowProductImagesInMiniShoppingCart = true, MiniShoppingCartProductNumber = 5, RoundPricesDuringCalculation = true, GroupTierPricesForDistinctShoppingCartItems = false, AllowCartItemEditing = true, RenderAssociatedAttributeValueQuantity = true }); await settingService.SaveSettingAsync(new OrderSettings { ReturnRequestNumberMask = "{ID}", IsReOrderAllowed = true, MinOrderSubtotalAmount = 0, MinOrderSubtotalAmountIncludingTax = false, MinOrderTotalAmount = 0, AutoUpdateOrderTotalsOnEditingOrder = false, AnonymousCheckoutAllowed = true, TermsOfServiceOnShoppingCartPage = true, TermsOfServiceOnOrderConfirmPage = false, OnePageCheckoutEnabled = true, OnePageCheckoutDisplayOrderTotalsOnPaymentInfoTab = false, DisableBillingAddressCheckoutStep = false, DisableOrderCompletedPage = false, DisplayPickupInStoreOnShippingMethodPage = false, AttachPdfInvoiceToOrderPlacedEmail = false, AttachPdfInvoiceToOrderProcessingEmail = false, AttachPdfInvoiceToOrderCompletedEmail = false, GeneratePdfInvoiceInCustomerLanguage = true, AttachPdfInvoiceToOrderPaidEmail = false, ReturnRequestsEnabled = true, ReturnRequestsAllowFiles = false, ReturnRequestsFileMaximumSize = 2048, NumberOfDaysReturnRequestAvailable = 365, MinimumOrderPlacementInterval = 30, ActivateGiftCardsAfterCompletingOrder = false, DeactivateGiftCardsAfterCancellingOrder = false, DeactivateGiftCardsAfterDeletingOrder = false, CompleteOrderWhenDelivered = true, CustomOrderNumberMask = "{ID}", ExportWithProducts = true, AllowAdminsToBuyCallForPriceProducts = true, ShowProductThumbnailInOrderDetailsPage = true, DisplayCustomerCurrencyOnOrders = false, DisplayOrderSummary = true }); await settingService.SaveSettingAsync(new SecuritySettings { EncryptionKey = CommonHelper.GenerateRandomDigitCode(16), AdminAreaAllowedIpAddresses = null, HoneypotEnabled = false, HoneypotInputName = "hpinput", AllowNonAsciiCharactersInHeaders = true, UseAesEncryptionAlgorithm = true, AllowStoreOwnerExportImportCustomersWithHashedPassword = true }); await settingService.SaveSettingAsync(new ShippingSettings { ActiveShippingRateComputationMethodSystemNames = ["Shipping.FixedByWeightByTotal"], ActivePickupPointProviderSystemNames = ["Pickup.PickupInStore"], ShipToSameAddress = true, AllowPickupInStore = true, DisplayPickupPointsOnMap = false, IgnoreAdditionalShippingChargeForPickupInStore = true, UseWarehouseLocation = false, NotifyCustomerAboutShippingFromMultipleLocations = false, FreeShippingOverXEnabled = false, FreeShippingOverXValue = decimal.Zero, FreeShippingOverXIncludingTax = false, EstimateShippingProductPageEnabled = true, EstimateShippingCartPageEnabled = true, EstimateShippingCityNameEnabled = false, DisplayShipmentEventsToCustomers = false, DisplayShipmentEventsToStoreOwner = false, HideShippingTotal = false, ReturnValidOptionsIfThereAreAny = true, BypassShippingMethodSelectionIfOnlyOne = false, UseCubeRootMethod = true, ConsiderAssociatedProductsDimensions = true, ShipSeparatelyOneItemEach = false, RequestDelay = 300, ShippingSorting = ShippingSortingEnum.Position, }); await settingService.SaveSettingAsync(new PaymentSettings { ActivePaymentMethodSystemNames = ["Payments.CheckMoneyOrder", "Payments.Manual"], AllowRePostingPayments = true, BypassPaymentMethodSelectionIfOnlyOne = true, ShowPaymentMethodDescriptions = true, SkipPaymentInfoStepForRedirectionPaymentMethods = false, CancelRecurringPaymentsAfterFailedPayment = false, RegenerateOrderGuidInterval = 180 }); await settingService.SaveSettingAsync(new TaxSettings { TaxBasedOn = TaxBasedOn.BillingAddress, TaxBasedOnPickupPointAddress = false, TaxDisplayType = TaxDisplayType.ExcludingTax, ActiveTaxProviderSystemName = "Tax.FixedOrByCountryStateZip", DefaultTaxAddressId = 0, DisplayTaxSuffix = false, DisplayTaxRates = false, PricesIncludeTax = false, AutomaticallyDetectCountry = true, AllowCustomersToSelectTaxDisplayType = false, ForceTaxExclusionFromOrderSubtotal = false, DefaultTaxCategoryId = 0, HideZeroTax = false, HideTaxInOrderSummary = false, ShippingIsTaxable = false, ShippingPriceIncludesTax = false, ShippingTaxClassId = 0, PaymentMethodAdditionalFeeIsTaxable = false, PaymentMethodAdditionalFeeIncludesTax = false, PaymentMethodAdditionalFeeTaxClassId = 0, EuVatEnabled = isEurope, EuVatEnabledForGuests = false, EuVatShopCountryId = isEurope ? (_countryRepository.Table.FirstOrDefault(x => x.TwoLetterIsoCode == country)?.Id ?? 0) : 0, EuVatAllowVatExemption = true, EuVatUseWebService = false, EuVatAssumeValid = false, EuVatEmailAdminWhenNewVatSubmitted = false, LogErrors = false }); await settingService.SaveSettingAsync(new DateTimeSettings { DefaultStoreTimeZoneId = string.Empty, AllowCustomersToSetTimeZone = false }); await settingService.SaveSettingAsync(new BlogSettings { Enabled = true, PostsPageSize = 10, AllowNotRegisteredUsersToLeaveComments = true, NotifyAboutNewBlogComments = false, NumberOfTags = 15, ShowHeaderRssUrl = false, BlogCommentsMustBeApproved = false, ShowBlogCommentsPerStore = false }); await settingService.SaveSettingAsync(new NewsSettings { Enabled = true, AllowNotRegisteredUsersToLeaveComments = true, NotifyAboutNewNewsComments = false, ShowNewsOnMainPage = true, MainPageNewsCount = 3, NewsArchivePageSize = 10, ShowHeaderRssUrl = false, NewsCommentsMustBeApproved = false, ShowNewsCommentsPerStore = false }); await settingService.SaveSettingAsync(new ForumSettings { ForumsEnabled = false, RelativeDateTimeFormattingEnabled = true, AllowCustomersToDeletePosts = false, AllowCustomersToEditPosts = false, AllowCustomersToManageSubscriptions = false, AllowGuestsToCreatePosts = false, AllowGuestsToCreateTopics = false, AllowPostVoting = true, MaxVotesPerDay = 30, TopicSubjectMaxLength = 450, PostMaxLength = 4000, StrippedTopicMaxLength = 45, TopicsPageSize = 10, PostsPageSize = 10, SearchResultsPageSize = 10, ActiveDiscussionsPageSize = 50, LatestCustomerPostsPageSize = 10, ShowCustomersPostCount = true, ForumEditor = EditorType.BBCodeEditor, SignaturesEnabled = true, AllowPrivateMessages = false, ShowAlertForPM = false, PrivateMessagesPageSize = 10, ForumSubscriptionsPageSize = 10, NotifyAboutPrivateMessages = false, PMSubjectMaxLength = 450, PMTextMaxLength = 4000, HomepageActiveDiscussionsTopicCount = 5, ActiveDiscussionsFeedEnabled = false, ActiveDiscussionsFeedCount = 25, ForumFeedsEnabled = false, ForumFeedCount = 10, ForumSearchTermMinimumLength = 3 }); await settingService.SaveSettingAsync(new VendorSettings { DefaultVendorPageSizeOptions = "6, 3, 9", VendorsBlockItemsToDisplay = 0, ShowVendorOnProductDetailsPage = true, AllowCustomersToContactVendors = true, AllowCustomersToApplyForVendorAccount = true, TermsOfServiceEnabled = false, AllowVendorsToEditInfo = false, NotifyStoreOwnerAboutVendorInformationChange = true, MaximumProductNumber = 3000, AllowVendorsToImportProducts = true }); var eaGeneral = _emailAccountRepository.Table.FirstOrDefault() ?? throw new Exception("Default email account cannot be loaded"); await settingService.SaveSettingAsync(new EmailAccountSettings { DefaultEmailAccountId = eaGeneral.Id }); await settingService.SaveSettingAsync(new WidgetSettings { ActiveWidgetSystemNames = ["Widgets.NivoSlider"] }); await settingService.SaveSettingAsync(new DisplayDefaultMenuItemSettings { DisplayHomepageMenuItem = true, DisplayNewProductsMenuItem = true, DisplayProductSearchMenuItem = true, DisplayCustomerInfoMenuItem = true, DisplayBlogMenuItem = true, DisplayForumsMenuItem = true, DisplayContactUsMenuItem = true }); await settingService.SaveSettingAsync(new DisplayDefaultFooterItemSettings { DisplaySitemapFooterItem = true, DisplayContactUsFooterItem = true, DisplayProductSearchFooterItem = true, DisplayNewsFooterItem = true, DisplayBlogFooterItem = true, DisplayForumsFooterItem = true, DisplayRecentlyViewedProductsFooterItem = true, DisplayCompareProductsFooterItem = true, DisplayNewProductsFooterItem = true, DisplayCustomerInfoFooterItem = true, DisplayCustomerOrdersFooterItem = true, DisplayCustomerAddressesFooterItem = true, DisplayShoppingCartFooterItem = true, DisplayWishlistFooterItem = true, DisplayApplyVendorAccountFooterItem = true }); await settingService.SaveSettingAsync(new CaptchaSettings { ReCaptchaApiUrl = "https://www.google.com/recaptcha/", ReCaptchaDefaultLanguage = string.Empty, ReCaptchaPrivateKey = string.Empty, ReCaptchaPublicKey = string.Empty, ReCaptchaRequestTimeout = 20, ReCaptchaTheme = string.Empty, AutomaticallyChooseLanguage = true, Enabled = false, CaptchaType = CaptchaType.CheckBoxReCaptchaV2, ReCaptchaV3ScoreThreshold = 0.5M, ShowOnApplyVendorPage = false, ShowOnBlogCommentPage = false, ShowOnContactUsPage = false, ShowOnEmailProductToFriendPage = false, ShowOnEmailWishlistToFriendPage = false, ShowOnForgotPasswordPage = false, ShowOnForum = false, ShowOnLoginPage = false, ShowOnNewsCommentPage = false, ShowOnNewsletterPage = false, ShowOnProductReviewPage = false, ShowOnRegistrationPage = false, ShowOnCheckoutPageForGuests = false, }); await settingService.SaveSettingAsync(new MessagesSettings { UsePopupNotifications = false }); await settingService.SaveSettingAsync(new ProxySettings { Enabled = false, Address = string.Empty, Port = string.Empty, Username = string.Empty, Password = string.Empty, BypassOnLocal = true, PreAuthenticate = true }); await settingService.SaveSettingAsync(new CookieSettings { CompareProductsCookieExpires = 24 * 10, RecentlyViewedProductsCookieExpires = 24 * 10, CustomerCookieExpires = 24 * 365 }); await settingService.SaveSettingAsync(new RobotsTxtSettings { DisallowPaths = [ "/admin", "/bin/", "/files/", "/files/exportimport/", "/install", "/*?*returnUrl=", //AJAX urls "/cart/estimateshipping", "/cart/selectshippingoption", "/customer/addressdelete", "/customer/removeexternalassociation", "/customer/checkusernameavailability", "/catalog/searchtermautocomplete", "/catalog/getcatalogroot", "/addproducttocart/catalog/*", "/addproducttocart/details/*", "/compareproducts/add/*", "/backinstocksubscribe/*", "/subscribenewsletter", "/t-popup/*", "/setproductreviewhelpfulness", "/poll/vote", "/country/getstatesbycountryid/", "/eucookielawaccept", "/topic/authenticate", "/category/products/", "/product/combinations", "/uploadfileproductattribute/*", "/shoppingcart/productdetails_attributechange/*", "/uploadfilereturnrequest", "/boards/topicwatch/*", "/boards/forumwatch/*", "/install/restartapplication", "/boards/postvote", "/product/estimateshipping/*", "/shoppingcart/checkoutattributechange/*" ], LocalizableDisallowPaths = [ "/addproducttocart/catalog/", "/addproducttocart/details/", "/backinstocksubscriptions/manage", "/boards/forumsubscriptions", "/boards/forumwatch", "/boards/postedit", "/boards/postdelete", "/boards/postcreate", "/boards/topicedit", "/boards/topicdelete", "/boards/topiccreate", "/boards/topicmove", "/boards/topicwatch", "/cart$", "/changecurrency", "/changelanguage", "/changetaxtype", "/checkout", "/checkout/billingaddress", "/checkout/completed", "/checkout/confirm", "/checkout/shippingaddress", "/checkout/shippingmethod", "/checkout/paymentinfo", "/checkout/paymentmethod", "/clearcomparelist", "/compareproducts", "/compareproducts/add/*", "/customer/avatar", "/customer/activation", "/customer/addresses", "/customer/changepassword", "/customer/checkusernameavailability", "/customer/downloadableproducts", "/customer/info", "/customer/productreviews", "/deletepm", "/emailwishlist", "/eucookielawaccept", "/inboxupdate", "/newsletter/subscriptionactivation", "/onepagecheckout", "/order/history", "/orderdetails", "/passwordrecovery/confirm", "/poll/vote", "/privatemessages", "/recentlyviewedproducts", "/returnrequest", "/returnrequest/history", "/rewardpoints/history", "/search?", "/sendpm", "/sentupdate", "/shoppingcart/*", "/storeclosed", "/subscribenewsletter", "/topic/authenticate", "/viewpm", "/uploadfilecheckoutattribute", "/uploadfileproductattribute", "/uploadfilereturnrequest", "/wishlist" ] }); } /// A task that represents the asynchronous operation protected virtual async Task InstallCheckoutAttributesAsync() { var ca1 = await InsertInstallationDataAsync(new CheckoutAttribute { Name = "Gift wrapping", IsRequired = true, ShippableProductRequired = true, AttributeControlType = AttributeControlType.DropdownList, DisplayOrder = 1 }); await InsertInstallationDataAsync( new CheckoutAttributeValue { Name = "No", PriceAdjustment = 0, DisplayOrder = 1, IsPreSelected = true, AttributeId = ca1.Id }, new CheckoutAttributeValue { Name = "Yes", PriceAdjustment = 10, DisplayOrder = 2, AttributeId = ca1.Id }); } /// A task that represents the asynchronous operation protected virtual async Task InstallSpecificationAttributesAsync() { var sag1 = await InsertInstallationDataAsync( new SpecificationAttributeGroup { Name = "System unit" }); var sa1 = await InsertInstallationDataAsync( new SpecificationAttribute { Name = "Screensize", DisplayOrder = 1 }); await InsertInstallationDataAsync( new SpecificationAttributeOption { SpecificationAttributeId = sa1.Id, Name = "13.0''", DisplayOrder = 2 }, new SpecificationAttributeOption { SpecificationAttributeId = sa1.Id, Name = "13.3''", DisplayOrder = 3 }, new SpecificationAttributeOption { SpecificationAttributeId = sa1.Id, Name = "14.0''", DisplayOrder = 4 }, new SpecificationAttributeOption { SpecificationAttributeId = sa1.Id, Name = "15.0''", DisplayOrder = 4 }, new SpecificationAttributeOption { SpecificationAttributeId = sa1.Id, Name = "15.6''", DisplayOrder = 5 }); var sa2 = await InsertInstallationDataAsync( new SpecificationAttribute { Name = "CPU Type", DisplayOrder = 2, SpecificationAttributeGroupId = sag1.Id }); await InsertInstallationDataAsync( new SpecificationAttributeOption { SpecificationAttributeId = sa2.Id, Name = "Intel Core i5", DisplayOrder = 1 }, new SpecificationAttributeOption { SpecificationAttributeId = sa2.Id, Name = "Intel Core i7", DisplayOrder = 2 }); var sa3 = await InsertInstallationDataAsync( new SpecificationAttribute { Name = "Memory", DisplayOrder = 3, SpecificationAttributeGroupId = sag1.Id }); await InsertInstallationDataAsync( new SpecificationAttributeOption { SpecificationAttributeId = sa3.Id, Name = "4 GB", DisplayOrder = 1 }, new SpecificationAttributeOption { SpecificationAttributeId = sa3.Id, Name = "8 GB", DisplayOrder = 2 }, new SpecificationAttributeOption { SpecificationAttributeId = sa3.Id, Name = "16 GB", DisplayOrder = 3 }); var sa4 = await InsertInstallationDataAsync( new SpecificationAttribute { Name = "Hard drive", DisplayOrder = 5, SpecificationAttributeGroupId = sag1.Id }); await InsertInstallationDataAsync( new SpecificationAttributeOption { SpecificationAttributeId = sa4.Id, Name = "128 GB", DisplayOrder = 7 }, new SpecificationAttributeOption { SpecificationAttributeId = sa4.Id, Name = "500 GB", DisplayOrder = 4 }, new SpecificationAttributeOption { SpecificationAttributeId = sa4.Id, Name = "1 TB", DisplayOrder = 3 }); var sa5 = await InsertInstallationDataAsync( new SpecificationAttribute { Name = "Color", DisplayOrder = 1 }); await InsertInstallationDataAsync( new SpecificationAttributeOption { SpecificationAttributeId = sa5.Id, Name = "Grey", DisplayOrder = 2, ColorSquaresRgb = "#8a97a8" }, new SpecificationAttributeOption { SpecificationAttributeId = sa5.Id, Name = "Red", DisplayOrder = 3, ColorSquaresRgb = "#8a374a" }, new SpecificationAttributeOption { SpecificationAttributeId = sa5.Id, Name = "Blue", DisplayOrder = 4, ColorSquaresRgb = "#47476f" }); } /// A task that represents the asynchronous operation protected virtual async Task InstallProductAttributesAsync() { var productAttributes = new List { new() { Name = "Color" }, new() { Name = "Print" }, new() { Name = "Custom Text" }, new() { Name = "HDD" }, new() { Name = "OS" }, new() { Name = "Processor" }, new() { Name = "RAM" }, new() { Name = "Size" }, new() { Name = "Software" } }; await InsertInstallationDataAsync(productAttributes); } /// A task that represents the asynchronous operation protected virtual async Task InstallCategoriesAsync() { //pictures var pictureService = EngineContext.Current.Resolve(); var sampleImagesPath = GetSamplesPath(); var categoryTemplateInGridAndLines = _categoryTemplateRepository .Table.FirstOrDefault(pt => pt.Name == "Products in Grid or Lines") ?? throw new Exception("Category template cannot be loaded"); //categories var allCategories = new List(); var categoryComputers = new Category { Name = "Computers", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_computers.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Computers"))).Id, IncludeInTopMenu = true, Published = true, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryComputers); await InsertInstallationDataAsync(categoryComputers); var categoryDesktops = new Category { Name = "Desktops", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryComputers.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_desktops.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Desktops"))).Id, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, IncludeInTopMenu = true, Published = true, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryDesktops); await InsertInstallationDataAsync(categoryDesktops); var categoryNotebooks = new Category { Name = "Notebooks", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryComputers.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_notebooks.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Notebooks"))).Id, IncludeInTopMenu = true, Published = true, DisplayOrder = 2, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryNotebooks); await InsertInstallationDataAsync(categoryNotebooks); var categorySoftware = new Category { Name = "Software", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryComputers.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_software.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Software"))).Id, IncludeInTopMenu = true, Published = true, DisplayOrder = 3, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categorySoftware); await InsertInstallationDataAsync(categorySoftware); var categoryElectronics = new Category { Name = "Electronics", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_electronics.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Electronics"))).Id, IncludeInTopMenu = true, Published = true, ShowOnHomepage = true, DisplayOrder = 2, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryElectronics); await InsertInstallationDataAsync(categoryElectronics); var categoryCameraPhoto = new Category { Name = "Camera & photo", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryElectronics.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_camera_photo.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Camera, photo"))).Id, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, IncludeInTopMenu = true, Published = true, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryCameraPhoto); await InsertInstallationDataAsync(categoryCameraPhoto); var categoryCellPhones = new Category { Name = "Cell phones", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryElectronics.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_cell_phones.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Cell phones"))).Id, IncludeInTopMenu = true, Published = true, DisplayOrder = 2, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryCellPhones); await InsertInstallationDataAsync(categoryCellPhones); var categoryOthers = new Category { Name = "Others", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryElectronics.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_accessories.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Accessories"))).Id, IncludeInTopMenu = true, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, Published = true, DisplayOrder = 3, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryOthers); await InsertInstallationDataAsync(categoryOthers); var categoryApparel = new Category { Name = "Apparel", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_apparel.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Apparel"))).Id, IncludeInTopMenu = true, Published = true, ShowOnHomepage = true, DisplayOrder = 3, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryApparel); await InsertInstallationDataAsync(categoryApparel); var categoryShoes = new Category { Name = "Shoes", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryApparel.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_shoes.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Shoes"))).Id, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, IncludeInTopMenu = true, Published = true, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryShoes); await InsertInstallationDataAsync(categoryShoes); var categoryClothing = new Category { Name = "Clothing", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryApparel.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_clothing.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Clothing"))).Id, IncludeInTopMenu = true, Published = true, DisplayOrder = 2, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryClothing); await InsertInstallationDataAsync(categoryClothing); var categoryAccessories = new Category { Name = "Accessories", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", ParentCategoryId = categoryApparel.Id, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_apparel_accessories.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Apparel Accessories"))).Id, IncludeInTopMenu = true, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, Published = true, DisplayOrder = 3, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryAccessories); await InsertInstallationDataAsync(categoryAccessories); var categoryDigitalDownloads = new Category { Name = "Digital downloads", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_digital_downloads.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Digital downloads"))).Id, IncludeInTopMenu = true, Published = true, ShowOnHomepage = true, DisplayOrder = 4, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryDigitalDownloads); await InsertInstallationDataAsync(categoryDigitalDownloads); var categoryBooks = new Category { Name = "Books", CategoryTemplateId = categoryTemplateInGridAndLines.Id, MetaKeywords = "Books, Dictionary, Textbooks", MetaDescription = "Books category description", PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_book.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Book"))).Id, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, IncludeInTopMenu = true, Published = true, DisplayOrder = 5, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryBooks); await InsertInstallationDataAsync(categoryBooks); var categoryJewelry = new Category { Name = "Jewelry", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_jewelry.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Jewelry"))).Id, PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, IncludeInTopMenu = true, Published = true, DisplayOrder = 6, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryJewelry); await InsertInstallationDataAsync(categoryJewelry); var categoryGiftCards = new Category { Name = "Gift Cards", CategoryTemplateId = categoryTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "category_gift_cards.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync("Gift Cards"))).Id, IncludeInTopMenu = true, Published = true, DisplayOrder = 7, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allCategories.Add(categoryGiftCards); await InsertInstallationDataAsync(categoryGiftCards); //search engine names foreach (var category in allCategories) await InsertInstallationDataAsync(new UrlRecord { EntityId = category.Id, EntityName = nameof(Category), LanguageId = 0, IsActive = true, Slug = await ValidateSeNameAsync(category, category.Name) }); } /// A task that represents the asynchronous operation protected virtual async Task InstallManufacturersAsync() { var pictureService = EngineContext.Current.Resolve(); var sampleImagesPath = GetSamplesPath(); var manufacturerTemplateInGridAndLines = _manufacturerTemplateRepository.Table.FirstOrDefault(pt => pt.Name == "Products in Grid or Lines") ?? throw new Exception("Manufacturer template cannot be loaded"); var allManufacturers = new List(); var manufacturerAsus = new Manufacturer { Name = "Apple", ManufacturerTemplateId = manufacturerTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, Published = true, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "manufacturer_apple.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Apple"))).Id, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(manufacturerAsus); allManufacturers.Add(manufacturerAsus); var manufacturerHp = new Manufacturer { Name = "HP", ManufacturerTemplateId = manufacturerTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, Published = true, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "manufacturer_hp.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Hp"))).Id, DisplayOrder = 5, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(manufacturerHp); allManufacturers.Add(manufacturerHp); var manufacturerNike = new Manufacturer { Name = "Nike", ManufacturerTemplateId = manufacturerTemplateInGridAndLines.Id, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9", Published = true, PictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "manufacturer_nike.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Nike"))).Id, DisplayOrder = 5, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(manufacturerNike); allManufacturers.Add(manufacturerNike); //search engine names foreach (var manufacturer in allManufacturers) await InsertInstallationDataAsync(new UrlRecord { EntityId = manufacturer.Id, EntityName = nameof(Manufacturer), LanguageId = 0, IsActive = true, Slug = await ValidateSeNameAsync(manufacturer, manufacturer.Name) }); } /// A task that represents the asynchronous operation protected virtual async Task InstallComputersAsync(ProductTemplate productTemplateSimple, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts) { var productBuildComputer = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Build your own computer", Sku = "COMP_CUST", ShortDescription = "Build it", FullDescription = "

Fight back against cluttered workspaces with the stylish IBM zBC12 All-in-One desktop PC, featuring powerful computing resources and a stunning 20.1-inch widescreen display with stunning XBRITE-HiColor LCD technology. The black IBM zBC12 has a built-in microphone and MOTION EYE camera with face-tracking technology that allows for easy communication with friends and family. And it has a built-in DVD burner and Sony's Movie Store software so you can create a digital entertainment library for personal viewing at your convenience. Easy to setup and even easier to use, this JS-series All-in-One includes an elegantly designed keyboard and a USB mouse.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "build-your-own-computer", AllowCustomerReviews = true, Price = 1200M, IsShipEnabled = true, IsFreeShipping = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, ShowOnHomepage = true, MarkAsNew = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productBuildComputer); await InsertInstallationDataAsync(productBuildComputer); await InsertInstallationDataAsync(new ProductCategory { ProductId = productBuildComputer.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Desktops").Id, DisplayOrder = 1 }); var picProductDesktops1 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_Desktops_1.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productBuildComputer.Name)); var picProductDesktops2 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_Desktops_2.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productBuildComputer.Name)); await InsertInstallationDataAsync( new ProductPicture { ProductId = productBuildComputer.Id, PictureId = picProductDesktops1.Id, DisplayOrder = 1 }, new ProductPicture { ProductId = productBuildComputer.Id, PictureId = picProductDesktops2.Id, DisplayOrder = 2 }); var pamProcessor = await InsertInstallationDataAsync(new ProductAttributeMapping { ProductId = productBuildComputer.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Processor").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamProcessor.Id, AttributeValueType = AttributeValueType.Simple, Name = "2.2 GHz Intel Pentium Dual-Core E2200", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamProcessor.Id, AttributeValueType = AttributeValueType.Simple, Name = "2.5 GHz Intel Pentium Dual-Core E2200", IsPreSelected = true, PriceAdjustment = 15, DisplayOrder = 2 }); var pamRam = await InsertInstallationDataAsync(new ProductAttributeMapping { ProductId = productBuildComputer.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "RAM").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamRam.Id, AttributeValueType = AttributeValueType.Simple, Name = "2 GB", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamRam.Id, AttributeValueType = AttributeValueType.Simple, Name = "4GB", PriceAdjustment = 20, DisplayOrder = 2 }, new ProductAttributeValue { ProductAttributeMappingId = pamRam.Id, AttributeValueType = AttributeValueType.Simple, Name = "8GB", PriceAdjustment = 60, DisplayOrder = 3 }); var pamHdd = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productBuildComputer.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "HDD").Id, AttributeControlType = AttributeControlType.RadioList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamHdd.Id, AttributeValueType = AttributeValueType.Simple, Name = "320 GB", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamHdd.Id, AttributeValueType = AttributeValueType.Simple, Name = "400 GB", PriceAdjustment = 100, DisplayOrder = 2 }); var pamOs = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productBuildComputer.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "OS").Id, AttributeControlType = AttributeControlType.RadioList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamOs.Id, AttributeValueType = AttributeValueType.Simple, Name = "Vista Home", PriceAdjustment = 50, IsPreSelected = true, DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamOs.Id, AttributeValueType = AttributeValueType.Simple, Name = "Vista Premium", PriceAdjustment = 60, DisplayOrder = 2 }); var pamSoftware = await InsertInstallationDataAsync(new ProductAttributeMapping { ProductId = productBuildComputer.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Software").Id, AttributeControlType = AttributeControlType.Checkboxes }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamSoftware.Id, AttributeValueType = AttributeValueType.Simple, Name = "Microsoft Office", PriceAdjustment = 50, IsPreSelected = true, DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamSoftware.Id, AttributeValueType = AttributeValueType.Simple, Name = "Acrobat Reader", PriceAdjustment = 10, DisplayOrder = 2 }, new ProductAttributeValue { ProductAttributeMappingId = pamSoftware.Id, AttributeValueType = AttributeValueType.Simple, Name = "Total Commander", PriceAdjustment = 5, DisplayOrder = 2 }); await AddProductTagAsync(productBuildComputer, "awesome"); await AddProductTagAsync(productBuildComputer, "computer"); var productDigitalStorm = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Digital Storm VANQUISH Custom Performance PC", Sku = "DS_VA3_PC", ShortDescription = "Digital Storm Vanquish 3 Desktop PC", FullDescription = "

Blow the doors off today’s most demanding games with maximum detail, speed, and power for an immersive gaming experience without breaking the bank.

Stay ahead of the competition, VANQUISH 3 is fully equipped to easily handle future upgrades, keeping your system on the cutting edge for years to come.

Each system is put through an extensive stress test, ensuring you experience zero bottlenecks and get the maximum performance from your hardware.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "compaq-presario-sr1519x-pentium-4-desktop-pc-with-cdrw", AllowCustomerReviews = true, Price = 1259M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productDigitalStorm); await InsertInstallationDataAsync(productDigitalStorm); await InsertInstallationDataAsync(new ProductCategory { ProductId = productDigitalStorm.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Desktops").Id, DisplayOrder = 1 }); var picProductDigitalStorm = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_DigitalStorm.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productDigitalStorm.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productDigitalStorm.Id, PictureId = picProductDigitalStorm.Id, DisplayOrder = 1 }); await AddProductTagAsync(productDigitalStorm, "cool"); await AddProductTagAsync(productDigitalStorm, "computer"); var productLenovoIdeaCentre = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Lenovo IdeaCentre", Sku = "LE_IC_600", ShortDescription = string.Empty, FullDescription = "

The A600 features a 21.5in screen, DVD or optional Blu-Ray drive, support for the full beans 1920 x 1080 HD, Dolby Home Cinema certification and an optional hybrid analogue/digital TV tuner.

Connectivity is handled by 802.11a/b/g - 802.11n is optional - and an ethernet port. You also get four USB ports, a Firewire slot, a six-in-one card reader and a 1.3- or two-megapixel webcam.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "hp-iq506-touchsmart-desktop-pc", AllowCustomerReviews = true, Price = 500M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productLenovoIdeaCentre); await InsertInstallationDataAsync(productLenovoIdeaCentre); await InsertInstallationDataAsync(new ProductCategory { ProductId = productLenovoIdeaCentre.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Desktops").Id, DisplayOrder = 1 }); var picProductLenovoIdeaCentre = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_LenovoIdeaCentre.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productLenovoIdeaCentre.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productLenovoIdeaCentre.Id, PictureId = picProductLenovoIdeaCentre.Id, DisplayOrder = 1 }); await AddProductTagAsync(productLenovoIdeaCentre, "awesome"); await AddProductTagAsync(productLenovoIdeaCentre, "computer"); var productAppleMacBookPro = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Apple MacBook Pro", Sku = "AP_MBP_13", ShortDescription = "A groundbreaking Retina display. A new force-sensing trackpad. All-flash architecture. Powerful dual-core and quad-core Intel processors. Together, these features take the notebook to a new level of performance. And they will do the same for you in everything you create.", FullDescription = "

With fifth-generation Intel Core processors, the latest graphics, and faster flash storage, the incredibly advanced MacBook Pro with Retina display moves even further ahead in performance and battery life.* *Compared with the previous generation.

Retina display with 2560-by-1600 resolution

Fifth-generation dual-core Intel Core i5 processor

Intel Iris Graphics

Up to 9 hours of battery life1

Faster flash storage2

802.11ac Wi-Fi

Two Thunderbolt 2 ports for connecting high-performance devices and transferring data at lightning speed

Two USB 3 ports (compatible with USB 2 devices) and HDMI

FaceTime HD camera

Pages, Numbers, Keynote, iPhoto, iMovie, GarageBand included

OS X, the world's most advanced desktop operating system

", ProductTemplateId = productTemplateSimple.Id, //SeName = "asus-eee-pc-1000ha-10-inch-netbook", AllowCustomerReviews = true, Price = 1800M, IsShipEnabled = true, IsFreeShipping = true, Weight = 3, Length = 3, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 2, OrderMaximumQuantity = 10000, Published = true, ShowOnHomepage = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productAppleMacBookPro); await InsertInstallationDataAsync(productAppleMacBookPro); await InsertInstallationDataAsync(new ProductCategory { ProductId = productAppleMacBookPro.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Notebooks").Id, DisplayOrder = 1 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productAppleMacBookPro.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "Apple").Id, DisplayOrder = 2 }); var picProductMacBook1 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_macbook_1.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productAppleMacBookPro.Name)); var picProductMacBook2 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_macbook_2.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productAppleMacBookPro.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productAppleMacBookPro.Id, PictureId = picProductMacBook1.Id, DisplayOrder = 1 }, new ProductPicture { ProductId = productAppleMacBookPro.Id, PictureId = picProductMacBook2.Id, DisplayOrder = 2 }); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productAppleMacBookPro.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Screensize", "13.0''") }, new ProductSpecificationAttribute { ProductId = productAppleMacBookPro.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("CPU Type", "Intel Core i5") }, new ProductSpecificationAttribute { ProductId = productAppleMacBookPro.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 3, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Memory", "4 GB") }); await AddProductTagAsync(productAppleMacBookPro, "compact"); await AddProductTagAsync(productAppleMacBookPro, "awesome"); await AddProductTagAsync(productAppleMacBookPro, "computer"); var productAsusN551JK = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Asus Laptop", Sku = "AS_551_LP", ShortDescription = "Laptop Asus N551JK Intel Core i7-4710HQ 2.5 GHz, RAM 16GB, HDD 1TB, Video NVidia GTX 850M 4GB, BluRay, 15.6, Full HD, Win 8.1", FullDescription = "

The ASUS N550JX combines cutting-edge audio and visual technology to deliver an unsurpassed multimedia experience. A full HD wide-view IPS panel is tailor-made for watching movies and the intuitive touchscreen makes for easy, seamless navigation. ASUS has paired the N550JX’s impressive display with SonicMaster Premium, co-developed with Bang & Olufsen ICEpower® audio experts, for true surround sound. A quad-speaker array and external subwoofer combine for distinct vocals and a low bass that you can feel.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "asus-eee-pc-900ha-89-inch-netbook-black", AllowCustomerReviews = true, Price = 1500M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productAsusN551JK); await InsertInstallationDataAsync(productAsusN551JK); await InsertInstallationDataAsync(new ProductCategory { ProductId = productAsusN551JK.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Notebooks").Id, DisplayOrder = 1 }); var picProductAsuspcN551Jk = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_asuspc_N551JK.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productAsusN551JK.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productAsusN551JK.Id, PictureId = picProductAsuspcN551Jk.Id, DisplayOrder = 1 }); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productAsusN551JK.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Screensize", "15.6''") }, new ProductSpecificationAttribute { ProductId = productAsusN551JK.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("CPU Type", "Intel Core i7") }, new ProductSpecificationAttribute { ProductId = productAsusN551JK.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 3, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Memory", "16 GB") }, new ProductSpecificationAttribute { ProductId = productAsusN551JK.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 4, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Hard drive", "1 TB") }); await AddProductTagAsync(productAsusN551JK, "compact"); await AddProductTagAsync(productAsusN551JK, "awesome"); await AddProductTagAsync(productAsusN551JK, "computer"); var productSamsungSeries = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Samsung Premium Ultrabook", Sku = "SM_900_PU", ShortDescription = "Samsung Series 9 NP900X4C-A06US 15-Inch Ultrabook (1.70 GHz Intel Core i5-3317U Processor, 8GB DDR3, 128GB SSD, Windows 8) Ash Black", FullDescription = "

Designed with mobility in mind, Samsung's durable, ultra premium, lightweight Series 9 laptop (model NP900X4C-A01US) offers mobile professionals and power users a sophisticated laptop equally suited for work and entertainment. Featuring a minimalist look that is both simple and sophisticated, its polished aluminum uni-body design offers an iconic look and feel that pushes the envelope with an edge just 0.58 inches thin. This Series 9 laptop also includes a brilliant 15-inch SuperBright Plus display with HD+ technology, 128 GB Solid State Drive (SSD), 8 GB of system memory, and up to 10 hours of battery life.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "hp-pavilion-artist-edition-dv2890nr-141-inch-laptop", AllowCustomerReviews = true, Price = 1590M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, //ShowOnHomepage = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productSamsungSeries); await InsertInstallationDataAsync(productSamsungSeries); await InsertInstallationDataAsync(new ProductCategory { ProductId = productSamsungSeries.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Notebooks").Id, DisplayOrder = 1 }); var picProductSamsungNp900X4C = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_SamsungNP900X4C.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productSamsungSeries.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productSamsungSeries.Id, PictureId = picProductSamsungNp900X4C.Id, DisplayOrder = 1 }); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productSamsungSeries.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Screensize", "15.0''") }, new ProductSpecificationAttribute { ProductId = productSamsungSeries.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("CPU Type", "Intel Core i5") }, new ProductSpecificationAttribute { ProductId = productSamsungSeries.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 3, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Memory", "8 GB") }, new ProductSpecificationAttribute { ProductId = productSamsungSeries.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 4, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Hard drive", "128 GB") }); await AddProductTagAsync(productSamsungSeries, "nice"); await AddProductTagAsync(productSamsungSeries, "computer"); await AddProductTagAsync(productSamsungSeries, "compact"); var productHpSpectre = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "HP Spectre XT Pro UltraBook", Sku = "HP_SPX_UB", ShortDescription = "HP Spectre XT Pro UltraBook / Intel Core i5-2467M / 13.3 / 4GB / 128GB / Windows 7 Professional / Laptop", FullDescription = "

Introducing HP ENVY Spectre XT, the Ultrabook designed for those who want style without sacrificing substance. It's sleek. It's thin. And with Intel. Corer i5 processor and premium materials, it's designed to go anywhere from the bistro to the boardroom, it's unlike anything you've ever seen from HP.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "hp-pavilion-elite-m9150f-desktop-pc", AllowCustomerReviews = true, Price = 1350M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productHpSpectre); await InsertInstallationDataAsync(productHpSpectre); await InsertInstallationDataAsync(new ProductCategory { ProductId = productHpSpectre.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Notebooks").Id, DisplayOrder = 1 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productHpSpectre.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "HP").Id, DisplayOrder = 3 }); var picProductHpSpectreXt1 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_HPSpectreXT_1.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productHpSpectre.Name)); var picProductHpSpectreXt2 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_HPSpectreXT_2.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productHpSpectre.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productHpSpectre.Id, PictureId = picProductHpSpectreXt1.Id, DisplayOrder = 1 }, new ProductPicture { ProductId = productHpSpectre.Id, PictureId = picProductHpSpectreXt2.Id, DisplayOrder = 2 }); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productHpSpectre.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Screensize", "13.3''") }, new ProductSpecificationAttribute { ProductId = productHpSpectre.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("CPU Type", "Intel Core i5") }, new ProductSpecificationAttribute { ProductId = productHpSpectre.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 3, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Memory", "4 GB") }, new ProductSpecificationAttribute { ProductId = productHpSpectre.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 4, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Hard drive", "128 GB") }); await AddProductTagAsync(productHpSpectre, "nice"); await AddProductTagAsync(productHpSpectre, "computer"); var productHpEnvy = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "HP Envy 15.6-Inch Sleekbook", Sku = "HP_ESB_15", ShortDescription = "HP ENVY 6-1202ea Ultrabook Beats Audio, 3rd generation Intel® CoreTM i7-3517U processor, 8GB RAM, 500GB HDD, Microsoft Windows 8, AMD Radeon HD 8750M (2 GB DDR3 dedicated)", FullDescription = "The UltrabookTM that's up for anything. Thin and light, the HP ENVY is the large screen UltrabookTM with Beats AudioTM. With a soft-touch base that makes it easy to grab and go, it's a laptop that's up for anything.

Features

- Windows 8 or other operating systems available

Top performance. Stylish design. Take notice.

- At just 19.8 mm (0.78 in) thin, the HP ENVY UltrabookTM is slim and light enough to take anywhere. It's the laptop that gets you noticed with the power to get it done.
- With an eye-catching metal design, it's a laptop that you want to carry with you. The soft-touch, slip-resistant base gives you the confidence to carry it with ease.

More entertaining. More gaming. More fun.

- Own the UltrabookTM with Beats AudioTM, dual speakers, a subwoofer, and an awesome display. Your music, movies and photo slideshows will always look and sound their best.
- Tons of video memory let you experience incredible gaming and multimedia without slowing down. Create and edit videos in a flash. And enjoy more of what you love to the fullest.
- The HP ENVY UltrabookTM is loaded with the ports you'd expect on a world-class laptop, but on a Sleekbook instead. Like HDMI, USB, RJ-45, and a headphone jack. You get all the right connections without compromising size.

Only from HP.

- Life heats up. That's why there's HP CoolSense technology, which automatically adjusts your notebook's temperature based on usage and conditions. It stays cool. You stay comfortable.
- With HP ProtectSmart, your notebook's data stays safe from accidental bumps and bruises. It senses motion and plans ahead, stopping your hard drive and protecting your entire digital life.
- Keep playing even in dimly lit rooms or on red eye flights. The optional backlit keyboard[1] is full-size so you don't compromise comfort. Backlit keyboard. Another bright idea.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "hp-pavilion-g60-230us-160-inch-laptop", AllowCustomerReviews = true, Price = 1460M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productHpEnvy); await InsertInstallationDataAsync(productHpEnvy); await InsertInstallationDataAsync(new ProductCategory { ProductId = productHpEnvy.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Notebooks").Id, DisplayOrder = 1 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productHpEnvy.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "HP").Id, DisplayOrder = 4 }); var picProductHpEnvy6 = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_HpEnvy6.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productHpEnvy.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productHpEnvy.Id, PictureId = picProductHpEnvy6.Id, DisplayOrder = 1 }); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productHpEnvy.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Screensize", "15.6''") }, new ProductSpecificationAttribute { ProductId = productHpEnvy.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("CPU Type", "Intel Core i7") }, new ProductSpecificationAttribute { ProductId = productHpEnvy.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 3, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Memory", "8 GB") }, new ProductSpecificationAttribute { ProductId = productHpEnvy.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 4, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Hard drive", "500 GB") }); await AddProductTagAsync(productHpEnvy, "computer"); await AddProductTagAsync(productHpEnvy, "cool"); await AddProductTagAsync(productHpEnvy, "compact"); var productLenovoThinkpad = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Lenovo Thinkpad Carbon Laptop", Sku = "LE_TX1_CL", ShortDescription = "Lenovo Thinkpad X1 Carbon Touch Intel Core i7 14 Ultrabook", FullDescription = "

The X1 Carbon brings a new level of quality to the ThinkPad legacy of high standards and innovation. It starts with the durable, carbon fiber-reinforced roll cage, making for the best Ultrabook construction available, and adds a host of other new features on top of the old favorites. Because for 20 years, we haven't stopped innovating. And you shouldn't stop benefiting from that.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "toshiba-satellite-a305-s6908-154-inch-laptop", AllowCustomerReviews = true, Price = 1360M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productLenovoThinkpad); await InsertInstallationDataAsync(productLenovoThinkpad); await InsertInstallationDataAsync(new ProductCategory { ProductId = productLenovoThinkpad.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Notebooks").Id, DisplayOrder = 1 }); var picProductLenovoThinkpad = await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "product_LenovoThinkpad.jpeg")), MimeTypes.ImageJpeg, await pictureService.GetPictureSeNameAsync(productLenovoThinkpad.Name)); await InsertInstallationDataAsync(new ProductPicture { ProductId = productLenovoThinkpad.Id, PictureId = picProductLenovoThinkpad.Id, DisplayOrder = 1 }); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productLenovoThinkpad.Id, AllowFiltering = false, ShowOnProductPage = true, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Screensize", "14.0''") }, new ProductSpecificationAttribute { ProductId = productLenovoThinkpad.Id, AllowFiltering = true, ShowOnProductPage = true, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("CPU Type", "Intel Core i7") }); await AddProductTagAsync(productLenovoThinkpad, "awesome"); await AddProductTagAsync(productLenovoThinkpad, "computer"); await AddProductTagAsync(productLenovoThinkpad, "compact"); var productAdobePhotoshop = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Adobe Photoshop", Sku = "AD_CS4_PH", ShortDescription = "Easily find and view all your photos", FullDescription = "

Adobe Photoshop CS4 software combines power and simplicity so you can make ordinary photos extraordinary; tell engaging stories in beautiful, personalized creations for print and web; and easily find and view all your photos. New Photoshop.com membership* works with Photoshop CS4 so you can protect your photos with automatic online backup and 2 GB of storage; view your photos anywhere you are; and share your photos in fun, interactive ways with invitation-only Online Albums.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "adobe-photoshop-elements-7", AllowCustomerReviews = true, Price = 75M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productAdobePhotoshop); await InsertInstallationDataAsync(productAdobePhotoshop); await InsertInstallationDataAsync(new ProductCategory { ProductId = productAdobePhotoshop.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Software").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productAdobePhotoshop, "product_AdobePhotoshop.jpeg"); await AddProductTagAsync(productAdobePhotoshop, "computer"); await AddProductTagAsync(productAdobePhotoshop, "awesome"); var productWindows8Pro = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Microsoft Windows OS", Sku = "MS_WIN_8P", ShortDescription = "Windows 8 is a Microsoft operating system that was released in 2012 as part of the company's Windows NT OS family. ", FullDescription = "

Windows 8 Pro is comparable to Windows 7 Professional and Ultimate and is targeted towards enthusiasts and business users; it includes all the features of Windows 8. Additional features include the ability to receive Remote Desktop connections, the ability to participate in a Windows Server domain, Encrypting File System, Hyper-V, and Virtual Hard Disk Booting, Group Policy as well as BitLocker and BitLocker To Go. Windows Media Center functionality is available only for Windows 8 Pro as a separate software package.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "corel-paint-shop-pro-photo-x2", AllowCustomerReviews = true, Price = 65M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productWindows8Pro); await InsertInstallationDataAsync(productWindows8Pro); await InsertInstallationDataAsync(new ProductCategory { ProductId = productWindows8Pro.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Software").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productWindows8Pro, "product_Windows.jpeg"); await AddProductTagAsync(productWindows8Pro, "awesome"); await AddProductTagAsync(productWindows8Pro, "computer"); var productSoundForge = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Sound Forge Pro (recurring)", Sku = "SF_PRO_11", ShortDescription = "Advanced audio waveform editor.", FullDescription = "

Sound Forge™ Pro is the application of choice for a generation of creative and prolific artists, producers, and editors. Record audio quickly on a rock-solid platform, address sophisticated audio processing tasks with surgical precision, and render top-notch master files with ease. New features include one-touch recording, metering for the new critical standards, more repair and restoration tools, and exclusive round-trip interoperability with SpectraLayers Pro. Taken together, these enhancements make this edition of Sound Forge Pro the deepest and most advanced audio editing platform available.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "major-league-baseball-2k9", IsRecurring = true, RecurringCycleLength = 30, RecurringCyclePeriod = RecurringProductCyclePeriod.Months, RecurringTotalCycles = 12, AllowCustomerReviews = true, Price = 54.99M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productSoundForge); await InsertInstallationDataAsync(productSoundForge); await InsertInstallationDataAsync(new ProductCategory { ProductId = productSoundForge.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Software").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productSoundForge, "product_SoundForge.jpeg"); await AddProductTagAsync(productSoundForge, "game"); await AddProductTagAsync(productSoundForge, "computer"); await AddProductTagAsync(productSoundForge, "cool"); relatedProducts.AddRange(new[] { new RelatedProduct { ProductId1 = productLenovoIdeaCentre.Id, ProductId2 = productDigitalStorm.Id }, new RelatedProduct { ProductId1 = productDigitalStorm.Id, ProductId2 = productBuildComputer.Id }, new RelatedProduct { ProductId1 = productDigitalStorm.Id, ProductId2 = productLenovoIdeaCentre.Id }, new RelatedProduct { ProductId1 = productDigitalStorm.Id, ProductId2 = productLenovoThinkpad.Id }, new RelatedProduct { ProductId1 = productDigitalStorm.Id, ProductId2 = productAppleMacBookPro.Id }, new RelatedProduct { ProductId1 = productLenovoIdeaCentre.Id, ProductId2 = productBuildComputer.Id }, new RelatedProduct { ProductId1 = productAsusN551JK.Id, ProductId2 = productLenovoThinkpad.Id }, new RelatedProduct { ProductId1 = productAsusN551JK.Id, ProductId2 = productAppleMacBookPro.Id }, new RelatedProduct { ProductId1 = productAsusN551JK.Id, ProductId2 = productSamsungSeries.Id }, new RelatedProduct { ProductId1 = productAsusN551JK.Id, ProductId2 = productHpSpectre.Id }, new RelatedProduct { ProductId1 = productLenovoThinkpad.Id, ProductId2 = productAsusN551JK.Id }, new RelatedProduct { ProductId1 = productLenovoThinkpad.Id, ProductId2 = productAppleMacBookPro.Id }, new RelatedProduct { ProductId1 = productLenovoThinkpad.Id, ProductId2 = productSamsungSeries.Id }, new RelatedProduct { ProductId1 = productLenovoThinkpad.Id, ProductId2 = productHpEnvy.Id }, new RelatedProduct { ProductId1 = productAppleMacBookPro.Id, ProductId2 = productLenovoThinkpad.Id }, new RelatedProduct { ProductId1 = productAppleMacBookPro.Id, ProductId2 = productSamsungSeries.Id }, new RelatedProduct { ProductId1 = productAppleMacBookPro.Id, ProductId2 = productAsusN551JK.Id }, new RelatedProduct { ProductId1 = productAppleMacBookPro.Id, ProductId2 = productHpSpectre.Id }, new RelatedProduct { ProductId1 = productHpSpectre.Id, ProductId2 = productLenovoThinkpad.Id }, new RelatedProduct { ProductId1 = productHpSpectre.Id, ProductId2 = productSamsungSeries.Id }, new RelatedProduct { ProductId1 = productHpSpectre.Id, ProductId2 = productAsusN551JK.Id }, new RelatedProduct { ProductId1 = productHpSpectre.Id, ProductId2 = productHpEnvy.Id }, new RelatedProduct { ProductId1 = productHpEnvy.Id, ProductId2 = productAsusN551JK.Id }, new RelatedProduct { ProductId1 = productHpEnvy.Id, ProductId2 = productAppleMacBookPro.Id }, new RelatedProduct { ProductId1 = productHpEnvy.Id, ProductId2 = productHpSpectre.Id }, new RelatedProduct { ProductId1 = productHpEnvy.Id, ProductId2 = productSamsungSeries.Id }, new RelatedProduct { ProductId1 = productSamsungSeries.Id, ProductId2 = productAsusN551JK.Id }, new RelatedProduct { ProductId1 = productSamsungSeries.Id, ProductId2 = productAppleMacBookPro.Id }, new RelatedProduct { ProductId1 = productSamsungSeries.Id, ProductId2 = productHpEnvy.Id }, new RelatedProduct { ProductId1 = productSamsungSeries.Id, ProductId2 = productHpSpectre.Id }, new RelatedProduct { ProductId1 = productLenovoIdeaCentre.Id, ProductId2 = productLenovoThinkpad.Id }, new RelatedProduct { ProductId1 = productLenovoIdeaCentre.Id, ProductId2 = productAppleMacBookPro.Id } }); } /// A task that represents the asynchronous operation protected virtual async Task InstallElectronicsAsync(ProductTemplate productTemplateSimple, ProductTemplate productTemplateGrouped, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts) { //this one is a grouped product with two associated ones var productNikonD5500DSLR = new Product { ProductType = ProductType.GroupedProduct, VisibleIndividually = true, Name = "Nikon D5500 DSLR", Sku = "N5500DS_0", ShortDescription = "Slim, lightweight Nikon D5500 packs a vari-angle touchscreen", FullDescription = "Nikon has announced its latest DSLR, the D5500. A lightweight, compact DX-format camera with a 24.2MP sensor, it’s the first of its type to offer a vari-angle touchscreen. The D5500 replaces the D5300 in Nikon’s range, and while it offers much the same features the company says it’s a much slimmer and lighter prospect. There’s a deep grip for easier handling and built-in Wi-Fi that lets you transfer and share shots via your phone or tablet.", ProductTemplateId = productTemplateGrouped.Id, //SeName = "canon-digital-slr-camera", AllowCustomerReviews = true, Published = true, Price = 670M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNikonD5500DSLR); await InsertInstallationDataAsync(productNikonD5500DSLR); await InsertInstallationDataAsync(new ProductCategory { ProductId = productNikonD5500DSLR.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Camera & photo").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productNikonD5500DSLR, "product_NikonCamera_1.jpeg"); await InsertProductPictureAsync(productNikonD5500DSLR, "product_NikonCamera_2.jpeg", 2); await AddProductTagAsync(productNikonD5500DSLR, "cool"); await AddProductTagAsync(productNikonD5500DSLR, "camera"); var productNikonD5500DslrAssociated1 = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = false, //hide this products ParentGroupedProductId = productNikonD5500DSLR.Id, Name = "Nikon D5500 DSLR - Black", Sku = "N5500DS_B", ProductTemplateId = productTemplateSimple.Id, //SeName = "canon-digital-slr-camera-black", AllowCustomerReviews = true, Published = true, Price = 670M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNikonD5500DslrAssociated1); await InsertInstallationDataAsync(productNikonD5500DslrAssociated1); await InsertProductPictureAsync(productNikonD5500DslrAssociated1, "product_NikonCamera_black.jpeg"); var productNikonD5500DslrAssociated2 = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = false, //hide this products ParentGroupedProductId = productNikonD5500DSLR.Id, Name = "Nikon D5500 DSLR - Red", Sku = "N5500DS_R", ProductTemplateId = productTemplateSimple.Id, //SeName = "canon-digital-slr-camera-silver", AllowCustomerReviews = true, Published = true, Price = 630M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNikonD5500DslrAssociated2); await InsertInstallationDataAsync(productNikonD5500DslrAssociated2); await InsertProductPictureAsync(productNikonD5500DslrAssociated2, "product_NikonCamera_red.jpeg"); var productLeica = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Leica T Mirrorless Digital Camera", Sku = "LT_MIR_DC", ShortDescription = "Leica T (Typ 701) Silver", FullDescription = "

The new Leica T offers a minimalist design that's crafted from a single block of aluminum. Made in Germany and assembled by hand, this 16.3 effective mega pixel camera is easy to use. With a massive 3.7 TFT LCD intuitive touch screen control, the user is able to configure and save their own menu system. The Leica T has outstanding image quality and also has 16GB of built in memory. This is Leica's first system camera to use Wi-Fi. Add the T-App to your portable iOS device and be able to transfer and share your images (free download from the Apple App Store)

", ProductTemplateId = productTemplateSimple.Id, //SeName = "canon-vixia-hf100-camcorder", AllowCustomerReviews = true, Price = 530M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productLeica); await InsertInstallationDataAsync(productLeica); await InsertInstallationDataAsync(new ProductCategory { ProductId = productLeica.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Camera & photo").Id, DisplayOrder = 3 }); await InsertProductPictureAsync(productLeica, "product_LeicaT.jpeg"); await AddProductTagAsync(productLeica, "camera"); await AddProductTagAsync(productLeica, "cool"); var productAppleICam = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Apple iCam", Sku = "APPLE_CAM", ShortDescription = "Photography becomes smart", FullDescription = "

A few months ago we featured the amazing WVIL camera, by many considered the future of digital photography. This is another very good looking concept, iCam is the vision of Italian designer Antonio DeRosa, the idea is to have a device that attaches to the iPhone 5, which then allows the user to have a camera with interchangeable lenses. The device would also feature a front-touch screen and a projector. Would be great if apple picked up on this and made it reality.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "panasonic-hdc-sdt750k-high-definition-3d-camcorder", AllowCustomerReviews = true, Price = 1300M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productAppleICam); await InsertInstallationDataAsync(productAppleICam); await InsertInstallationDataAsync(new ProductCategory { ProductId = productAppleICam.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Camera & photo").Id, DisplayOrder = 2 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productAppleICam.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "Apple").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productAppleICam, "product_iCam.jpeg"); var productHtcOne = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "HTC smartphone", Sku = "M8_HTC_5L", ShortDescription = "HTC - One (M8) 4G LTE Cell Phone with 32GB Memory - Gunmetal (Sprint)", FullDescription = "

HTC One (M8) Cell Phone for Sprint: With its brushed-metal design and wrap-around unibody frame, the HTC One (M8) is designed to fit beautifully in your hand. It's fun to use with amped up sound and a large Full HD touch screen, and intuitive gesture controls make it seem like your phone almost knows what you need before you do.

Sprint Easy Pay option available in store.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "blackberry-bold-9000-phone-black-att", AllowCustomerReviews = true, Price = 245M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, ShowOnHomepage = true, MarkAsNew = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productHtcOne); await InsertInstallationDataAsync(productHtcOne); await InsertInstallationDataAsync(new ProductCategory { ProductId = productHtcOne.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Cell phones").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productHtcOne, "product_HTC_One_M8.jpeg"); await AddProductTagAsync(productHtcOne, "cell"); await AddProductTagAsync(productHtcOne, "compact"); await AddProductTagAsync(productHtcOne, "awesome"); var productHtcOneMini = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "HTC One Mini Blue", Sku = "OM_HTC_BL", ShortDescription = "HTC One and HTC One Mini now available in bright blue hue", FullDescription = "

HTC One mini smartphone with 4.30-inch 720x1280 display powered by 1.4GHz processor alongside 1GB RAM and 4-Ultrapixel rear camera.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "samsung-rugby-a837-phone-black-att", AllowCustomerReviews = true, Price = 100M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, MarkAsNew = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productHtcOneMini); await InsertInstallationDataAsync(productHtcOneMini); await InsertInstallationDataAsync(new ProductCategory { ProductId = productHtcOneMini.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Cell phones").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productHtcOneMini, "product_HTC_One_Mini_1.jpeg"); await InsertProductPictureAsync(productHtcOneMini, "product_HTC_One_Mini_2.jpeg", 2); await AddProductTagAsync(productHtcOneMini, "awesome"); await AddProductTagAsync(productHtcOneMini, "compact"); await AddProductTagAsync(productHtcOneMini, "cell"); var productNokiaLumia = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Nokia Lumia 1020", Sku = "N_1020_LU", ShortDescription = "Nokia Lumia 1020 4G Cell Phone (Unlocked)", FullDescription = "

Capture special moments for friends and family with this Nokia Lumia 1020 32GB WHITE cell phone that features an easy-to-use 41.0MP rear-facing camera and a 1.2MP front-facing camera. The AMOLED touch screen offers 768 x 1280 resolution for crisp visuals.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "sony-dcr-sr85-1mp-60gb-hard-drive-handycam-camcorder", AllowCustomerReviews = true, Price = 349M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNokiaLumia); await InsertInstallationDataAsync(productNokiaLumia); await InsertInstallationDataAsync(new ProductCategory { ProductId = productNokiaLumia.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Cell phones").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productNokiaLumia, "product_Lumia1020.jpeg"); await AddProductTagAsync(productNokiaLumia, "awesome"); await AddProductTagAsync(productNokiaLumia, "cool"); await AddProductTagAsync(productNokiaLumia, "camera"); var productBeatsPill = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Beats Pill Wireless Speaker", Sku = "BP_20_WSP", ShortDescription = "Pill 2.0 Portable Bluetooth Speaker (1-Piece): Watch your favorite movies and listen to music with striking sound quality. This lightweight, portable speaker is easy to take with you as you travel to any destination, keeping you entertained wherever you are. ", FullDescription = "
  • Pair and play with your Bluetooth® device with 30 foot range
  • Built-in speakerphone
  • 7 hour rechargeable battery
  • Power your other devices with USB charge out
  • Tap two Beats Pills™ together for twice the sound with Beats Bond™
", ProductTemplateId = productTemplateSimple.Id, //SeName = "acer-aspire-one-89-mini-notebook-case-black", AllowCustomerReviews = true, Price = 79.99M, IsShipEnabled = true, IsFreeShipping = true, Weight = 2, Length = 2, Width = 2, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, MarkAsNew = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, HasTierPrices = true }; allProducts.Add(productBeatsPill); await InsertInstallationDataAsync(productBeatsPill); await InsertInstallationDataAsync(new ProductCategory { ProductId = productBeatsPill.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Others").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productBeatsPill, "product_PillBeats_1.jpeg"); await InsertProductPictureAsync(productBeatsPill, "product_PillBeats_2.jpeg", 2); await InsertInstallationDataAsync(new List { new() { Quantity = 2, Price = 19, ProductId = productBeatsPill.Id }, new() { Quantity = 5, Price = 17, ProductId = productBeatsPill.Id }, new() { Quantity = 10, Price = 15, StartDateTimeUtc = DateTime.UtcNow.AddDays(-7), EndDateTimeUtc = DateTime.UtcNow.AddDays(7), ProductId = productBeatsPill.Id } }); await AddProductTagAsync(productBeatsPill, "computer"); await AddProductTagAsync(productBeatsPill, "cool"); var productUniversalTabletCover = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Universal 7-8 Inch Tablet Cover", Sku = "TC_78I_UN", ShortDescription = "Universal protection for 7-inch & 8-inch tablets", FullDescription = "

Made of durable polyurethane, our Universal Cover is slim, lightweight, and strong, with protective corners that stretch to hold most 7 and 8-inch tablets securely. This tough case helps protects your tablet from bumps, scuffs, and dings.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "apc-back-ups-rs-800va-ups-800-va-ups-battery-lead-acid-br800blk", AllowCustomerReviews = true, Price = 39M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productUniversalTabletCover); await InsertInstallationDataAsync(productUniversalTabletCover); await InsertInstallationDataAsync(new ProductCategory { ProductId = productUniversalTabletCover.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Others").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productUniversalTabletCover, "product_TabletCover.jpeg"); await AddProductTagAsync(productUniversalTabletCover, "computer"); await AddProductTagAsync(productUniversalTabletCover, "cool"); var productPortableSoundSpeakers = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Portable Sound Speakers", Sku = "PT_SPK_SN", ShortDescription = "Universall portable sound speakers", FullDescription = "

Your phone cut the cord, now it's time for you to set your music free and buy a Bluetooth speaker. Thankfully, there's one suited for everyone out there.

Some Bluetooth speakers excel at packing in as much functionality as the unit can handle while keeping the price down. Other speakers shuck excess functionality in favor of premium build materials instead. Whatever path you choose to go down, you'll be greeted with many options to suit your personal tastes.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "microsoft-bluetooth-notebook-mouse-5000-macwindows", AllowCustomerReviews = true, Price = 37M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Electronics & Software").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productPortableSoundSpeakers); await InsertInstallationDataAsync(productPortableSoundSpeakers); await InsertInstallationDataAsync(new ProductCategory { ProductId = productPortableSoundSpeakers.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Others").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productPortableSoundSpeakers, "product_Speakers.jpeg"); relatedProducts.AddRange(new[] { new RelatedProduct { ProductId1 = productLeica.Id, ProductId2 = productHtcOneMini.Id }, new RelatedProduct { ProductId1 = productLeica.Id, ProductId2 = productNikonD5500DSLR.Id }, new RelatedProduct { ProductId1 = productLeica.Id, ProductId2 = productAppleICam.Id }, new RelatedProduct { ProductId1 = productLeica.Id, ProductId2 = productNokiaLumia.Id }, new RelatedProduct { ProductId1 = productHtcOne.Id, ProductId2 = productHtcOneMini.Id }, new RelatedProduct { ProductId1 = productHtcOne.Id, ProductId2 = productNokiaLumia.Id }, new RelatedProduct { ProductId1 = productHtcOne.Id, ProductId2 = productBeatsPill.Id }, new RelatedProduct { ProductId1 = productHtcOne.Id, ProductId2 = productPortableSoundSpeakers.Id }, new RelatedProduct { ProductId1 = productHtcOneMini.Id, ProductId2 = productHtcOne.Id }, new RelatedProduct { ProductId1 = productHtcOneMini.Id, ProductId2 = productNokiaLumia.Id }, new RelatedProduct { ProductId1 = productHtcOneMini.Id, ProductId2 = productBeatsPill.Id }, new RelatedProduct { ProductId1 = productHtcOneMini.Id, ProductId2 = productPortableSoundSpeakers.Id }, new RelatedProduct { ProductId1 = productNokiaLumia.Id, ProductId2 = productHtcOne.Id }, new RelatedProduct { ProductId1 = productNokiaLumia.Id, ProductId2 = productHtcOneMini.Id }, new RelatedProduct { ProductId1 = productNokiaLumia.Id, ProductId2 = productBeatsPill.Id }, new RelatedProduct { ProductId1 = productNokiaLumia.Id, ProductId2 = productPortableSoundSpeakers.Id } }); } /// A task that represents the asynchronous operation protected virtual async Task InstallApparelAsync(ProductTemplate productTemplateSimple, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts, ProductAvailabilityRange productAvailabilityRange) { var productNikeFloral = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Nike Floral Roshe Customized Running Shoes", Sku = "NK_FRC_RS", ShortDescription = "When you ran across these shoes, you will immediately fell in love and needed a pair of these customized beauties.", FullDescription = "

Each Rosh Run is personalized and exclusive, handmade in our workshop Custom. Run Your Rosh creations born from the hand of an artist specialized in sneakers, more than 10 years of experience.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "adidas-womens-supernova-csh-7-running-shoe", AllowCustomerReviews = true, Price = 40M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNikeFloral); await InsertInstallationDataAsync(productNikeFloral); await InsertInstallationDataAsync(new ProductCategory { ProductId = productNikeFloral.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Shoes").Id, DisplayOrder = 1 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productNikeFloral.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "Nike").Id, DisplayOrder = 2 }); var picProductNikeFloralShoe1Id = await InsertProductPictureAsync(productNikeFloral, "product_NikeFloralShoe_1.jpg"); var picProductNikeFloralShoe2Id = await InsertProductPictureAsync(productNikeFloral, "product_NikeFloralShoe_2.jpg", 2); await InsertInstallationDataAsync(new ProductSpecificationAttribute { ProductId = productNikeFloral.Id, AllowFiltering = true, ShowOnProductPage = false, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Color", "Grey") }); var pamSize = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productNikeFloral.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Size").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "8", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "9", DisplayOrder = 2 }, new ProductAttributeValue { ProductAttributeMappingId = pamSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "10", DisplayOrder = 3 }, new ProductAttributeValue { ProductAttributeMappingId = pamSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "11", DisplayOrder = 4 }); var pamColor = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productNikeFloral.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Color").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamColor.Id, AttributeValueType = AttributeValueType.Simple, Name = "White/Blue", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamColor.Id, AttributeValueType = AttributeValueType.Simple, Name = "White/Black", DisplayOrder = 2 }); var pamPrint = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productNikeFloral.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Print").Id, AttributeControlType = AttributeControlType.ImageSquares, IsRequired = true }); var pavNatural = await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamPrint.Id, AttributeValueType = AttributeValueType.Simple, Name = "Natural", DisplayOrder = 1, ImageSquaresPictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "p_attribute_print_2.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Natural Print"))).Id }); await InsertInstallationDataAsync(new ProductAttributeValuePicture { PictureId = picProductNikeFloralShoe1Id, ProductAttributeValueId = pavNatural.Id }); var pavFresh = await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamPrint.Id, AttributeValueType = AttributeValueType.Simple, Name = "Fresh", DisplayOrder = 2, ImageSquaresPictureId = (await pictureService.InsertPictureAsync(await _fileProvider.ReadAllBytesAsync(_fileProvider.Combine(sampleImagesPath, "p_attribute_print_1.jpg")), MimeTypes.ImagePJpeg, await pictureService.GetPictureSeNameAsync("Fresh Print"))).Id }); await InsertInstallationDataAsync( new ProductAttributeValuePicture { PictureId = picProductNikeFloralShoe2Id, ProductAttributeValueId = pavFresh.Id }); await AddProductTagAsync(productNikeFloral, "cool"); await AddProductTagAsync(productNikeFloral, "shoes"); await AddProductTagAsync(productNikeFloral, "apparel"); await UpdateInstallationDataAsync(productNikeFloral); var productAdidas = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "adidas Consortium Campus 80s Running Shoes", Sku = "AD_C80_RS", ShortDescription = "adidas Consortium Campus 80s Primeknit Light Maroon/Running Shoes", FullDescription = "

One of three colorways of the adidas Consortium Campus 80s Primeknit set to drop alongside each other. This pair comes in light maroon and running white. Featuring a maroon-based primeknit upper with white accents. A limited release, look out for these at select adidas Consortium accounts worldwide.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "etnies-mens-digit-sneaker", AllowCustomerReviews = true, Price = 27.56M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, //ShowOnHomepage = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productAdidas); await InsertInstallationDataAsync(productAdidas); await InsertInstallationDataAsync(new ProductCategory { ProductId = productAdidas.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Shoes").Id, DisplayOrder = 1 }); var picProductAdidasId = await InsertProductPictureAsync(productAdidas, "product_adidas.jpg"); var picProductAdidas2Id = await InsertProductPictureAsync(productAdidas, "product_adidas_2.jpg", 2); var picProductAdidas3Id = await InsertProductPictureAsync(productAdidas, "product_adidas_3.jpg", 3); await InsertInstallationDataAsync( new ProductSpecificationAttribute { ProductId = productAdidas.Id, AllowFiltering = true, ShowOnProductPage = false, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Color", "Grey") }, new ProductSpecificationAttribute { ProductId = productAdidas.Id, AllowFiltering = true, ShowOnProductPage = false, DisplayOrder = 2, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Color", "Red") }, new ProductSpecificationAttribute { ProductId = productAdidas.Id, AllowFiltering = true, ShowOnProductPage = false, DisplayOrder = 3, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Color", "Blue") }); var pamAdidasSize = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productAdidas.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Size").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamAdidasSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "8", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamAdidasSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "9", DisplayOrder = 2 }, new ProductAttributeValue { ProductAttributeMappingId = pamAdidasSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "10", DisplayOrder = 3 }, new ProductAttributeValue { ProductAttributeMappingId = pamAdidasSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "11", DisplayOrder = 4 }); var pamAdidasColor = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productAdidas.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Color").Id, AttributeControlType = AttributeControlType.ColorSquares, IsRequired = true }); var pavRed = await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamAdidasColor.Id, AttributeValueType = AttributeValueType.Simple, Name = "Red", IsPreSelected = true, ColorSquaresRgb = "#663030", DisplayOrder = 1 }); await InsertInstallationDataAsync( new ProductAttributeValuePicture { PictureId = picProductAdidasId, ProductAttributeValueId = pavRed.Id }); var pavBlue = await InsertInstallationDataAsync(new ProductAttributeValue { ProductAttributeMappingId = pamAdidasColor.Id, AttributeValueType = AttributeValueType.Simple, Name = "Blue", ColorSquaresRgb = "#363656", DisplayOrder = 2 }); await InsertInstallationDataAsync( new ProductAttributeValuePicture { PictureId = picProductAdidas2Id, ProductAttributeValueId = pavBlue.Id }); var pavSilver = await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamAdidasColor.Id, AttributeValueType = AttributeValueType.Simple, Name = "Silver", ColorSquaresRgb = "#c5c5d5", DisplayOrder = 3 }); await InsertInstallationDataAsync( new ProductAttributeValuePicture { PictureId = picProductAdidas3Id, ProductAttributeValueId = pavSilver.Id }); await AddProductTagAsync(productAdidas, "cool"); await AddProductTagAsync(productAdidas, "shoes"); await AddProductTagAsync(productAdidas, "apparel"); await UpdateInstallationDataAsync(productAdidas); var productNikeZoom = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Nike SB Zoom Stefan Janoski \"Medium Mint\"", Sku = "NK_ZSJ_MM", ShortDescription = "Nike SB Zoom Stefan Janoski Dark Grey Medium Mint Teal ...", FullDescription = "The newly Nike SB Zoom Stefan Janoski gets hit with a \"Medium Mint\" accents that sits atop a Dark Grey suede. Expected to drop in October.", ProductTemplateId = productTemplateSimple.Id, //SeName = "v-blue-juniors-cuffed-denim-short-with-rhinestones", AllowCustomerReviews = true, Price = 30M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNikeZoom); await InsertInstallationDataAsync(productNikeZoom); await InsertInstallationDataAsync(new ProductCategory { ProductId = productNikeZoom.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Shoes").Id, DisplayOrder = 1 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productNikeZoom.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "Nike").Id, DisplayOrder = 2 }); await InsertProductPictureAsync(productNikeZoom, "product_NikeZoom.jpg"); await InsertInstallationDataAsync(new ProductSpecificationAttribute { ProductId = productNikeZoom.Id, AllowFiltering = true, ShowOnProductPage = false, DisplayOrder = 1, SpecificationAttributeOptionId = await GetSpecificationAttributeOptionIdAsync("Color", "Grey") }); await AddProductTagAsync(productNikeZoom, "jeans"); await AddProductTagAsync(productNikeZoom, "cool"); await AddProductTagAsync(productNikeZoom, "apparel"); var productNikeTailwind = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Nike Tailwind Loose Short-Sleeve Running Shirt", Sku = "NK_TLS_RS", ShortDescription = string.Empty, FullDescription = "

Boost your adrenaline with the Nike® Women's Tailwind Running Shirt. The lightweight, slouchy fit is great for layering, and moisture-wicking fabrics keep you feeling at your best. This tee has a notched hem for an enhanced range of motion, while flat seams with reinforcement tape lessen discomfort and irritation over longer distances. Put your keys and card in the side zip pocket and take off in your Nike® running t-shirt.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "50s-rockabilly-polka-dot-top-jr-plus-size", AllowCustomerReviews = true, Published = true, Price = 15M, IsShipEnabled = true, Weight = 1, Length = 2, Width = 3, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNikeTailwind); await InsertInstallationDataAsync(productNikeTailwind); await InsertInstallationDataAsync(new ProductCategory { ProductId = productNikeTailwind.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Clothing").Id, DisplayOrder = 1 }); await InsertInstallationDataAsync(new ProductManufacturer { ProductId = productNikeTailwind.Id, ManufacturerId = _manufacturerRepository.Table.Single(c => c.Name == "Nike").Id, DisplayOrder = 2 }); await InsertProductPictureAsync(productNikeTailwind, "product_NikeShirt.jpg"); var pamNikeSize = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productNikeTailwind.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Size").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamNikeSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "Small", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamNikeSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "1X", DisplayOrder = 2 }, new ProductAttributeValue { ProductAttributeMappingId = pamNikeSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "2X", DisplayOrder = 3 }, new ProductAttributeValue { ProductAttributeMappingId = pamNikeSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "3X", DisplayOrder = 4 }, new ProductAttributeValue { ProductAttributeMappingId = pamNikeSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "4X", DisplayOrder = 5 }, new ProductAttributeValue { ProductAttributeMappingId = pamNikeSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "5X", DisplayOrder = 6 }); await AddProductTagAsync(productNikeTailwind, "cool"); await AddProductTagAsync(productNikeTailwind, "apparel"); await AddProductTagAsync(productNikeTailwind, "shirt"); var productOversizedWomenTShirt = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Oversized Women T-Shirt", Sku = "WM_OVR_TS", ShortDescription = string.Empty, FullDescription = "

This oversized women t-Shirt needs minimum ironing. It is a great product at a great value!

", ProductTemplateId = productTemplateSimple.Id, //SeName = "arrow-mens-wrinkle-free-pinpoint-solid-long-sleeve", AllowCustomerReviews = true, Price = 24M, IsShipEnabled = true, Weight = 4, Length = 3, Width = 3, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, HasTierPrices = true }; allProducts.Add(productOversizedWomenTShirt); await InsertInstallationDataAsync(productOversizedWomenTShirt); await InsertInstallationDataAsync(new ProductCategory { ProductId = productOversizedWomenTShirt.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Clothing").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productOversizedWomenTShirt, "product_WomenTShirt.jpg"); await InsertInstallationDataAsync(new List { new() { Quantity = 3, Price = 21, ProductId = productOversizedWomenTShirt.Id }, new() { Quantity = 7, Price = 19, ProductId = productOversizedWomenTShirt.Id }, new() { Quantity = 10, Price = 16, ProductId = productOversizedWomenTShirt.Id } }); await AddProductTagAsync(productOversizedWomenTShirt, "cool"); await AddProductTagAsync(productOversizedWomenTShirt, "apparel"); await AddProductTagAsync(productOversizedWomenTShirt, "shirt"); var productCustomTShirt = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Custom T-Shirt", Sku = "CS_TSHIRT", ShortDescription = "T-Shirt - Add Your Content", FullDescription = "

Comfort comes in all shapes and forms, yet this tee out does it all. Rising above the rest, our classic cotton crew provides the simple practicality you need to make it through the day. Tag-free, relaxed fit wears well under dress shirts or stands alone in laid-back style. Reinforced collar and lightweight feel give way to long-lasting shape and breathability. One less thing to worry about, rely on this tee to provide comfort and ease with every wear.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "custom-t-shirt", AllowCustomerReviews = true, Price = 15M, IsShipEnabled = true, Weight = 4, Length = 3, Width = 3, Height = 3, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productCustomTShirt); await InsertInstallationDataAsync(productCustomTShirt); await InsertInstallationDataAsync(new ProductCategory { ProductId = productCustomTShirt.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Clothing").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productCustomTShirt, "product_CustomTShirt.jpeg"); await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productCustomTShirt.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Custom Text").Id, TextPrompt = "Enter your text:", AttributeControlType = AttributeControlType.TextBox, IsRequired = true }); await AddProductTagAsync(productCustomTShirt, "cool"); await AddProductTagAsync(productCustomTShirt, "shirt"); await AddProductTagAsync(productCustomTShirt, "apparel"); var productLeviJeans = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Levi's 511 Jeans", Sku = "LV_511_JN", ShortDescription = "Levi's Faded Black 511 Jeans ", FullDescription = "

Between a skinny and straight fit, our 511™ slim fit jeans are cut close without being too restricting. Slim throughout the thigh and leg opening for a long and lean look.

  • Slouch1y at top; sits below the waist
  • Slim through the leg, close at the thigh and straight to the ankle
  • Stretch for added comfort
  • Classic five-pocket styling
  • 99% Cotton, 1% Spandex, 11.2 oz. - Imported
", ProductTemplateId = productTemplateSimple.Id, //SeName = "levis-skinny-511-jeans", AllowCustomerReviews = true, Price = 43.5M, OldPrice = 55M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow, HasTierPrices = true }; allProducts.Add(productLeviJeans); await InsertInstallationDataAsync(productLeviJeans); await InsertInstallationDataAsync(new ProductCategory { ProductId = productLeviJeans.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Clothing").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productLeviJeans, "product_LeviJeans_1.jpg"); await InsertProductPictureAsync(productLeviJeans, "product_LeviJeans_2.jpg", 2); await InsertInstallationDataAsync(new List { new() { Quantity = 3, Price = 40, ProductId = productLeviJeans.Id }, new() { Quantity = 6, Price = 38, ProductId = productLeviJeans.Id }, new() { Quantity = 10, Price = 35, ProductId = productLeviJeans.Id } }); await AddProductTagAsync(productLeviJeans, "cool"); await AddProductTagAsync(productLeviJeans, "jeans"); await AddProductTagAsync(productLeviJeans, "apparel"); var productObeyHat = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Obey Propaganda Hat", Sku = "OB_HAT_PR", ShortDescription = string.Empty, FullDescription = "

Printed poplin 5 panel camp hat with debossed leather patch and web closure

", ProductTemplateId = productTemplateSimple.Id, //SeName = "indiana-jones-shapeable-wool-hat", AllowCustomerReviews = true, Price = 30M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productObeyHat); await InsertInstallationDataAsync(productObeyHat); await InsertInstallationDataAsync(new ProductCategory { ProductId = productObeyHat.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Accessories").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productObeyHat, "product_hat.jpg"); var pamObeyHatSize = await InsertInstallationDataAsync( new ProductAttributeMapping { ProductId = productObeyHat.Id, ProductAttributeId = _productAttributeRepository.Table.Single(x => x.Name == "Size").Id, AttributeControlType = AttributeControlType.DropdownList, IsRequired = true }); await InsertInstallationDataAsync( new ProductAttributeValue { ProductAttributeMappingId = pamObeyHatSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "Small", DisplayOrder = 1 }, new ProductAttributeValue { ProductAttributeMappingId = pamObeyHatSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "Medium", DisplayOrder = 2 }, new ProductAttributeValue { ProductAttributeMappingId = pamObeyHatSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "Large", DisplayOrder = 3 }, new ProductAttributeValue { ProductAttributeMappingId = pamObeyHatSize.Id, AttributeValueType = AttributeValueType.Simple, Name = "X-Large", DisplayOrder = 4 }); await AddProductTagAsync(productObeyHat, "apparel"); await AddProductTagAsync(productObeyHat, "cool"); var productBelt = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Reversible Horseferry Check Belt", Sku = "RH_CHK_BL", ShortDescription = "Reversible belt in Horseferry check with smooth leather trim", FullDescription = "

Reversible belt in Horseferry check with smooth leather trim

Leather lining, polished metal buckle

", ProductTemplateId = productTemplateSimple.Id, //SeName = "nike-golf-casual-belt", AllowCustomerReviews = true, Price = 45M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, ProductAvailabilityRangeId = productAvailabilityRange.Id, StockQuantity = 0, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productBelt); await InsertInstallationDataAsync(productBelt); await InsertInstallationDataAsync(new ProductCategory { ProductId = productBelt.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Accessories").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productBelt, "product_Belt.jpeg"); var productSunglasses = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Ray Ban Aviator Sunglasses", Sku = "RB_AVR_SG", ShortDescription = "Aviator sunglasses are one of the first widely popularized styles of modern day sunwear.", FullDescription = "

Since 1937, Ray-Ban can genuinely claim the title as the world's leading sunglasses and optical eyewear brand. Combining the best of fashion and sports performance, the Ray-Ban line of Sunglasses delivers a truly classic style that will have you looking great today and for years to come.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "ray-ban-aviator-sunglasses-rb-3025", AllowCustomerReviews = true, Price = 25M, IsShipEnabled = true, Weight = 7, Length = 7, Width = 7, Height = 7, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Apparel").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productSunglasses); await InsertInstallationDataAsync(productSunglasses); await InsertInstallationDataAsync(new ProductCategory { ProductId = productSunglasses.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Accessories").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productSunglasses, "product_Sunglasses.jpg"); await AddProductTagAsync(productSunglasses, "apparel"); await AddProductTagAsync(productSunglasses, "cool"); relatedProducts.AddRange(new[] { new RelatedProduct { ProductId1 = productAdidas.Id, ProductId2 = productLeviJeans.Id }, new RelatedProduct { ProductId1 = productAdidas.Id, ProductId2 = productNikeFloral.Id }, new RelatedProduct { ProductId1 = productAdidas.Id, ProductId2 = productNikeZoom.Id }, new RelatedProduct { ProductId1 = productAdidas.Id, ProductId2 = productNikeTailwind.Id }, new RelatedProduct { ProductId1 = productLeviJeans.Id, ProductId2 = productAdidas.Id }, new RelatedProduct { ProductId1 = productLeviJeans.Id, ProductId2 = productNikeFloral.Id }, new RelatedProduct { ProductId1 = productLeviJeans.Id, ProductId2 = productNikeZoom.Id }, new RelatedProduct { ProductId1 = productLeviJeans.Id, ProductId2 = productNikeTailwind.Id }, new RelatedProduct { ProductId1 = productCustomTShirt.Id, ProductId2 = productLeviJeans.Id }, new RelatedProduct { ProductId1 = productCustomTShirt.Id, ProductId2 = productNikeTailwind.Id }, new RelatedProduct { ProductId1 = productCustomTShirt.Id, ProductId2 = productOversizedWomenTShirt.Id }, new RelatedProduct { ProductId1 = productCustomTShirt.Id, ProductId2 = productObeyHat.Id } }); } /// A task that represents the asynchronous operation protected virtual async Task InstallDigitalDownloadsAsync(ProductTemplate productTemplateSimple, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts, string sampleDownloadsPath, IDownloadService downloadService) { var downloadNightVision1 = new Download { DownloadGuid = Guid.NewGuid(), ContentType = MimeTypes.ApplicationXZipCo, DownloadBinary = await _fileProvider.ReadAllBytesAsync(sampleDownloadsPath + "product_NightVision_1.zip"), Extension = ".zip", Filename = "Night_Vision_1", IsNew = true }; await downloadService.InsertDownloadAsync(downloadNightVision1); var downloadNightVision2 = new Download { DownloadGuid = Guid.NewGuid(), ContentType = MimeTypes.TextPlain, DownloadBinary = await _fileProvider.ReadAllBytesAsync(sampleDownloadsPath + "product_NightVision_2.txt"), Extension = ".txt", Filename = "Night_Vision_1", IsNew = true }; await downloadService.InsertDownloadAsync(downloadNightVision2); var productNightVision = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Night Visions", Sku = "NIGHT_VSN", ShortDescription = "Night Visions is the debut studio album by American rock band Imagine Dragons.", FullDescription = "

Original Release Date: September 4, 2012

Release Date: September 4, 2012

Genre - Alternative rock, indie rock, electronic rock

Label - Interscope/KIDinaKORNER

Copyright: (C) 2011 Interscope Records

", ProductTemplateId = productTemplateSimple.Id, //SeName = "poker-face", AllowCustomerReviews = true, Price = 2.8M, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Downloadable Products").Id, ManageInventoryMethod = ManageInventoryMethod.DontManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, IsDownload = true, DownloadId = downloadNightVision1.Id, DownloadActivationType = DownloadActivationType.WhenOrderIsPaid, UnlimitedDownloads = true, HasUserAgreement = false, HasSampleDownload = true, SampleDownloadId = downloadNightVision2.Id, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productNightVision); await InsertInstallationDataAsync(productNightVision); await InsertInstallationDataAsync(new ProductCategory { ProductId = productNightVision.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Digital downloads").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productNightVision, "product_NightVisions.jpeg"); await AddProductTagAsync(productNightVision, "awesome"); await AddProductTagAsync(productNightVision, "digital"); var downloadIfYouWait1 = new Download { DownloadGuid = Guid.NewGuid(), ContentType = MimeTypes.ApplicationXZipCo, DownloadBinary = await _fileProvider.ReadAllBytesAsync(sampleDownloadsPath + "product_IfYouWait_1.zip"), Extension = ".zip", Filename = "If_You_Wait_1", IsNew = true }; await downloadService.InsertDownloadAsync(downloadIfYouWait1); var downloadIfYouWait2 = new Download { DownloadGuid = Guid.NewGuid(), ContentType = MimeTypes.TextPlain, DownloadBinary = await _fileProvider.ReadAllBytesAsync(sampleDownloadsPath + "product_IfYouWait_2.txt"), Extension = ".txt", Filename = "If_You_Wait_1", IsNew = true }; await downloadService.InsertDownloadAsync(downloadIfYouWait2); var productIfYouWait = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "If You Wait (donation)", Sku = "IF_YOU_WT", ShortDescription = "If You Wait is the debut studio album by English indie pop band London Grammar", FullDescription = "

Original Release Date: September 6, 2013

Genre - Electronica, dream pop downtempo, pop

Label - Metal & Dust/Ministry of Sound

Producer - Tim Bran, Roy Kerr London, Grammar

Length - 43:22

", ProductTemplateId = productTemplateSimple.Id, //SeName = "single-ladies-put-a-ring-on-it", CustomerEntersPrice = true, MinimumCustomerEnteredPrice = 0.5M, MaximumCustomerEnteredPrice = 100M, AllowCustomerReviews = true, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Downloadable Products").Id, ManageInventoryMethod = ManageInventoryMethod.DontManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, IsDownload = true, DownloadId = downloadIfYouWait1.Id, DownloadActivationType = DownloadActivationType.WhenOrderIsPaid, UnlimitedDownloads = true, HasUserAgreement = false, HasSampleDownload = true, SampleDownloadId = downloadIfYouWait2.Id, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productIfYouWait); await InsertInstallationDataAsync(productIfYouWait); await InsertInstallationDataAsync(new ProductCategory { ProductId = productIfYouWait.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Digital downloads").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productIfYouWait, "product_IfYouWait.jpeg"); await AddProductTagAsync(productIfYouWait, "digital"); await AddProductTagAsync(productIfYouWait, "awesome"); var downloadScienceAndFaith = new Download { DownloadGuid = Guid.NewGuid(), ContentType = MimeTypes.ApplicationXZipCo, DownloadBinary = await _fileProvider.ReadAllBytesAsync(sampleDownloadsPath + "product_ScienceAndFaith_1.zip"), Extension = ".zip", Filename = "Science_And_Faith", IsNew = true }; await downloadService.InsertDownloadAsync(downloadScienceAndFaith); var productScienceAndFaith = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Science & Faith", Sku = "SCI_FAITH", ShortDescription = "Science & Faith is the second studio album by Irish pop rock band The Script.", FullDescription = "

# Original Release Date: September 10, 2010
# Label: RCA, Epic/Phonogenic(America)
# Copyright: 2010 RCA Records.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "the-battle-of-los-angeles", AllowCustomerReviews = true, CustomerEntersPrice = true, MinimumCustomerEnteredPrice = 0.5M, MaximumCustomerEnteredPrice = 1000M, Price = decimal.Zero, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Downloadable Products").Id, ManageInventoryMethod = ManageInventoryMethod.DontManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, IsDownload = true, DownloadId = downloadScienceAndFaith.Id, DownloadActivationType = DownloadActivationType.WhenOrderIsPaid, UnlimitedDownloads = true, HasUserAgreement = false, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productScienceAndFaith); await InsertInstallationDataAsync(productScienceAndFaith); await InsertInstallationDataAsync(new ProductCategory { ProductId = productScienceAndFaith.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Digital downloads").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productScienceAndFaith, "product_ScienceAndFaith.jpeg"); await AddProductTagAsync(productScienceAndFaith, "digital"); await AddProductTagAsync(productScienceAndFaith, "awesome"); relatedProducts.AddRange(new[] { new RelatedProduct { ProductId1 = productIfYouWait.Id, ProductId2 = productNightVision.Id }, new RelatedProduct { ProductId1 = productIfYouWait.Id, ProductId2 = productScienceAndFaith.Id }, new RelatedProduct { ProductId1 = productNightVision.Id, ProductId2 = productIfYouWait.Id }, new RelatedProduct { ProductId1 = productNightVision.Id, ProductId2 = productScienceAndFaith.Id } }); } /// A task that represents the asynchronous operation protected virtual async Task InstallBooksAsync(ProductTemplate productTemplateSimple, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts) { var productFahrenheit = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Fahrenheit 451 by Ray Bradbury", Sku = "FR_451_RB", ShortDescription = "Fahrenheit 451 is a dystopian novel by Ray Bradbury published in 1953. It is regarded as one of his best works.", FullDescription = "

The novel presents a future American society where books are outlawed and firemen burn any that are found. The title refers to the temperature that Bradbury understood to be the autoignition point of paper.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "best-grilling-recipes", AllowCustomerReviews = true, Price = 27M, OldPrice = 30M, IsShipEnabled = true, IsFreeShipping = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Books").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productFahrenheit); await InsertInstallationDataAsync(productFahrenheit); await InsertInstallationDataAsync(new ProductCategory { ProductId = productFahrenheit.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Books").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productFahrenheit, "product_Fahrenheit451.jpeg"); await AddProductTagAsync(productFahrenheit, "awesome"); await AddProductTagAsync(productFahrenheit, "book"); await AddProductTagAsync(productFahrenheit, "nice"); var productFirstPrizePies = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "First Prize Pies", Sku = "FIRST_PRP", ShortDescription = "Allison Kave made pies as a hobby, until one day her boyfriend convinced her to enter a Brooklyn pie-making contest. She won. In fact, her pies were such a hit that she turned pro.", FullDescription = "

First Prize Pies, a boutique, made-to-order pie business that originated on New York's Lower East Side, has become synonymous with tempting and unusual confections. For the home baker who is passionate about seasonal ingredients and loves a creative approach to recipes, First Prize Pies serves up 52 weeks of seasonal and eclectic pastries in an interesting pie-a-week format. Clear instructions, technical tips and creative encouragement guide novice bakers as well as pie mavens. With its nostalgia-evoking photos of homemade pies fresh out of the oven, First Prize Pies will be as giftable as it is practical.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "eatingwell-in-season", AllowCustomerReviews = true, Price = 51M, OldPrice = 67M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Books").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productFirstPrizePies); await InsertInstallationDataAsync(productFirstPrizePies); await InsertInstallationDataAsync(new ProductCategory { ProductId = productFirstPrizePies.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Books").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productFirstPrizePies, "product_FirstPrizePies.jpeg"); await AddProductTagAsync(productFirstPrizePies, "book"); var productPrideAndPrejudice = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Pride and Prejudice", Sku = "PRIDE_PRJ", ShortDescription = "Pride and Prejudice is a novel of manners by Jane Austen, first published in 1813.", FullDescription = "

Set in England in the early 19th century, Pride and Prejudice tells the story of Mr and Mrs Bennet's five unmarried daughters after the rich and eligible Mr Bingley and his status-conscious friend, Mr Darcy, have moved into their neighbourhood. While Bingley takes an immediate liking to the eldest Bennet daughter, Jane, Darcy has difficulty adapting to local society and repeatedly clashes with the second-eldest Bennet daughter, Elizabeth.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "the-best-skillet-recipes", AllowCustomerReviews = true, Price = 24M, OldPrice = 35M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Books").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productPrideAndPrejudice); await InsertInstallationDataAsync(productPrideAndPrejudice); await InsertInstallationDataAsync(new ProductCategory { ProductId = productPrideAndPrejudice.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Books").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productPrideAndPrejudice, "product_PrideAndPrejudice.jpeg"); await AddProductTagAsync(productPrideAndPrejudice, "book"); relatedProducts.AddRange(new[] { new RelatedProduct { ProductId1 = productPrideAndPrejudice.Id, ProductId2 = productFirstPrizePies.Id }, new RelatedProduct { ProductId1 = productPrideAndPrejudice.Id, ProductId2 = productFahrenheit.Id }, new RelatedProduct { ProductId1 = productFirstPrizePies.Id, ProductId2 = productPrideAndPrejudice.Id }, new RelatedProduct { ProductId1 = productFirstPrizePies.Id, ProductId2 = productFahrenheit.Id }, new RelatedProduct { ProductId1 = productFahrenheit.Id, ProductId2 = productFirstPrizePies.Id }, new RelatedProduct { ProductId1 = productFahrenheit.Id, ProductId2 = productPrideAndPrejudice.Id } }); } /// A task that represents the asynchronous operation protected virtual async Task InstallJewelryAsync(ProductTemplate productTemplateSimple, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts) { var productElegantGemstoneNecklace = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Elegant Gemstone Necklace (rental)", Sku = "EG_GEM_NL", ShortDescription = "Classic and elegant gemstone necklace now available in our store", FullDescription = "

For those who like jewelry, creating their ownelegant jewelry from gemstone beads provides an economical way to incorporate genuine gemstones into your jewelry wardrobe. Manufacturers create beads from all kinds of precious gemstones and semi-precious gemstones, which are available in bead shops, craft stores, and online marketplaces.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "diamond-pave-earrings", AllowCustomerReviews = true, IsRental = true, RentalPriceLength = 1, RentalPricePeriod = RentalPricePeriod.Days, Price = 30M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Jewelry").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, MarkAsNew = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productElegantGemstoneNecklace); await InsertInstallationDataAsync(productElegantGemstoneNecklace); await InsertInstallationDataAsync(new ProductCategory { ProductId = productElegantGemstoneNecklace.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Jewelry").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productElegantGemstoneNecklace, "product_GemstoneNecklaces.jpg"); await AddProductTagAsync(productElegantGemstoneNecklace, "jewelry"); await AddProductTagAsync(productElegantGemstoneNecklace, "awesome"); var productFlowerGirlBracelet = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Flower Girl Bracelet", Sku = "FL_GIRL_B", ShortDescription = "Personalised Flower Braceled", FullDescription = "

This is a great gift for your flower girl to wear on your wedding day. A delicate bracelet that is made with silver plated soldered cable chain, gives this bracelet a dainty look for young wrist. A Swarovski heart, shown in Rose, hangs off a silver plated flower. Hanging alongside the heart is a silver plated heart charm with Flower Girl engraved on both sides. This is a great style for the younger flower girl.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "diamond-tennis-bracelet", AllowCustomerReviews = true, Price = 360M, IsShipEnabled = true, IsFreeShipping = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Jewelry").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productFlowerGirlBracelet); await InsertInstallationDataAsync(productFlowerGirlBracelet); await InsertInstallationDataAsync(new ProductCategory { ProductId = productFlowerGirlBracelet.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Jewelry").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productFlowerGirlBracelet, "product_FlowerBracelet.jpg"); await AddProductTagAsync(productFlowerGirlBracelet, "awesome"); await AddProductTagAsync(productFlowerGirlBracelet, "jewelry"); var productEngagementRing = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "Vintage Style Engagement Ring", Sku = "VS_ENG_RN", ShortDescription = "1.24 Carat (ctw) in 14K White Gold (Certified)", FullDescription = "

Dazzle her with this gleaming 14 karat white gold vintage proposal. A ravishing collection of 11 decadent diamonds come together to invigorate a superbly ornate gold shank. Total diamond weight on this antique style engagement ring equals 1 1/4 carat (ctw). Item includes diamond certificate.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "vintage-style-three-stone-diamond-engagement-ring", AllowCustomerReviews = true, Price = 2100M, IsShipEnabled = true, Weight = 2, Length = 2, Width = 2, Height = 2, TaxCategoryId = _taxCategoryRepository.Table.Single(tc => tc.Name == "Jewelry").Id, ManageInventoryMethod = ManageInventoryMethod.ManageStock, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, DisplayStockAvailability = true, LowStockActivity = LowStockActivity.DisableBuyButton, BackorderMode = BackorderMode.NoBackorders, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(productEngagementRing); await InsertInstallationDataAsync(productEngagementRing); await InsertInstallationDataAsync(new ProductCategory { ProductId = productEngagementRing.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Jewelry").Id, DisplayOrder = 1 }); await InsertProductPictureAsync(productEngagementRing, "product_EngagementRing_1.jpg"); await AddProductTagAsync(productEngagementRing, "jewelry"); await AddProductTagAsync(productEngagementRing, "awesome"); relatedProducts.AddRange(new[] { new RelatedProduct { ProductId1 = productFlowerGirlBracelet.Id, ProductId2 = productEngagementRing.Id }, new RelatedProduct { ProductId1 = productFlowerGirlBracelet.Id, ProductId2 = productElegantGemstoneNecklace.Id }, new RelatedProduct { ProductId1 = productEngagementRing.Id, ProductId2 = productFlowerGirlBracelet.Id }, new RelatedProduct { ProductId1 = productEngagementRing.Id, ProductId2 = productElegantGemstoneNecklace.Id }, new RelatedProduct { ProductId1 = productElegantGemstoneNecklace.Id, ProductId2 = productFlowerGirlBracelet.Id }, new RelatedProduct { ProductId1 = productElegantGemstoneNecklace.Id, ProductId2 = productEngagementRing.Id } }); } /// A task that represents the asynchronous operation protected virtual async Task InstallGiftCardsAsync(ProductTemplate productTemplateSimple, List allProducts, string sampleImagesPath, IPictureService pictureService, List relatedProducts, DeliveryDate deliveryDate) { var product25GiftCard = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "$25 Virtual Gift Card", Sku = "VG_CR_025", ShortDescription = "$25 Gift Card. Gift Cards must be redeemed through our site Web site toward the purchase of eligible products.", FullDescription = "

Gift Cards must be redeemed through our site Web site toward the purchase of eligible products. Purchases are deducted from the GiftCard balance. Any unused balance will be placed in the recipient's GiftCard account when redeemed. If an order exceeds the amount of the GiftCard, the balance must be paid with a credit card or other available payment method.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "25-virtual-gift-card", AllowCustomerReviews = true, Price = 25M, IsGiftCard = true, GiftCardType = GiftCardType.Virtual, ManageInventoryMethod = ManageInventoryMethod.DontManageStock, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, Published = true, ShowOnHomepage = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(product25GiftCard); await InsertInstallationDataAsync(product25GiftCard); await InsertInstallationDataAsync(new ProductCategory { ProductId = product25GiftCard.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Gift Cards").Id, DisplayOrder = 2 }); await InsertProductPictureAsync(product25GiftCard, "product_25giftcart.jpeg"); await AddProductTagAsync(product25GiftCard, "nice"); await AddProductTagAsync(product25GiftCard, "gift"); var product50GiftCard = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "$50 Physical Gift Card", Sku = "PG_CR_050", ShortDescription = "$50 Gift Card. Gift Cards must be redeemed through our site Web site toward the purchase of eligible products.", FullDescription = "

Gift Cards must be redeemed through our site Web site toward the purchase of eligible products. Purchases are deducted from the GiftCard balance. Any unused balance will be placed in the recipient's GiftCard account when redeemed. If an order exceeds the amount of the GiftCard, the balance must be paid with a credit card or other available payment method.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "50-physical-gift-card", AllowCustomerReviews = true, Price = 50M, IsGiftCard = true, GiftCardType = GiftCardType.Physical, IsShipEnabled = true, IsFreeShipping = true, DeliveryDateId = deliveryDate.Id, Weight = 1, Length = 1, Width = 1, Height = 1, ManageInventoryMethod = ManageInventoryMethod.DontManageStock, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, Published = true, MarkAsNew = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(product50GiftCard); await InsertInstallationDataAsync(product50GiftCard); await InsertInstallationDataAsync(new ProductCategory { ProductId = product50GiftCard.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Gift Cards").Id, DisplayOrder = 3 }); await InsertProductPictureAsync(product50GiftCard, "product_50giftcart.jpeg"); var product100GiftCard = new Product { ProductType = ProductType.SimpleProduct, VisibleIndividually = true, Name = "$100 Physical Gift Card", Sku = "PG_CR_100", ShortDescription = "$100 Gift Card. Gift Cards must be redeemed through our site Web site toward the purchase of eligible products.", FullDescription = "

Gift Cards must be redeemed through our site Web site toward the purchase of eligible products. Purchases are deducted from the GiftCard balance. Any unused balance will be placed in the recipient's GiftCard account when redeemed. If an order exceeds the amount of the GiftCard, the balance must be paid with a credit card or other available payment method.

", ProductTemplateId = productTemplateSimple.Id, //SeName = "100-physical-gift-card", AllowCustomerReviews = true, Price = 100M, IsGiftCard = true, GiftCardType = GiftCardType.Physical, IsShipEnabled = true, DeliveryDateId = deliveryDate.Id, Weight = 1, Length = 1, Width = 1, Height = 1, ManageInventoryMethod = ManageInventoryMethod.DontManageStock, OrderMinimumQuantity = 1, OrderMaximumQuantity = 10000, StockQuantity = 10000, NotifyAdminForQuantityBelow = 1, AllowBackInStockSubscriptions = false, Published = true, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; allProducts.Add(product100GiftCard); await InsertInstallationDataAsync(product100GiftCard); await InsertInstallationDataAsync(new ProductCategory { ProductId = product100GiftCard.Id, CategoryId = _categoryRepository.Table.Single(c => c.Name == "Gift Cards").Id, DisplayOrder = 4 }); await InsertProductPictureAsync(product100GiftCard, "product_100giftcart.jpeg"); } /// A task that represents the asynchronous operation protected virtual async Task InstallProductsAsync(string defaultUserEmail) { var productTemplateSimple = _productTemplateRepository.Table.FirstOrDefault(pt => pt.Name == "Simple product") ?? throw new Exception("Simple product template could not be loaded"); var productTemplateGrouped = _productTemplateRepository.Table.FirstOrDefault(pt => pt.Name == "Grouped product (with variants)") ?? throw new Exception("Grouped product template could not be loaded"); //delivery date var deliveryDate = _deliveryDateRepository.Table.FirstOrDefault() ?? throw new Exception("No default deliveryDate could be loaded"); //product availability range var productAvailabilityRange = _productAvailabilityRangeRepository.Table.FirstOrDefault() ?? throw new Exception("No default product availability range could be loaded"); //default customer/user var defaultCustomer = _customerRepository.Table.FirstOrDefault(x => x.Email == defaultUserEmail) ?? throw new Exception("Cannot load default customer"); //default store var defaultStore = _storeRepository.Table.FirstOrDefault() ?? throw new Exception("No default store could be loaded"); //pictures var pictureService = EngineContext.Current.Resolve(); var sampleImagesPath = GetSamplesPath(); //downloads var downloadService = EngineContext.Current.Resolve(); var sampleDownloadsPath = GetSamplesPath(); //products var allProducts = new List(); //related products var relatedProducts = new List(); //desktops, notebooks, software await InstallComputersAsync(productTemplateSimple, allProducts, sampleImagesPath, pictureService, relatedProducts); //camera & photo, cell phones, others await InstallElectronicsAsync(productTemplateSimple, productTemplateGrouped, allProducts, sampleImagesPath, pictureService, relatedProducts); //shoes, clothing, accessories await InstallApparelAsync(productTemplateSimple, allProducts, sampleImagesPath, pictureService, relatedProducts, productAvailabilityRange); //digital downloads await InstallDigitalDownloadsAsync(productTemplateSimple, allProducts, sampleImagesPath, pictureService, relatedProducts, sampleDownloadsPath, downloadService); //books await InstallBooksAsync(productTemplateSimple, allProducts, sampleImagesPath, pictureService, relatedProducts); //jewelry await InstallJewelryAsync(productTemplateSimple, allProducts, sampleImagesPath, pictureService, relatedProducts); //gift cards await InstallGiftCardsAsync(productTemplateSimple, allProducts, sampleImagesPath, pictureService, relatedProducts, deliveryDate); //search engine names foreach (var product in allProducts) await InsertInstallationDataAsync(new UrlRecord { EntityId = product.Id, EntityName = nameof(Product), LanguageId = 0, IsActive = true, Slug = await ValidateSeNameAsync(product, product.Name) }); //related products await InsertInstallationDataAsync(relatedProducts); //reviews using (var random = new SecureRandomNumberGenerator()) { foreach (var product in allProducts) { if (product.ProductType != ProductType.SimpleProduct) continue; //only 3 of 4 products will have reviews if (random.Next(4) == 3) continue; //rating from 4 to 5 var rating = random.Next(4, 6); await InsertInstallationDataAsync(new ProductReview { CustomerId = defaultCustomer.Id, ProductId = product.Id, StoreId = defaultStore.Id, IsApproved = true, Title = "Some sample review", ReviewText = $"This sample review is for the {product.Name}. I've been waiting for this product to be available. It is priced just right.", //random (4 or 5) Rating = rating, HelpfulYesTotal = 0, HelpfulNoTotal = 0, CreatedOnUtc = DateTime.UtcNow }); product.ApprovedRatingSum = rating; product.ApprovedTotalReviews = 1; } } await UpdateInstallationDataAsync(allProducts); //stock quantity history foreach (var product in allProducts) if (product.StockQuantity > 0) await InsertInstallationDataAsync(new StockQuantityHistory { ProductId = product.Id, WarehouseId = product.WarehouseId > 0 ? (int?)product.WarehouseId : null, QuantityAdjustment = product.StockQuantity, StockQuantity = product.StockQuantity, Message = "The stock quantity has been edited", CreatedOnUtc = DateTime.UtcNow }); } /// A task that represents the asynchronous operation protected virtual async Task InstallForumsAsync() { var forumGroup = new ForumGroup { Name = "General", DisplayOrder = 5, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(forumGroup); var newProductsForum = new Forum { ForumGroupId = forumGroup.Id, Name = "New Products", Description = "Discuss new products and industry trends", NumTopics = 0, NumPosts = 0, LastPostCustomerId = 0, LastPostTime = null, DisplayOrder = 1, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(newProductsForum); var mobileDevicesForum = new Forum { ForumGroupId = forumGroup.Id, Name = "Mobile Devices Forum", Description = "Discuss the mobile phone market", NumTopics = 0, NumPosts = 0, LastPostCustomerId = 0, LastPostTime = null, DisplayOrder = 10, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(mobileDevicesForum); var packagingShippingForum = new Forum { ForumGroupId = forumGroup.Id, Name = "Packaging & Shipping", Description = "Discuss packaging & shipping", NumTopics = 0, NumPosts = 0, LastPostTime = null, DisplayOrder = 20, CreatedOnUtc = DateTime.UtcNow, UpdatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(packagingShippingForum); } /// A task that represents the asynchronous operation protected virtual async Task InstallDiscountsAsync() { var discounts = new List { new() { IsActive = true, Name = "Sample discount with coupon code", DiscountType = DiscountType.AssignedToSkus, DiscountLimitation = DiscountLimitationType.Unlimited, UsePercentage = false, DiscountAmount = 10, RequiresCouponCode = true, CouponCode = "123" }, new() { IsActive = true, Name = "'20% order total' discount", DiscountType = DiscountType.AssignedToOrderTotal, DiscountLimitation = DiscountLimitationType.Unlimited, UsePercentage = true, DiscountPercentage = 20, StartDateUtc = new DateTime(2010, 1, 1), EndDateUtc = new DateTime(2020, 1, 1), RequiresCouponCode = true, CouponCode = "456" } }; await InsertInstallationDataAsync(discounts); } /// A task that represents the asynchronous operation protected virtual async Task InstallBlogPostsAsync(string defaultUserEmail) { var defaultLanguage = _languageRepository.Table.FirstOrDefault() ?? throw new Exception("Default language could not be loaded"); var blogService = EngineContext.Current.Resolve(); var blogPosts = new List { new() { AllowComments = true, LanguageId = defaultLanguage.Id, Title = "How a blog can help your growing e-Commerce business", BodyOverview = "

When you start an online business, your main aim is to sell the products, right? As a business owner, you want to showcase your store to more audience. So, you decide to go on social media, why? Because everyone is doing it, then why shouldn’t you? It is tempting as everyone is aware of the hype that it is the best way to market your brand.

Do you know having a blog for your online store can be very helpful? Many businesses do not understand the importance of having a blog because they don’t have time to post quality content.

Today, we will talk about how a blog can play an important role for the growth of your e-Commerce business. Later, we will also discuss some tips that will be helpful to you for writing business related blog posts.

", Body = "

When you start an online business, your main aim is to sell the products, right? As a business owner, you want to showcase your store to more audience. So, you decide to go on social media, why? Because everyone is doing it, then why shouldn’t you? It is tempting as everyone is aware of the hype that it is the best way to market your brand.

Do you know having a blog for your online store can be very helpful? Many businesses do not understand the importance of having a blog because they don’t have time to post quality content.

Today, we will talk about how a blog can play an important role for the growth of your e-Commerce business. Later, we will also discuss some tips that will be helpful to you for writing business related blog posts.

1) Blog is useful in educating your customers

Blogging is one of the best way by which you can educate your customers about your products/services that you offer. This helps you as a business owner to bring more value to your brand. When you provide useful information to the customers about your products, they are more likely to buy products from you. You can use your blog for providing tutorials in regard to the use of your products.

For example: If you have an online store that offers computer parts. You can write tutorials about how to build a computer or how to make your computer’s performance better. While talking about these things, you can mention products in the tutorials and provide link to your products within the blog post from your website. Your potential customers might get different ideas of using your product and will likely to buy products from your online store.

2) Blog helps your business in Search Engine Optimization (SEO)

Blog posts create more internal links to your website which helps a lot in SEO. Blog is a great way to have quality content on your website related to your products/services which is indexed by all major search engines like Google, Bing and Yahoo. The more original content you write in your blog post, the better ranking you will get in search engines. SEO is an on-going process and posting blog posts regularly keeps your site active all the time which is beneficial when it comes to search engine optimization.

For example: Let’s say you sell “Sony Television Model XYZ” and you regularly publish blog posts about your product. Now, whenever someone searches for “Sony Television Model XYZ”, Google will crawl on your website knowing that you have something to do with this particular product. Hence, your website will show up on the search result page whenever this item is being searched.

3) Blog helps in boosting your sales by convincing the potential customers to buy

If you own an online business, there are so many ways you can share different stories with your audience in regard your products/services that you offer. Talk about how you started your business, share stories that educate your audience about what’s new in your industry, share stories about how your product/service was beneficial to someone or share anything that you think your audience might find interesting (it does not have to be related to your product). This kind of blogging shows that you are an expert in your industry and interested in educating your audience. It sets you apart in the competitive market. This gives you an opportunity to showcase your expertise by educating the visitors and it can turn your audience into buyers.

Fun Fact: Did you know that 92% of companies who decided to blog acquired customers through their blog?

nopCommerce is great e-Commerce solution that also offers a variety of CMS features including blog. A store owner has full access for managing the blog posts and related comments.

", Tags = "e-commerce, blog, moey", CreatedOnUtc = DateTime.UtcNow }, new() { AllowComments = true, LanguageId = defaultLanguage.Id, Title = "Why your online store needs a wish list", BodyOverview = "

What comes to your mind, when you hear the term” wish list”? The application of this feature is exactly how it sounds like: a list of things that you wish to get. As an online store owner, would you like your customers to be able to save products in a wish list so that they review or buy them later? Would you like your customers to be able to share their wish list with friends and family for gift giving?

Offering your customers a feature of wish list as part of shopping cart is a great way to build loyalty to your store site. Having the feature of wish list on a store site allows online businesses to engage with their customers in a smart way as it allows the shoppers to create a list of what they desire and their preferences for future purchase.

", Body = "

What comes to your mind, when you hear the term” wish list”? The application of this feature is exactly how it sounds like: a list of things that you wish to get. As an online store owner, would you like your customers to be able to save products in a wish list so that they review or buy them later? Would you like your customers to be able to share their wish list with friends and family for gift giving?

Offering your customers a feature of wish list as part of shopping cart is a great way to build loyalty to your store site. Having the feature of wish list on a store site allows online businesses to engage with their customers in a smart way as it allows the shoppers to create a list of what they desire and their preferences for future purchase.

Does every e-Commerce store needs a wish list? The answer to this question in most cases is yes, because of the following reasons:

Understanding the needs of your customers - A wish list is a great way to know what is in your customer’s mind. Try to think the purchase history as a small portion of the customer’s preferences. But, the wish list is like a wide open door that can give any online business a lot of valuable information about their customer and what they like or desire.

Shoppers like to share their wish list with friends and family - Providing your customers a way to email their wish list to their friends and family is a pleasant way to make online shopping enjoyable for the shoppers. It is always a good idea to make the wish list sharable by a unique link so that it can be easily shared though different channels like email or on social media sites.

Wish list can be a great marketing tool – Another way to look at wish list is a great marketing tool because it is extremely targeted and the recipients are always motivated to use it. For example: when your younger brother tells you that his wish list is on a certain e-Commerce store. What is the first thing you are going to do? You are most likely to visit the e-Commerce store, check out the wish list and end up buying something for your younger brother.

So, how a wish list is a marketing tool? The reason is quite simple, it introduce your online store to new customers just how it is explained in the above example.

Encourage customers to return to the store site – Having a feature of wish list on the store site can increase the return traffic because it encourages customers to come back and buy later. Allowing the customers to save the wish list to their online accounts gives them a reason return to the store site and login to the account at any time to view or edit the wish list items.

Wish list can be used for gifts for different occasions like weddings or birthdays. So, what kind of benefits a gift-giver gets from a wish list?

  • It gives them a surety that they didn’t buy a wrong gift
  • It guarantees that the recipient will like the gift
  • It avoids any awkward moments when the recipient unwraps the gift and as a gift-giver you got something that the recipient do not want

Wish list is a great feature to have on a store site – So, what kind of benefits a business owner gets from a wish list

  • It is a great way to advertise an online store as many people do prefer to shop where their friend or family shop online
  • It allows the current customers to return to the store site and open doors for the new customers
  • It allows store admins to track what’s in customers wish list and run promotions accordingly to target specific customer segments

nopCommerce offers the feature of wish list that allows customers to create a list of products that they desire or planning to buy in future.

", Tags = "e-commerce, nopCommerce, sample tag, money", CreatedOnUtc = DateTime.UtcNow.AddSeconds(1) } }; await InsertInstallationDataAsync(blogPosts); //search engine names foreach (var blogPost in blogPosts) await InsertInstallationDataAsync(new UrlRecord { EntityId = blogPost.Id, EntityName = nameof(BlogPost), LanguageId = blogPost.LanguageId, IsActive = true, Slug = await ValidateSeNameAsync(blogPost, blogPost.Title) }); //comments var defaultCustomer = _customerRepository.Table.FirstOrDefault(x => x.Email == defaultUserEmail) ?? throw new Exception("Cannot load default customer"); //default store var defaultStore = _storeRepository.Table.FirstOrDefault() ?? throw new Exception("No default store could be loaded"); foreach (var blogPost in blogPosts) await blogService.InsertBlogCommentAsync(new BlogComment { BlogPostId = blogPost.Id, CustomerId = defaultCustomer.Id, CommentText = "This is a sample comment for this blog post", IsApproved = true, StoreId = defaultStore.Id, CreatedOnUtc = DateTime.UtcNow }); await UpdateInstallationDataAsync(blogPosts); } /// A task that represents the asynchronous operation protected virtual async Task InstallNewsAsync(string defaultUserEmail) { var defaultLanguage = _languageRepository.Table.FirstOrDefault() ?? throw new Exception("Default language could not be loaded"); var newsService = EngineContext.Current.Resolve(); var news = new List { new() { AllowComments = true, LanguageId = defaultLanguage.Id, Title = "About nopCommerce", Short = "It's stable and highly usable. From downloads to documentation, www.nopCommerce.com offers a comprehensive base of information, resources, and support to the nopCommerce community.", Full = "

For full feature list go to nopCommerce.com

Providing outstanding custom search engine optimization, web development services and e-commerce development solutions to our clients at a fair price in a professional manner.

", Published = true, CreatedOnUtc = DateTime.UtcNow }, new() { AllowComments = true, LanguageId = defaultLanguage.Id, Title = "nopCommerce new release!", Short = "nopCommerce includes everything you need to begin your e-commerce online store. We have thought of everything and it's all included! nopCommerce is a fully customizable shopping cart", Full = "

nopCommerce includes everything you need to begin your e-commerce online store. We have thought of everything and it's all included!

", Published = true, CreatedOnUtc = DateTime.UtcNow.AddSeconds(1) }, new() { AllowComments = true, LanguageId = defaultLanguage.Id, Title = "New online store is open!", Short = "The new nopCommerce store is open now! We are very excited to offer our new range of products. We will be constantly adding to our range so please register on our site.", Full = "

Our online store is officially up and running. Stock up for the holiday season! We have a great selection of items. We will be constantly adding to our range so please register on our site, this will enable you to keep up to date with any new products.

All shipping is worldwide and will leave the same day an order is placed! Happy Shopping and spread the word!!

", Published = true, CreatedOnUtc = DateTime.UtcNow.AddSeconds(2) } }; await InsertInstallationDataAsync(news); //search engine names foreach (var newsItem in news) await InsertInstallationDataAsync(new UrlRecord { EntityId = newsItem.Id, EntityName = nameof(NewsItem), LanguageId = newsItem.LanguageId, IsActive = true, Slug = await ValidateSeNameAsync(newsItem, newsItem.Title) }); //comments var defaultCustomer = _customerRepository.Table.FirstOrDefault(x => x.Email == defaultUserEmail) ?? throw new Exception("Cannot load default customer"); //default store var defaultStore = _storeRepository.Table.FirstOrDefault() ?? throw new Exception("No default store could be loaded"); foreach (var newsItem in news) await newsService.InsertNewsCommentAsync(new NewsComment { NewsItemId = newsItem.Id, CustomerId = defaultCustomer.Id, CommentTitle = "Sample comment title", CommentText = "This is a sample comment...", IsApproved = true, StoreId = defaultStore.Id, CreatedOnUtc = DateTime.UtcNow }); await UpdateInstallationDataAsync(news); } /// A task that represents the asynchronous operation protected virtual async Task InstallPollsAsync() { var defaultLanguage = _languageRepository.Table.FirstOrDefault() ?? throw new Exception("Default language could not be loaded"); var poll1 = new Poll { LanguageId = defaultLanguage.Id, Name = "Do you like nopCommerce?", SystemKeyword = string.Empty, Published = true, ShowOnHomepage = true, DisplayOrder = 1 }; await InsertInstallationDataAsync(poll1); var answers = new List { new() { Name = "Excellent", DisplayOrder = 1, PollId = poll1.Id }, new() { Name = "Good", DisplayOrder = 2, PollId = poll1.Id }, new() { Name = "Poor", DisplayOrder = 3, PollId = poll1.Id }, new() { Name = "Very bad", DisplayOrder = 4, PollId = poll1.Id } }; await InsertInstallationDataAsync(answers); } /// A task that represents the asynchronous operation protected virtual async Task InstallActivityLogTypesAsync() { var activityLogTypes = new List { //admin area activities new() { SystemKeyword = "AddNewAddressAttribute", Enabled = true, Name = "Add a new address attribute" }, new() { SystemKeyword = "AddNewAddressAttributeValue", Enabled = true, Name = "Add a new address attribute value" }, new() { SystemKeyword = "AddNewAffiliate", Enabled = true, Name = "Add a new affiliate" }, new() { SystemKeyword = "AddNewBlogPost", Enabled = true, Name = "Add a new blog post" }, new() { SystemKeyword = "AddNewCampaign", Enabled = true, Name = "Add a new campaign" }, new() { SystemKeyword = "AddNewCategory", Enabled = true, Name = "Add a new category" }, new() { SystemKeyword = "AddNewCheckoutAttribute", Enabled = true, Name = "Add a new checkout attribute" }, new() { SystemKeyword = "AddNewCountry", Enabled = true, Name = "Add a new country" }, new() { SystemKeyword = "AddNewCurrency", Enabled = true, Name = "Add a new currency" }, new() { SystemKeyword = "AddNewCustomer", Enabled = true, Name = "Add a new customer" }, new() { SystemKeyword = "AddNewCustomerAttribute", Enabled = true, Name = "Add a new customer attribute" }, new() { SystemKeyword = "AddNewCustomerAttributeValue", Enabled = true, Name = "Add a new customer attribute value" }, new() { SystemKeyword = "AddNewCustomerRole", Enabled = true, Name = "Add a new customer role" }, new() { SystemKeyword = "AddNewDiscount", Enabled = true, Name = "Add a new discount" }, new() { SystemKeyword = "AddNewEmailAccount", Enabled = true, Name = "Add a new email account" }, new() { SystemKeyword = "AddNewGiftCard", Enabled = true, Name = "Add a new gift card" }, new() { SystemKeyword = "AddNewLanguage", Enabled = true, Name = "Add a new language" }, new() { SystemKeyword = "AddNewManufacturer", Enabled = true, Name = "Add a new manufacturer" }, new() { SystemKeyword = "AddNewMeasureDimension", Enabled = true, Name = "Add a new measure dimension" }, new() { SystemKeyword = "AddNewMeasureWeight", Enabled = true, Name = "Add a new measure weight" }, new() { SystemKeyword = "AddNewNews", Enabled = true, Name = "Add a new news" }, new() { SystemKeyword = "AddNewProduct", Enabled = true, Name = "Add a new product" }, new() { SystemKeyword = "AddNewProductAttribute", Enabled = true, Name = "Add a new product attribute" }, new() { SystemKeyword = "AddNewSetting", Enabled = true, Name = "Add a new setting" }, new() { SystemKeyword = "AddNewSpecAttribute", Enabled = true, Name = "Add a new specification attribute" }, new() { SystemKeyword = "AddNewSpecAttributeGroup", Enabled = true, Name = "Add a new specification attribute group" }, new() { SystemKeyword = "AddNewStateProvince", Enabled = true, Name = "Add a new state or province" }, new() { SystemKeyword = "AddNewStore", Enabled = true, Name = "Add a new store" }, new() { SystemKeyword = "AddNewTopic", Enabled = true, Name = "Add a new topic" }, new() { SystemKeyword = "AddNewReviewType", Enabled = true, Name = "Add a new review type" }, new() { SystemKeyword = "AddNewVendor", Enabled = true, Name = "Add a new vendor" }, new() { SystemKeyword = "AddNewVendorAttribute", Enabled = true, Name = "Add a new vendor attribute" }, new() { SystemKeyword = "AddNewVendorAttributeValue", Enabled = true, Name = "Add a new vendor attribute value" }, new() { SystemKeyword = "AddNewWarehouse", Enabled = true, Name = "Add a new warehouse" }, new() { SystemKeyword = "AddNewWidget", Enabled = true, Name = "Add a new widget" }, new() { SystemKeyword = "DeleteActivityLog", Enabled = true, Name = "Delete activity log" }, new() { SystemKeyword = "DeleteAddressAttribute", Enabled = true, Name = "Delete an address attribute" }, new() { SystemKeyword = "DeleteAddressAttributeValue", Enabled = true, Name = "Delete an address attribute value" }, new() { SystemKeyword = "DeleteAffiliate", Enabled = true, Name = "Delete an affiliate" }, new() { SystemKeyword = "DeleteBlogPost", Enabled = true, Name = "Delete a blog post" }, new() { SystemKeyword = "DeleteBlogPostComment", Enabled = true, Name = "Delete a blog post comment" }, new() { SystemKeyword = "DeleteCampaign", Enabled = true, Name = "Delete a campaign" }, new() { SystemKeyword = "DeleteCategory", Enabled = true, Name = "Delete category" }, new() { SystemKeyword = "DeleteCheckoutAttribute", Enabled = true, Name = "Delete a checkout attribute" }, new() { SystemKeyword = "DeleteCountry", Enabled = true, Name = "Delete a country" }, new() { SystemKeyword = "DeleteCurrency", Enabled = true, Name = "Delete a currency" }, new() { SystemKeyword = "DeleteCustomer", Enabled = true, Name = "Delete a customer" }, new() { SystemKeyword = "DeleteCustomerAttribute", Enabled = true, Name = "Delete a customer attribute" }, new() { SystemKeyword = "DeleteCustomerAttributeValue", Enabled = true, Name = "Delete a customer attribute value" }, new() { SystemKeyword = "DeleteCustomerRole", Enabled = true, Name = "Delete a customer role" }, new() { SystemKeyword = "DeleteDiscount", Enabled = true, Name = "Delete a discount" }, new() { SystemKeyword = "DeleteEmailAccount", Enabled = true, Name = "Delete an email account" }, new() { SystemKeyword = "DeleteGiftCard", Enabled = true, Name = "Delete a gift card" }, new() { SystemKeyword = "DeleteLanguage", Enabled = true, Name = "Delete a language" }, new() { SystemKeyword = "DeleteManufacturer", Enabled = true, Name = "Delete a manufacturer" }, new() { SystemKeyword = "DeleteMeasureDimension", Enabled = true, Name = "Delete a measure dimension" }, new() { SystemKeyword = "DeleteMeasureWeight", Enabled = true, Name = "Delete a measure weight" }, new() { SystemKeyword = "DeleteMessageTemplate", Enabled = true, Name = "Delete a message template" }, new() { SystemKeyword = "DeleteNews", Enabled = true, Name = "Delete a news" }, new() { SystemKeyword = "DeleteNewsComment", Enabled = true, Name = "Delete a news comment" }, new() { SystemKeyword = "DeleteOrder", Enabled = true, Name = "Delete an order" }, new() { SystemKeyword = "DeletePlugin", Enabled = true, Name = "Delete a plugin" }, new() { SystemKeyword = "DeleteProduct", Enabled = true, Name = "Delete a product" }, new() { SystemKeyword = "DeleteProductAttribute", Enabled = true, Name = "Delete a product attribute" }, new() { SystemKeyword = "DeleteProductReview", Enabled = true, Name = "Delete a product review" }, new() { SystemKeyword = "DeleteReturnRequest", Enabled = true, Name = "Delete a return request" }, new() { SystemKeyword = "DeleteReviewType", Enabled = true, Name = "Delete a review type" }, new() { SystemKeyword = "DeleteSetting", Enabled = true, Name = "Delete a setting" }, new() { SystemKeyword = "DeleteSpecAttribute", Enabled = true, Name = "Delete a specification attribute" }, new() { SystemKeyword = "DeleteSpecAttributeGroup", Enabled = true, Name = "Delete a specification attribute group" }, new() { SystemKeyword = "DeleteStateProvince", Enabled = true, Name = "Delete a state or province" }, new() { SystemKeyword = "DeleteStore", Enabled = true, Name = "Delete a store" }, new() { SystemKeyword = "DeleteSystemLog", Enabled = true, Name = "Delete system log" }, new() { SystemKeyword = "DeleteTopic", Enabled = true, Name = "Delete a topic" }, new() { SystemKeyword = "DeleteVendor", Enabled = true, Name = "Delete a vendor" }, new() { SystemKeyword = "DeleteVendorAttribute", Enabled = true, Name = "Delete a vendor attribute" }, new() { SystemKeyword = "DeleteVendorAttributeValue", Enabled = true, Name = "Delete a vendor attribute value" }, new() { SystemKeyword = "DeleteWarehouse", Enabled = true, Name = "Delete a warehouse" }, new() { SystemKeyword = "DeleteWidget", Enabled = true, Name = "Delete a widget" }, new() { SystemKeyword = "EditActivityLogTypes", Enabled = true, Name = "Edit activity log types" }, new() { SystemKeyword = "EditAddressAttribute", Enabled = true, Name = "Edit an address attribute" }, new() { SystemKeyword = "EditAddressAttributeValue", Enabled = true, Name = "Edit an address attribute value" }, new() { SystemKeyword = "EditAffiliate", Enabled = true, Name = "Edit an affiliate" }, new() { SystemKeyword = "EditBlogPost", Enabled = true, Name = "Edit a blog post" }, new() { SystemKeyword = "EditCampaign", Enabled = true, Name = "Edit a campaign" }, new() { SystemKeyword = "EditCategory", Enabled = true, Name = "Edit category" }, new() { SystemKeyword = "EditCheckoutAttribute", Enabled = true, Name = "Edit a checkout attribute" }, new() { SystemKeyword = "EditCountry", Enabled = true, Name = "Edit a country" }, new() { SystemKeyword = "EditCurrency", Enabled = true, Name = "Edit a currency" }, new() { SystemKeyword = "EditCustomer", Enabled = true, Name = "Edit a customer" }, new() { SystemKeyword = "EditCustomerAttribute", Enabled = true, Name = "Edit a customer attribute" }, new() { SystemKeyword = "EditCustomerAttributeValue", Enabled = true, Name = "Edit a customer attribute value" }, new() { SystemKeyword = "EditCustomerRole", Enabled = true, Name = "Edit a customer role" }, new() { SystemKeyword = "EditDiscount", Enabled = true, Name = "Edit a discount" }, new() { SystemKeyword = "EditEmailAccount", Enabled = true, Name = "Edit an email account" }, new() { SystemKeyword = "EditGiftCard", Enabled = true, Name = "Edit a gift card" }, new() { SystemKeyword = "EditLanguage", Enabled = true, Name = "Edit a language" }, new() { SystemKeyword = "EditManufacturer", Enabled = true, Name = "Edit a manufacturer" }, new() { SystemKeyword = "EditMeasureDimension", Enabled = true, Name = "Edit a measure dimension" }, new() { SystemKeyword = "EditMeasureWeight", Enabled = true, Name = "Edit a measure weight" }, new() { SystemKeyword = "EditMessageTemplate", Enabled = true, Name = "Edit a message template" }, new() { SystemKeyword = "EditNews", Enabled = true, Name = "Edit a news" }, new() { SystemKeyword = "EditOrder", Enabled = true, Name = "Edit an order" }, new() { SystemKeyword = "EditPlugin", Enabled = true, Name = "Edit a plugin" }, new() { SystemKeyword = "EditProduct", Enabled = true, Name = "Edit a product" }, new() { SystemKeyword = "EditProductAttribute", Enabled = true, Name = "Edit a product attribute" }, new() { SystemKeyword = "EditProductReview", Enabled = true, Name = "Edit a product review" }, new() { SystemKeyword = "EditPromotionProviders", Enabled = true, Name = "Edit promotion providers" }, new() { SystemKeyword = "EditReturnRequest", Enabled = true, Name = "Edit a return request" }, new() { SystemKeyword = "EditReviewType", Enabled = true, Name = "Edit a review type" }, new() { SystemKeyword = "EditSettings", Enabled = true, Name = "Edit setting(s)" }, new() { SystemKeyword = "EditStateProvince", Enabled = true, Name = "Edit a state or province" }, new() { SystemKeyword = "EditStore", Enabled = true, Name = "Edit a store" }, new() { SystemKeyword = "EditTask", Enabled = true, Name = "Edit a task" }, new() { SystemKeyword = "EditSpecAttribute", Enabled = true, Name = "Edit a specification attribute" }, new() { SystemKeyword = "EditSpecAttributeGroup", Enabled = true, Name = "Edit a specification attribute group" }, new() { SystemKeyword = "EditVendor", Enabled = true, Name = "Edit a vendor" }, new() { SystemKeyword = "EditVendorAttribute", Enabled = true, Name = "Edit a vendor attribute" }, new() { SystemKeyword = "EditVendorAttributeValue", Enabled = true, Name = "Edit a vendor attribute value" }, new() { SystemKeyword = "EditWarehouse", Enabled = true, Name = "Edit a warehouse" }, new() { SystemKeyword = "EditTopic", Enabled = true, Name = "Edit a topic" }, new() { SystemKeyword = "EditWidget", Enabled = true, Name = "Edit a widget" }, new() { SystemKeyword = "Impersonation.Started", Enabled = true, Name = "Customer impersonation session. Started" }, new() { SystemKeyword = "Impersonation.Finished", Enabled = true, Name = "Customer impersonation session. Finished" }, new() { SystemKeyword = "ImportCategories", Enabled = true, Name = "Categories were imported" }, new() { SystemKeyword = "ImportManufacturers", Enabled = true, Name = "Manufacturers were imported" }, new() { SystemKeyword = "ImportProducts", Enabled = true, Name = "Products were imported" }, new() { SystemKeyword = "ImportCustomers", Enabled = true, Name = "Customers were imported" }, new() { SystemKeyword = "ImportNewsLetterSubscriptions", Enabled = true, Name = "Newsletter subscriptions were imported" }, new() { SystemKeyword = "ImportStates", Enabled = true, Name = "States were imported" }, new() { SystemKeyword = "ExportCustomers", Enabled = true, Name = "Customers were exported" }, new() { SystemKeyword = "ExportCategories", Enabled = true, Name = "Categories were exported" }, new() { SystemKeyword = "ExportManufacturers", Enabled = true, Name = "Manufacturers were exported" }, new() { SystemKeyword = "ExportProducts", Enabled = true, Name = "Products were exported" }, new() { SystemKeyword = "ExportOrders", Enabled = true, Name = "Orders were exported" }, new() { SystemKeyword = "ExportStates", Enabled = true, Name = "States were exported" }, new() { SystemKeyword = "ExportNewsLetterSubscriptions", Enabled = true, Name = "Newsletter subscriptions were exported" }, new() { SystemKeyword = "InstallNewPlugin", Enabled = true, Name = "Install a new plugin" }, new() { SystemKeyword = "UninstallPlugin", Enabled = true, Name = "Uninstall a plugin" }, new() { SystemKeyword = "UpdatePlugin", Enabled = true, Name = "Update a plugin" }, //public store activities new() { SystemKeyword = "PublicStore.ViewCategory", Enabled = false, Name = "Public store. View a category" }, new() { SystemKeyword = "PublicStore.ViewManufacturer", Enabled = false, Name = "Public store. View a manufacturer" }, new() { SystemKeyword = "PublicStore.ViewProduct", Enabled = false, Name = "Public store. View a product" }, new() { SystemKeyword = "PublicStore.PlaceOrder", Enabled = false, Name = "Public store. Place an order" }, new() { SystemKeyword = "PublicStore.SendPM", Enabled = false, Name = "Public store. Send PM" }, new() { SystemKeyword = "PublicStore.ContactUs", Enabled = false, Name = "Public store. Use contact us form" }, new() { SystemKeyword = "PublicStore.AddToCompareList", Enabled = false, Name = "Public store. Add to compare list" }, new() { SystemKeyword = "PublicStore.AddToShoppingCart", Enabled = false, Name = "Public store. Add to shopping cart" }, new() { SystemKeyword = "PublicStore.AddToWishlist", Enabled = false, Name = "Public store. Add to wishlist" }, new() { SystemKeyword = "PublicStore.Login", Enabled = false, Name = "Public store. Login" }, new() { SystemKeyword = "PublicStore.Logout", Enabled = false, Name = "Public store. Logout" }, new() { SystemKeyword = "PublicStore.AddProductReview", Enabled = false, Name = "Public store. Add product review" }, new() { SystemKeyword = "PublicStore.AddNewsComment", Enabled = false, Name = "Public store. Add news comment" }, new() { SystemKeyword = "PublicStore.AddBlogComment", Enabled = false, Name = "Public store. Add blog comment" }, new() { SystemKeyword = "PublicStore.AddForumTopic", Enabled = false, Name = "Public store. Add forum topic" }, new() { SystemKeyword = "PublicStore.EditForumTopic", Enabled = false, Name = "Public store. Edit forum topic" }, new() { SystemKeyword = "PublicStore.DeleteForumTopic", Enabled = false, Name = "Public store. Delete forum topic" }, new() { SystemKeyword = "PublicStore.AddForumPost", Enabled = false, Name = "Public store. Add forum post" }, new() { SystemKeyword = "PublicStore.EditForumPost", Enabled = false, Name = "Public store. Edit forum post" }, new() { SystemKeyword = "PublicStore.DeleteForumPost", Enabled = false, Name = "Public store. Delete forum post" }, new() { SystemKeyword = "UploadNewPlugin", Enabled = true, Name = "Upload a plugin" }, new() { SystemKeyword = "UploadNewTheme", Enabled = true, Name = "Upload a theme" }, new() { SystemKeyword = "UploadIcons", Enabled = true, Name = "Upload a favicon and app icons" } }; await InsertInstallationDataAsync(activityLogTypes); } /// A task that represents the asynchronous operation protected virtual async Task InstallProductTemplatesAsync() { var productTemplates = new List { new() { Name = "Simple product", ViewPath = "ProductTemplate.Simple", DisplayOrder = 10, IgnoredProductTypes = ((int)ProductType.GroupedProduct).ToString() }, new() { Name = "Grouped product (with variants)", ViewPath = "ProductTemplate.Grouped", DisplayOrder = 100, IgnoredProductTypes = ((int)ProductType.SimpleProduct).ToString() } }; await InsertInstallationDataAsync(productTemplates); } /// A task that represents the asynchronous operation protected virtual async Task InstallCategoryTemplatesAsync() { var categoryTemplates = new List { new() { Name = "Products in Grid or Lines", ViewPath = "CategoryTemplate.ProductsInGridOrLines", DisplayOrder = 1 } }; await InsertInstallationDataAsync(categoryTemplates); } /// A task that represents the asynchronous operation protected virtual async Task InstallManufacturerTemplatesAsync() { var manufacturerTemplates = new List { new() { Name = "Products in Grid or Lines", ViewPath = "ManufacturerTemplate.ProductsInGridOrLines", DisplayOrder = 1 } }; await InsertInstallationDataAsync(manufacturerTemplates); } /// A task that represents the asynchronous operation protected virtual async Task InstallTopicTemplatesAsync() { var topicTemplates = new List { new() { Name = "Default template", ViewPath = "TopicDetails", DisplayOrder = 1 } }; await InsertInstallationDataAsync(topicTemplates); } /// A task that represents the asynchronous operation protected virtual async Task InstallScheduleTasksAsync() { var lastEnabledUtc = DateTime.UtcNow; var tasks = new List { new() { Name = "Send emails", Seconds = 60, Type = "Nop.Services.Messages.QueuedMessagesSendTask, Nop.Services", Enabled = true, LastEnabledUtc = lastEnabledUtc, StopOnError = false }, new() { Name = "Keep alive", Seconds = 300, Type = "Nop.Services.Common.KeepAliveTask, Nop.Services", Enabled = true, LastEnabledUtc = lastEnabledUtc, StopOnError = false }, new() { Name = nameof(ResetLicenseCheckTask), Seconds = 2073600, Type = "Nop.Services.Common.ResetLicenseCheckTask, Nop.Services", Enabled = true, LastEnabledUtc = lastEnabledUtc, StopOnError = false }, new() { Name = "Delete guests", Seconds = 600, Type = "Nop.Services.Customers.DeleteGuestsTask, Nop.Services", Enabled = true, LastEnabledUtc = lastEnabledUtc, StopOnError = false }, new() { Name = "Clear cache", Seconds = 600, Type = "Nop.Services.Caching.ClearCacheTask, Nop.Services", Enabled = false, StopOnError = false }, new() { Name = "Clear log", //60 minutes Seconds = 3600, Type = "Nop.Services.Logging.ClearLogTask, Nop.Services", Enabled = false, StopOnError = false }, new() { Name = "Update currency exchange rates", //60 minutes Seconds = 3600, Type = "Nop.Services.Directory.UpdateExchangeRateTask, Nop.Services", Enabled = true, LastEnabledUtc = lastEnabledUtc, StopOnError = false }, new() { Name = "Delete inactive customers (GDPR)", //24 hours Seconds = 86400, Type = "Nop.Services.Gdpr.DeleteInactiveCustomersTask, Nop.Services", Enabled = false, StopOnError = false } }; await InsertInstallationDataAsync(tasks); } /// A task that represents the asynchronous operation protected virtual async Task InstallReturnRequestReasonsAsync() { var returnRequestReasons = new List { new() { Name = "Received Wrong Product", DisplayOrder = 1 }, new() { Name = "Wrong Product Ordered", DisplayOrder = 2 }, new() { Name = "There Was A Problem With The Product", DisplayOrder = 3 } }; await InsertInstallationDataAsync(returnRequestReasons); } /// A task that represents the asynchronous operation protected virtual async Task InstallReturnRequestActionsAsync() { var returnRequestActions = new List { new() { Name = "Repair", DisplayOrder = 1 }, new() { Name = "Replacement", DisplayOrder = 2 }, new() { Name = "Store Credit", DisplayOrder = 3 } }; await InsertInstallationDataAsync(returnRequestActions); } /// A task that represents the asynchronous operation protected virtual async Task InstallWarehousesAsync() { var warehouse1address = new Address { Address1 = "21 West 52nd Street", City = "New York", StateProvinceId = _stateProvinceRepository.Table.FirstOrDefault(sp => sp.Name == "New York")?.Id, CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "USA")?.Id, ZipPostalCode = "10021", CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(warehouse1address); var warehouse2address = new Address { Address1 = "300 South Spring Stree", City = "Los Angeles", StateProvinceId = _stateProvinceRepository.Table.FirstOrDefault(sp => sp.Name == "California")?.Id, CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "USA")?.Id, ZipPostalCode = "90013", CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(warehouse2address); var warehouses = new List { new() { Name = "Warehouse 1 (New York)", AddressId = warehouse1address.Id }, new() { Name = "Warehouse 2 (Los Angeles)", AddressId = warehouse2address.Id } }; await InsertInstallationDataAsync(warehouses); } /// A task that represents the asynchronous operation protected virtual async Task InstallVendorsAsync() { var vendors = new List { new() { Name = "Vendor 1", Email = "vendor1email@gmail.com", Description = "Some description...", AdminComment = string.Empty, PictureId = 0, Active = true, DisplayOrder = 1, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9, 18", PriceRangeFiltering = true, ManuallyPriceRange = true, PriceFrom = NopCatalogDefaults.DefaultPriceRangeFrom, PriceTo = NopCatalogDefaults.DefaultPriceRangeTo, }, new() { Name = "Vendor 2", Email = "vendor2email@gmail.com", Description = "Some description...", AdminComment = string.Empty, PictureId = 0, Active = true, DisplayOrder = 2, PageSize = 6, AllowCustomersToSelectPageSize = true, PageSizeOptions = "6, 3, 9, 18" } }; await InsertInstallationDataAsync(vendors); //search engine names foreach (var vendor in vendors) await InsertInstallationDataAsync(new UrlRecord { EntityId = vendor.Id, EntityName = nameof(Vendor), LanguageId = 0, IsActive = true, Slug = await ValidateSeNameAsync(vendor, vendor.Name) }); } /// A task that represents the asynchronous operation protected virtual async Task InstallAffiliatesAsync() { var affiliateAddress = new Address { FirstName = "John", LastName = "Smith", Email = "affiliate_email@gmail.com", Company = "Company name here...", City = "New York", Address1 = "21 West 52nd Street", ZipPostalCode = "10021", PhoneNumber = "123456789", StateProvinceId = _stateProvinceRepository.Table.FirstOrDefault(sp => sp.Name == "New York")?.Id, CountryId = _countryRepository.Table.FirstOrDefault(c => c.ThreeLetterIsoCode == "USA")?.Id, CreatedOnUtc = DateTime.UtcNow }; await InsertInstallationDataAsync(affiliateAddress); var affilate = new Affiliate { Active = true, AddressId = affiliateAddress.Id }; await InsertInstallationDataAsync(affilate); } /// A task that represents the asynchronous operation protected virtual async Task AddProductTagAsync(Product product, string tag) { var productTag = _productTagRepository.Table.FirstOrDefault(pt => pt.Name == tag); if (productTag is null) { productTag = new ProductTag { Name = tag }; await InsertInstallationDataAsync(productTag); //search engine name await InsertInstallationDataAsync(new UrlRecord { EntityId = productTag.Id, EntityName = nameof(ProductTag), LanguageId = 0, IsActive = true, Slug = await ValidateSeNameAsync(productTag, productTag.Name) }); } await InsertInstallationDataAsync(new ProductProductTagMapping { ProductTagId = productTag.Id, ProductId = product.Id }); } #endregion #region Methods /// /// Install required data /// /// Default user email /// Default user password /// Language pack info /// RegionInfo /// CultureInfo /// A task that represents the asynchronous operation public virtual async Task InstallRequiredDataAsync(string defaultUserEmail, string defaultUserPassword, (string languagePackDownloadLink, int languagePackProgress) languagePackInfo, RegionInfo regionInfo, CultureInfo cultureInfo) { await InstallStoresAsync(); await InstallMeasuresAsync(regionInfo); await InstallTaxCategoriesAsync(); await InstallLanguagesAsync(languagePackInfo, cultureInfo, regionInfo); await InstallCurrenciesAsync(cultureInfo, regionInfo); await InstallCountriesAndStatesAsync(); await InstallShippingMethodsAsync(); await InstallDeliveryDatesAsync(); await InstallProductAvailabilityRangesAsync(); await InstallEmailAccountsAsync(); await InstallMessageTemplatesAsync(); await InstallTopicTemplatesAsync(); await InstallSettingsAsync(regionInfo); await InstallCustomersAndUsersAsync(defaultUserEmail, defaultUserPassword); await InstallTopicsAsync(); await InstallActivityLogTypesAsync(); await InstallProductTemplatesAsync(); await InstallCategoryTemplatesAsync(); await InstallManufacturerTemplatesAsync(); await InstallScheduleTasksAsync(); await InstallReturnRequestReasonsAsync(); await InstallReturnRequestActionsAsync(); } /// /// Install sample data /// /// Default user email /// A task that represents the asynchronous operation public virtual async Task InstallSampleDataAsync(string defaultUserEmail) { await InstallSampleCustomersAsync(); await InstallCheckoutAttributesAsync(); await InstallSpecificationAttributesAsync(); await InstallProductAttributesAsync(); await InstallCategoriesAsync(); await InstallManufacturersAsync(); await InstallProductsAsync(defaultUserEmail); await InstallForumsAsync(); await InstallDiscountsAsync(); await InstallBlogPostsAsync(defaultUserEmail); await InstallNewsAsync(defaultUserEmail); await InstallPollsAsync(); await InstallWarehousesAsync(); await InstallVendorsAsync(); await InstallAffiliatesAsync(); await InstallOrdersAsync(); await InstallActivityLogAsync(defaultUserEmail); await InstallSearchTermsAsync(); var settingService = EngineContext.Current.Resolve(); await settingService.SaveSettingAsync(new DisplayDefaultMenuItemSettings { DisplayHomepageMenuItem = false, DisplayNewProductsMenuItem = false, DisplayProductSearchMenuItem = false, DisplayCustomerInfoMenuItem = false, DisplayBlogMenuItem = false, DisplayForumsMenuItem = false, DisplayContactUsMenuItem = false }); } #endregion } }