правки_и_создание_модуля_для_взаимодействия_с_пользователем #10

Closed
TabeevAlexander wants to merge 3 commits from правки_и_создание_модуля_для_взаимодействия_с_пользователем into main
113 changed files with 75705 additions and 44 deletions

View File

@ -9,9 +9,11 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ServiceStationDataModels",
EndProject EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ServiceStationContracts", "ServiceStationContracts\ServiceStationContracts.csproj", "{7813B987-065A-48FA-A3D0-70F02DFF21A4}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ServiceStationContracts", "ServiceStationContracts\ServiceStationContracts.csproj", "{7813B987-065A-48FA-A3D0-70F02DFF21A4}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ServiceStationDatabaseImplement", "ServiceStationDatabaseImplement\ServiceStationDatabaseImplement.csproj", "{EE5A19E3-8363-48C3-A672-0CD32F26AA31}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ServiceStationDatabaseImplement", "ServiceStationDatabaseImplement\ServiceStationDatabaseImplement.csproj", "{EE5A19E3-8363-48C3-A672-0CD32F26AA31}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ServiceStationBusinessLogic", "ServiceStationBusinessLogic\ServiceStationBusinessLogic.csproj", "{733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ServiceStationBusinessLogic", "ServiceStationBusinessLogic\ServiceStationBusinessLogic.csproj", "{733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ServiceStationGuarantorApp", "ServiceStationGuarantorApp\ServiceStationGuarantorApp.csproj", "{D10437F7-B462-42AD-80C1-5F57BFD5564F}"
EndProject EndProject
Global Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution GlobalSection(SolutionConfigurationPlatforms) = preSolution
@ -39,6 +41,10 @@ Global
{733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}.Debug|Any CPU.Build.0 = Debug|Any CPU {733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}.Debug|Any CPU.Build.0 = Debug|Any CPU
{733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}.Release|Any CPU.ActiveCfg = Release|Any CPU {733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}.Release|Any CPU.ActiveCfg = Release|Any CPU
{733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}.Release|Any CPU.Build.0 = Release|Any CPU {733FDBAC-A9F3-4B44-989B-BEB0CA6358C8}.Release|Any CPU.Build.0 = Release|Any CPU
{D10437F7-B462-42AD-80C1-5F57BFD5564F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{D10437F7-B462-42AD-80C1-5F57BFD5564F}.Debug|Any CPU.Build.0 = Debug|Any CPU
{D10437F7-B462-42AD-80C1-5F57BFD5564F}.Release|Any CPU.ActiveCfg = Release|Any CPU
{D10437F7-B462-42AD-80C1-5F57BFD5564F}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection EndGlobalSection
GlobalSection(SolutionProperties) = preSolution GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE HideSolutionNode = FALSE

View File

@ -130,16 +130,16 @@ namespace ServiceStationBusinessLogic.BusinessLogics
throw new ArgumentNullException("Нет номера телефона поручителя", nameof(model.GuarantorNumber)); throw new ArgumentNullException("Нет номера телефона поручителя", nameof(model.GuarantorNumber));
} }
_logger.LogInformation("Guarantor. GuarantorFIO:{GuarantorFIO}.GuarantorPassword:{GuarantorPassword}.GuarantorNumber:{GuarantorNumber} Id: {Id}", model.GuarantorFIO, model.GuarantorPassword, model.GuarantorEmail, model.Id); _logger.LogInformation("Guarantor. GuarantorFIO:{GuarantorFIO}.GuarantorPassword:{GuarantorPassword}.GuarantorNumber:{GuarantorNumber} Id: {Id}", model.GuarantorFIO, model.GuarantorPassword, model.GuarantorNumber, model.Id);
var element = _guarantorStorage.GetElement(new GuarantorSearchModel var element = _guarantorStorage.GetElement(new GuarantorSearchModel
{ {
GuarantorFIO = model.GuarantorFIO GuarantorNumber = model.GuarantorNumber
}); });
if (element != null && element.Id != model.Id) if (element != null && element.Id != model.Id)
{ {
throw new InvalidOperationException("Поручитель с таким ФИО уже есть"); throw new InvalidOperationException("Поручитель с таким номером уже есть");
} }
} }
} }

View File

@ -101,7 +101,7 @@ namespace ServiceStationBusinessLogic.BusinessLogics
{ {
throw new ArgumentNullException("Цена ТО должна быть больше 0", nameof(model.WorkPrice)); throw new ArgumentNullException("Цена ТО должна быть больше 0", nameof(model.WorkPrice));
} }
_logger.LogInformation("TechnicalWork. WorkType:{WorkType}. WorkPrice:{WorkPrice}. Id:{Id}", model.WorkType, model.WorkType, model.Id); _logger.LogInformation("TechnicalWork. WorkType:{WorkType}. WorkPrice:{WorkPrice}. Id:{Id}", model.WorkType, model.WorkPrice, model.Id);
var element = _technicalWorkStorage.GetElement(new TechnicalWorkSearchModel var element = _technicalWorkStorage.GetElement(new TechnicalWorkSearchModel
{ {
WorkType = model.WorkType WorkType = model.WorkType

View File

@ -18,6 +18,8 @@ namespace ServiceStationContracts.BindingModels
public int ExecutorId { get; set; } public int ExecutorId { get; set; }
public int? RepairId { get; set; }
public Dictionary<int, ICarModel> DefectCars { get; set; } = new(); public Dictionary<int, ICarModel> DefectCars { get; set; } = new();
} }
} }

View File

@ -20,7 +20,7 @@ namespace ServiceStationContracts.BindingModels
public int GuarantorId { get; set; } public int GuarantorId { get; set; }
public int TechnicalWorkId { get; set; } public int? TechnicalWorkId { get; set; }
public Dictionary<int, ISparePartModel> WorkSpareParts { get; set; } = new(); public Dictionary<int, ISparePartModel> WorkSpareParts { get; set; } = new();
} }

View File

@ -11,5 +11,6 @@ namespace ServiceStationContracts.SearchModels
public int? Id { get; set; } public int? Id { get; set; }
public string? GuarantorFIO { get; set; } public string? GuarantorFIO { get; set; }
public string? GuarantorEmail { get; set; } public string? GuarantorEmail { get; set; }
public string? GuarantorNumber { get; set; }
} }
} }

View File

@ -21,6 +21,8 @@ namespace ServiceStationContracts.ViewModels
public int ExecutorId { get; set; } public int ExecutorId { get; set; }
public int? RepairId { get; set; }
public Dictionary<int, ICarModel> DefectCars { get; set; } = new(); public Dictionary<int, ICarModel> DefectCars { get; set; } = new();
} }
} }

View File

@ -24,8 +24,8 @@ namespace ServiceStationContracts.ViewModels
public int GuarantorId { get; set; } public int GuarantorId { get; set; }
public int TechnicalWorkId { get; set; } public int? TechnicalWorkId { get; set; }
public Dictionary<int, ISparePartModel> WorkSpareParts { get; } = new(); public Dictionary<int, ISparePartModel> WorkSpareParts { get; set; } = new();
} }
} }

View File

@ -12,6 +12,7 @@ namespace ServiceStationDataModels.Models
string DefectType { get; } string DefectType { get; }
double DefectPrice { get; } double DefectPrice { get; }
int ExecutorId { get; } int ExecutorId { get; }
int? RepairId { get; }
public Dictionary<int, ICarModel> DefectCars { get; } public Dictionary<int, ICarModel> DefectCars { get; }
} }
} }

View File

@ -16,8 +16,6 @@ namespace ServiceStationDataModels.Models
int GuarantorId { get; } int GuarantorId { get; }
int DefectId { get; }
public Dictionary<int, ISparePartModel> RepairSpareParts { get; } public Dictionary<int, ISparePartModel> RepairSpareParts { get; }
} }
} }

View File

@ -16,7 +16,7 @@ namespace ServiceStationDataModels.Models
int GuarantorId { get; } int GuarantorId { get; }
int TechnicalWorkId { get; } int? TechnicalWorkId { get; }
public Dictionary<int, ISparePartModel> WorkSpareParts { get; } public Dictionary<int, ISparePartModel> WorkSpareParts { get; }
} }

View File

@ -23,7 +23,7 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.Car) .ThenInclude(x => x.Car)
.ThenInclude(x => x.CarTechnicalWorks) .ThenInclude(x => x.CarTechnicalWorks)
.ThenInclude(x => x.TechnicalWork) .ThenInclude(x => x.TechnicalWork)
.Include(x => x.Repairs) .Include(x => x.Repair)
.Include(x => x.Executor) .Include(x => x.Executor)
.Select(x => x.GetViewModel) .Select(x => x.GetViewModel)
.ToList(); .ToList();
@ -41,7 +41,7 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.Car) .ThenInclude(x => x.Car)
.ThenInclude(x => x.CarTechnicalWorks) .ThenInclude(x => x.CarTechnicalWorks)
.ThenInclude(x => x.TechnicalWork) .ThenInclude(x => x.TechnicalWork)
.Include(x => x.Repairs) .Include(x => x.Repair)
.Include(x => x.Executor) .Include(x => x.Executor)
.Where(x => x.ExecutorId == model.ExecutorId) .Where(x => x.ExecutorId == model.ExecutorId)
.ToList() .ToList()
@ -53,7 +53,7 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.Car) .ThenInclude(x => x.Car)
.ThenInclude(x => x.CarTechnicalWorks) .ThenInclude(x => x.CarTechnicalWorks)
.ThenInclude(x => x.TechnicalWork) .ThenInclude(x => x.TechnicalWork)
.Include(x => x.Repairs) .Include(x => x.Repair)
.Include(x => x.Executor) .Include(x => x.Executor)
.Where(x => x.DefectType == model.DefectType) .Where(x => x.DefectType == model.DefectType)
.ToList() .ToList()
@ -72,7 +72,7 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.Car) .ThenInclude(x => x.Car)
.ThenInclude(x => x.CarTechnicalWorks) .ThenInclude(x => x.CarTechnicalWorks)
.ThenInclude(x => x.TechnicalWork) .ThenInclude(x => x.TechnicalWork)
.Include(x => x.Repairs) .Include(x => x.Repair)
.Include(x => x.Executor) .Include(x => x.Executor)
.FirstOrDefault(x => (!string.IsNullOrEmpty(model.DefectType) && x.DefectType == model.DefectType) || (model.Id.HasValue && x.Id == model.Id))? .FirstOrDefault(x => (!string.IsNullOrEmpty(model.DefectType) && x.DefectType == model.DefectType) || (model.Id.HasValue && x.Id == model.Id))?
.GetViewModel; .GetViewModel;

View File

@ -22,7 +22,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartWorks) .ThenInclude(x => x.SparePartWorks)
.ThenInclude(x => x.Work) .ThenInclude(x => x.Work)
//.Include(x => x.Defect)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.Select(x => x.GetViewModel) .Select(x => x.GetViewModel)
.ToList(); .ToList();
@ -40,7 +39,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartWorks) .ThenInclude(x => x.SparePartWorks)
.ThenInclude(x => x.Work) .ThenInclude(x => x.Work)
//.Include(x => x.Defect)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.Where(x => x.GuarantorId == model.GuarantorId) .Where(x => x.GuarantorId == model.GuarantorId)
.ToList() .ToList()
@ -52,7 +50,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartWorks) .ThenInclude(x => x.SparePartWorks)
.ThenInclude(x => x.Work) .ThenInclude(x => x.Work)
//.Include(x => x.Defect)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.Where(x => x.RepairName == model.RepairName) .Where(x => x.RepairName == model.RepairName)
.ToList() .ToList()
@ -71,7 +68,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartWorks) .ThenInclude(x => x.SparePartWorks)
.ThenInclude(x => x.Work) .ThenInclude(x => x.Work)
//.Include(x => x.Defect)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.FirstOrDefault(x => (!string.IsNullOrEmpty(model.RepairName) && x.RepairName == model.RepairName) || (model.Id.HasValue && x.Id == model.Id))? .FirstOrDefault(x => (!string.IsNullOrEmpty(model.RepairName) && x.RepairName == model.RepairName) || (model.Id.HasValue && x.Id == model.Id))?
.GetViewModel; .GetViewModel;

View File

@ -22,7 +22,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartRepairs) .ThenInclude(x => x.SparePartRepairs)
.ThenInclude(x => x.Repair) .ThenInclude(x => x.Repair)
//.Include(x => x.TechnicalWork)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.ToList() .ToList()
.Select(x => x.GetViewModel) .Select(x => x.GetViewModel)
@ -44,7 +43,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartRepairs) .ThenInclude(x => x.SparePartRepairs)
.ThenInclude(x => x.Repair) .ThenInclude(x => x.Repair)
//.Include(x => x.TechnicalWork)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.Where(x => x.GuarantorId == model.GuarantorId) .Where(x => x.GuarantorId == model.GuarantorId)
.Select(x => x.GetViewModel) .Select(x => x.GetViewModel)
@ -57,7 +55,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartRepairs) .ThenInclude(x => x.SparePartRepairs)
.ThenInclude(x => x.Repair) .ThenInclude(x => x.Repair)
//.Include(x => x.TechnicalWork)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.Where(x => x.GuarantorId == model.GuarantorId) .Where(x => x.GuarantorId == model.GuarantorId)
.ToList() .ToList()
@ -69,7 +66,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartRepairs) .ThenInclude(x => x.SparePartRepairs)
.ThenInclude(x => x.Repair) .ThenInclude(x => x.Repair)
//.Include(x => x.TechnicalWork)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.Where(x => x.WorkName.Contains(model.WorkName)) .Where(x => x.WorkName.Contains(model.WorkName))
.ToList() .ToList()
@ -87,7 +83,6 @@ namespace ServiceStationDatabaseImplement.Implements
.ThenInclude(x => x.SparePart) .ThenInclude(x => x.SparePart)
.ThenInclude(x => x.SparePartRepairs) .ThenInclude(x => x.SparePartRepairs)
.ThenInclude(x => x.Repair) .ThenInclude(x => x.Repair)
//.Include(x => x.TechnicalWork)
.Include(x => x.Guarantor) .Include(x => x.Guarantor)
.FirstOrDefault(x => (!string.IsNullOrEmpty(model.WorkName) && x.WorkName == model.WorkName) || (model.Id.HasValue && x.Id == model.Id))? .FirstOrDefault(x => (!string.IsNullOrEmpty(model.WorkName) && x.WorkName == model.WorkName) || (model.Id.HasValue && x.Id == model.Id))?
.GetViewModel; .GetViewModel;

View File

@ -25,7 +25,10 @@ namespace ServiceStationDatabaseImplement.Models
[Required] [Required]
public int ExecutorId { get; set; } public int ExecutorId { get; set; }
public int? RepairId { get; set; }
public virtual Executor Executor { get; set; } public virtual Executor Executor { get; set; }
public virtual Repair? Repair { get; set; }
private Dictionary<int, ICarModel>? _defectCars = null; private Dictionary<int, ICarModel>? _defectCars = null;
@ -43,8 +46,6 @@ namespace ServiceStationDatabaseImplement.Models
} }
[ForeignKey("DefectId")] [ForeignKey("DefectId")]
public virtual List<CarDefect> Cars { get; set; } = new(); public virtual List<CarDefect> Cars { get; set; } = new();
[ForeignKey("DefectId")]
public virtual List<Repair> Repairs { get; set; } = new();
public static Defect? Create(ServiceStationDatabase context, DefectBindingModel model) public static Defect? Create(ServiceStationDatabase context, DefectBindingModel model)
{ {
@ -65,6 +66,11 @@ namespace ServiceStationDatabaseImplement.Models
public void Update(DefectBindingModel model) public void Update(DefectBindingModel model)
{ {
if(model == null) return; if(model == null) return;
if (model.RepairId.HasValue)
{
RepairId = model.RepairId;
return;
}
DefectType = model.DefectType; DefectType = model.DefectType;
DefectPrice = model.DefectPrice; DefectPrice = model.DefectPrice;
} }

View File

@ -28,15 +28,14 @@ namespace ServiceStationDatabaseImplement.Models
[Required] [Required]
public int GuarantorId { get; set; } public int GuarantorId { get; set; }
[Required] [ForeignKey("RepairId")]
public int DefectId { get; set; } public virtual List<Defect> Defects { get; set; } = new();
public virtual Guarantor Guarantor { get; set; } public virtual Guarantor Guarantor { get; set; }
//public virtual Defect Defect { get; set; }
private Dictionary<int, ISparePartModel>? _repairSpareParts = null; private Dictionary<int, ISparePartModel>? _repairSpareParts = null;
[NotMapped]
public Dictionary<int, ISparePartModel> RepairSpareParts public Dictionary<int, ISparePartModel> RepairSpareParts
{ {
get get
@ -52,9 +51,6 @@ namespace ServiceStationDatabaseImplement.Models
[ForeignKey("RepairId")] [ForeignKey("RepairId")]
public virtual List<SparePartRepair> SpareParts { get; set; } = new(); public virtual List<SparePartRepair> SpareParts { get; set; } = new();
//[ForeignKey("RepairId")]
//public virtual List<Defect> Defects { get; set; } = new();
public static Repair? Create(ServiceStationDatabase context, RepairBindingModel model) public static Repair? Create(ServiceStationDatabase context, RepairBindingModel model)
{ {
if (model == null) return null; if (model == null) return null;
@ -65,7 +61,6 @@ namespace ServiceStationDatabaseImplement.Models
Status = model.Status, Status = model.Status,
RepairPrice = model.RepairPrice, RepairPrice = model.RepairPrice,
GuarantorId = model.GuarantorId, GuarantorId = model.GuarantorId,
DefectId = model.DefectId,
SpareParts = model.RepairSpareParts.Select(x => new SparePartRepair SpareParts = model.RepairSpareParts.Select(x => new SparePartRepair
{ {
SparePart = context.SpareParts.First(y => y.Id == x.Key) SparePart = context.SpareParts.First(y => y.Id == x.Key)
@ -88,7 +83,6 @@ namespace ServiceStationDatabaseImplement.Models
Status = Status, Status = Status,
RepairPrice = RepairPrice, RepairPrice = RepairPrice,
GuarantorId = GuarantorId, GuarantorId = GuarantorId,
DefectId = DefectId,
RepairSpareParts = RepairSpareParts RepairSpareParts = RepairSpareParts
}; };

View File

@ -26,7 +26,6 @@ namespace ServiceStationDatabaseImplement.Models
[Required] [Required]
public int ExecutorId { get; set; } public int ExecutorId { get; set; }
public virtual Executor Executor { get; set; } public virtual Executor Executor { get; set; }
public virtual Work Work { get; set; }
private Dictionary<int, ICarModel>? _technicalWorkCars = null; private Dictionary<int, ICarModel>? _technicalWorkCars = null;
public Dictionary<int, ICarModel> TechnicalWorkCars public Dictionary<int, ICarModel> TechnicalWorkCars
@ -43,6 +42,9 @@ namespace ServiceStationDatabaseImplement.Models
[ForeignKey("TechnicalWorkId")] [ForeignKey("TechnicalWorkId")]
public virtual List<CarTechnicalWork> Cars { get; set; } = new(); public virtual List<CarTechnicalWork> Cars { get; set; } = new();
[ForeignKey("TechnicalWorkId")]
public virtual List<Work> Works { get; set; } = new();
public static TechnicalWork? Create(ServiceStationDatabase context, TechnicalWorkBindingModel model) public static TechnicalWork? Create(ServiceStationDatabase context, TechnicalWorkBindingModel model)
{ {
if (model == null) return null; if (model == null) return null;
@ -73,6 +75,7 @@ namespace ServiceStationDatabaseImplement.Models
WorkType = WorkType, WorkType = WorkType,
DateStartWork = DateStartWork, DateStartWork = DateStartWork,
WorkPrice = WorkPrice, WorkPrice = WorkPrice,
TechnicalWorkCars = TechnicalWorkCars,
ExecutorId = ExecutorId ExecutorId = ExecutorId
}; };

View File

@ -28,13 +28,12 @@ namespace ServiceStationDatabaseImplement.Models
[Required] [Required]
public int GuarantorId { get; set; } public int GuarantorId { get; set; }
[Required] public int? TechnicalWorkId { get; set; }
public int TechnicalWorkId { get; set; }
public virtual TechnicalWork? TechnicalWork { get; set; }
public virtual Guarantor Guarantor { get; set; } public virtual Guarantor Guarantor { get; set; }
//public virtual TechnicalWork TechnicalWork { get; set; }
private Dictionary<int, ISparePartModel>? _workSpareParts = null; private Dictionary<int, ISparePartModel>? _workSpareParts = null;
public Dictionary<int, ISparePartModel> WorkSpareParts public Dictionary<int, ISparePartModel> WorkSpareParts
@ -52,9 +51,6 @@ namespace ServiceStationDatabaseImplement.Models
[ForeignKey("WorkId")] [ForeignKey("WorkId")]
public virtual List<SparePartWork> SpareParts { get; set; } = new(); public virtual List<SparePartWork> SpareParts { get; set; } = new();
[ForeignKey("WorkId")]
public virtual List<TechnicalWork> TechnicalWorks { get; set; } = new();
public static Work? Create(ServiceStationDatabase context, WorkBindingModel model) public static Work? Create(ServiceStationDatabase context, WorkBindingModel model)
{ {
if (model == null) return null; if (model == null) return null;
@ -75,6 +71,12 @@ namespace ServiceStationDatabaseImplement.Models
public void Update(WorkBindingModel model) public void Update(WorkBindingModel model)
{ {
if (model == null) return;
if (model.TechnicalWorkId.HasValue)
{
TechnicalWorkId = model.TechnicalWorkId;
return;
}
WorkName = model.WorkName; WorkName = model.WorkName;
Status = model.Status; Status = model.Status;
WorkPrice = model.WorkPrice; WorkPrice = model.WorkPrice;
@ -88,6 +90,7 @@ namespace ServiceStationDatabaseImplement.Models
Status = Status, Status = Status,
WorkPrice = WorkPrice, WorkPrice = WorkPrice,
GuarantorId = GuarantorId, GuarantorId = GuarantorId,
WorkSpareParts = WorkSpareParts,
TechnicalWorkId = TechnicalWorkId TechnicalWorkId = TechnicalWorkId
}; };

View File

@ -0,0 +1,49 @@
using Newtonsoft.Json;
using ServiceStationContracts.ViewModels;
using System.Net.Http.Headers;
using System.Text;
namespace ServiceStationGuarantorApp
{
public class APIGuarantor
{
private static readonly HttpClient _guarantor = new();
public static GuarantorViewModel? Guarantor { get; set; } = null;
public static void Connect(IConfiguration configuration)
{
_guarantor.BaseAddress = new Uri(configuration["IPAddress"]);
_guarantor.DefaultRequestHeaders.Accept.Clear();
_guarantor.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
}
public static T? GetRequest<T>(string requestUrl)
{
var response = _guarantor.GetAsync(requestUrl);
var result = response.Result.Content.ReadAsStringAsync().Result;
if (response.Result.IsSuccessStatusCode)
{
return JsonConvert.DeserializeObject<T>(result);
}
else
{
throw new Exception(result);
}
}
public static void PostRequest<T>(string requestUrl, T model)
{
var json = JsonConvert.SerializeObject(model);
var data = new StringContent(json, Encoding.UTF8, "application/json");
var response = _guarantor.PostAsync(requestUrl, data);
var result = response.Result.Content.ReadAsStringAsync().Result;
if (!response.Result.IsSuccessStatusCode)
{
throw new Exception(result);
}
}
}
}

View File

@ -0,0 +1,179 @@
using Microsoft.AspNetCore.Mvc;
using ServiceStationContracts.BindingModels;
using ServiceStationGuarantorApp.Models;
using System.Diagnostics;
namespace ServiceStationGuarantorApp.Controllers
{
public class HomeController : Controller
{
private readonly ILogger<HomeController> _logger;
public HomeController(ILogger<HomeController> logger)
{
_logger = logger;
}
public IActionResult Index()
{
return View();
}
[HttpGet]
public IActionResult Privacy()
{
//if (APIGuarantor.Guarantor == null)
//{
// return Redirect("~/Home/Enter");
//}
return View();
}
//[HttpPost]
//public void Privacy(string number, string email, string FIO, string password)
//{
// if (APIGuarantor.Guarantor == null)
// {
// throw new Exception("Вы как сюда попали? Сюда вход только авторизованным");
// }
// if (string.IsNullOrEmpty(number) || string.IsNullOrEmpty(FIO) || string.IsNullOrEmpty(password))
// {
// throw new Exception("Введите номер, ФИО и пароль");
// }
// APIGuarantor.PostRequest("api/guarantor/updatedata", new GuarantorBindingModel
// {
// Id = APIGuarantor.Guarantor.Id,
// GuarantorNumber = number,
// GuarantorEmail = email,
// GuarantorFIO = FIO,
// GuarantorPassword = password,
// });
// APIGuarantor.Guarantor.GuarantorNumber = number;
// APIGuarantor.Guarantor.GuarantorEmail = email;
// APIGuarantor.Guarantor.GuarantorFIO = FIO;
// APIGuarantor.Guarantor.GuarantorPassword = password;
// Response.Redirect("Index");
//}
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult Error()
{
return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
}
[HttpGet]
public IActionResult Enter()
{
return View();
}
[HttpGet]
public IActionResult Register()
{
return View();
}
[HttpGet]
public IActionResult ListDefectSparePartToFile()
{
return View();
}
[HttpGet]
public IActionResult ListSparePartsToPdfFile()
{
return View();
}
[HttpGet]
public IActionResult ListSpareParts()
{
return View();
}
[HttpGet]
public IActionResult ListRepairs()
{
return View();
}
[HttpGet]
public IActionResult ListWorks()
{
return View();
}
[HttpGet]
public IActionResult CreateSparePart()
{
return View();
}
[HttpGet]
public IActionResult UpdateSparePart()
{
return View();
}
[HttpGet]
public IActionResult DeleteSparePart()
{
return View();
}
[HttpGet]
public IActionResult CreateRepair()
{
return View();
}
[HttpGet]
public IActionResult UpdateRepair() {
return View();
}
[HttpGet]
public IActionResult DeleteRepair()
{
return View();
}
[HttpGet]
public IActionResult AddSparepartToRepair()
{
return View();
}
[HttpGet]
public IActionResult CreateWork()
{
return View();
}
[HttpGet]
public IActionResult UpdateWork()
{
return View();
}
[HttpGet]
public IActionResult DeleteWork()
{
return View();
}
[HttpGet]
public IActionResult AddSparepartToWork()
{
return View();
}
[HttpGet]
public IActionResult BindingRepairToDefects()
{
return View();
}
}
}

View File

@ -0,0 +1,9 @@
namespace ServiceStationGuarantorApp.Models
{
public class ErrorViewModel
{
public string? RequestId { get; set; }
public bool ShowRequestId => !string.IsNullOrEmpty(RequestId);
}
}

View File

@ -0,0 +1,30 @@
using ServiceStationGuarantorApp;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllersWithViews();
var app = builder.Build();
APIGuarantor.Connect(builder.Configuration);
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Home/Error");
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}");
app.Run();

View File

@ -0,0 +1,28 @@
{
"iisSettings": {
"windowsAuthentication": false,
"anonymousAuthentication": true,
"iisExpress": {
"applicationUrl": "http://localhost:57829",
"sslPort": 44384
}
},
"profiles": {
"ServiceStationGuarantorApp": {
"commandName": "Project",
"dotnetRunMessages": true,
"launchBrowser": true,
"applicationUrl": "https://localhost:7052;http://localhost:5244",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}

View File

@ -0,0 +1,17 @@
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<Nullable>enable</Nullable>
<ImplicitUsings>enable</ImplicitUsings>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Newtonsoft.Json" Version="13.0.3" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\ServiceStationContracts\ServiceStationContracts.csproj" />
</ItemGroup>
</Project>

View File

@ -0,0 +1,42 @@
@using ServiceStationContracts.ViewModels;
@using ServiceStationDataModels.Models;
@{
ViewData["Title"] = "AddSparepartToRepair";
}
@model Tuple<List<RepairViewModel>, List<SparePartViewModel>>
<div class="container">
<h2>Добавление запчастей к ремонтам:</h2>
<form method="post">
<div class="form-group">
<label for="repair">Выберите ремонт</label>
<select id="repair" name="repair" class="form-control">
@* тут будет код *@
</select>
</div>
<div class="form-group">
<label for="sparepart">Выберите запчасть</label>
<table class="table mb-0">
<thead>
<tr>
<th scope="col"></th>
<th scope="col">Название запчасти</th>
<th scope="col">Стоимость запчасти</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Добавить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</form>
</div>

View File

@ -0,0 +1,42 @@
@using ServiceStationContracts.ViewModels;
@using ServiceStationDataModels.Models;
@{
ViewData["Title"] = "AddSparepartToWork";
}
@model Tuple<List<WorkViewModel>, List<SparePartViewModel>>
<div class="container">
<h2>Добавление запчастей к работам:</h2>
<form method="post">
<div class="form-group">
<label for="work">Выберите работу</label>
<select id="work" name="work" class="form-control">
@* тут будет код *@
</select>
</div>
<div class="form-group">
<label for="sparepart">Выберите запчасть</label>
<table class="table mb-0">
<thead>
<tr>
<th scope="col"></th>
<th scope="col">Название запчасти</th>
<th scope="col">Стоимость запчасти</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Добавить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</form>
</div>

View File

@ -0,0 +1,32 @@
@using ServiceStationContracts.ViewModels;
@using ServiceStationDataModels.Models;
@{
ViewData["Title"] = "BindingRepairToDefects";
}
@model Tuple<List<RepairViewModel>, List<DefectViewModel>>
<div class="container w-50">
<form method="post">
<div class="form-group">
<label for="repair">Выберите ремонт</label>
<select id="repair" name="repair" class="form-control">
@* тут будет код *@
</select>
</div>
<div class="form-group">
<label for="defect">Выберите неисправность</label>
<select id="defect" name="defect" class="form-control">
@* тут будет код *@
</select>
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Добавить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</form>
</div>

View File

@ -0,0 +1,24 @@

@{
ViewData["Title"] = "CreateRepair";
}
<form method="post">
<div class="w-25 container justify-content-center align-items-center">
<div class="form-group py-2">
<label>Название ремонта</label>
<input type="text" id="repairName" placeholder="Введите название ремонта" name="repairName" class="form-control" />
</div>
<div class="form-group py-2">
<label>Стоимость ремонта</label>
<input type="number" min="100" step="100" id="repairPrice" placeholder="Введите стоимость ремонта" name="repairPrice" class="form-control" />
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Сохранить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</form>

View File

@ -0,0 +1,24 @@

@{
ViewData["Title"] = "CreateSparePart";
}
<form method="post">
<div class="w-25 container justify-content-center align-items-center">
<div class="form-group py-2">
<label>Название запчасти</label>
<input type="text" id="sparepartName" placeholder="Введите название запчасти" name="sparepartName" class="form-control" />
</div>
<div class="form-group py-2">
<label>Стоимость запчасти</label>
<input type="text" id="sparepartPrice" placeholder="Введите стоимость запчасти" name="sparepartPrice" class="form-control" step="1" />
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Сохранить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</form>

View File

@ -0,0 +1,24 @@

@{
ViewData["Title"] = "CreateWork";
}
<form method="post">
<div class="w-25 container justify-content-center align-items-center">
<div class="form-group py-2">
<label>Название работы</label>
<input type="text" id="workName" placeholder="Введите название работы" name="workName" class="form-control" />
</div>
<div class="form-group py-2">
<label>Стоимость работы</label>
<input type="number" min="100" step="100" id="workPrice" placeholder="Введите стоимость работы" name="workPrice" class="form-control" />
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Сохранить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</form>

View File

@ -0,0 +1,22 @@

@{
ViewData["Title"] = "DeleteRepair";
}
<form method="post">
<div class="container d-flex justify-content-center align-items-center w-25">
<div class="card-body">
<div class="form-group">
<label> Ремонт: </label>
<select id="repair" name="repair" class="form-control"></select>
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Удалить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,22 @@

@{
ViewData["Title"] = "DeleteSparePart";
}
<form method="post">
<div class="container d-flex justify-content-center align-items-center0 w-25">
<div class="card-body">
<div class="form-group">
<label>Запчасти: </label>
<select id="sparepart" name="sparepart" class="form-control"></select>
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Удалить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,21 @@
@{
ViewData["Title"] = "DeleteWork";
}
<form method="post">
<div class="container d-flex justify-content-center align-items-center w-25">
<div class="card-body">
<div class="form-group">
<label> Работа: </label>
<select id="work" name="work" class="form-control"></select>
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Удалить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,27 @@
@{
ViewData["Title"] = "Enter";
}
<div class="text-center">
<h2 class="display-4">Вход в приложение</h2>
</div>
<form method="post">
<div class="container d-flex justify-content-center align-items-center">
<div class="card-body">
<div class="form-group pb-3">
<label>Номер телефона</label>
<input type="text" name="number" class="form-control" placeholder="Введите свой номер телефона"/>
</div>
<div class="form-group pb-3">
<label>Пароль</label>
<input type="password" name="password" class="form-control" placeholder="Введите свой пароль"/>
</div>
<div class="form-group d-flex justify-content-center">
<button type="submit" class="btn btn-outline-dark">Войти</button>
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,8 @@
@{
ViewData["Title"] = "Home Page";
}
<div class="text-center">
<h1 class="display-4">Welcome</h1>
<p>Learn about <a href="https://docs.microsoft.com/aspnet/core">building Web apps with ASP.NET Core</a>.</p>
</div>

View File

@ -0,0 +1,40 @@
@using ServiceStationContracts.ViewModels
@model List<SparePartViewModel>
@{
ViewData["Title"] = "ListDefectSparePartToFile";
}
<div class="text-center">
<h2 class="display-4">Создание отчёта по запчастям</h2>
</div>
<div class="text-start">
<form method="post">
<label class="form-label fs-4">Выберите формат файла:</label>
<div class="form-check d-flex">
<input class="form-check-input my-auto" type="radio" name="type" value="docx" id="docx">
<label class="form-check-label fs-5 ps-2" for="docx">Word-файл</label>
</div>
<div class="form-check d-flex">
<input class="form-check-input my-auto" type="radio" name="type" value="xlsx" id="xlsx" checked>
<label class="form-check-label fs-5 ps-2" for="xlsx">Excel-файл</label>
</div>
<table class="table table-hover">
<thead class="thead-light">
<tr>
<th scope="col"></th>
<th scope="col" class="fs-5">Название запчасти</th>
<th scope="col" class="fs-5">Цена</th>
</tr>
</thead>
</table>
<div class="d-flex justify-content-center">
<button type="submit" class="btn btn-block btn-outline-dark w-100">Создать</button>
</div>
</form>
</div>

View File

@ -0,0 +1,46 @@
@using ServiceStationContracts.ViewModels
@model List<RepairViewModel>
@{
ViewData["Title"] = "ListRepairs";
}
<section>
<h2>Список ремонтов:</h2>
<table class="table">
<thead class="thead-dark">
<tr style="height: 31px">
<th>
Название ремонта
</th>
<th>
Статус ремонта
</th>
<th>
Стоимость ремонта
</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
<div class="flex-column justify-content-md-center">
<div class="text-center">
<a asp-controller="Home" asp-action="CreateRepair" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Добавить</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="UpdateRepair" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Изменить</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="AddSparepartToRepair" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Добавить запчасть</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="DeleteRepair" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Удалить</a>
</div>
</div>
</section>

View File

@ -0,0 +1,37 @@
@using ServiceStationContracts.ViewModels
@{
ViewData["Title"] = "ListSpareParts";
}
<section>
<h2>Список запчастей:</h2>
<table class="table">
<thead class="thead-dark">
<tr style="height: 31px">
<th>
Название
</th>
<th>
Стоимость
</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
<div class="flex-column justify-content-md-center">
<div class="text-center">
<a asp-controller="Home" asp-action="CreateSparePart" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Добавить</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="UpdateSparePart" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Изменить</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="DeleteSparePart" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Удалить</a>
</div>
</div>
</section>

View File

@ -0,0 +1,47 @@
@using ServiceStationContracts.ViewModels
@{
ViewData["Title"] = "ListSparePartsToPdfFile";
}
<div class="text-center">
<h2 class="display-4">Отчёт по запчастям за период</h2>
</div>
<form method="post">
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label for="dateFrom" class="form-label text-custom-color-1">Начало периода:</label>
<input type="datetime-local" id="dateFrom" name="dateFrom" class="form-control" placeholder="Выберите дату начала периода">
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label for="dateTo" class="form-label text-custom-color-1">Окончание периода:</label>
<input type="datetime-local" id="dateTo" name="dateTo" class="form-control" placeholder="Выберите дату окончания периода">
</div>
</div>
</div>
<div class="form-group mb-4">
<label for="guarantorEmail" class="form-label text-custom-color-1">Введите почту:</label>
<input type="email" id="guarantorEmail" name="guarantorEmail" class="form-control" placeholder="Введите вашу почту">
</div>
<div class="row mb-4">
<div class="col-md-8"></div>
<div class="col-md-4">
<button type="submit" class="btn btn-outline-dark w-100 text-center d-flex justify-content-md-center">Отправить на почту</button>
</div>
</div>
<div class="row mb-4">
<div class="col-md-8"></div>
<div class="col-md-4">
<button type="button" id="demonstrate" class="btn btn-outline-dark w-100 text-center d-flex justify-content-md-center">Предварительный просмотр</button>
</div>
</div>
<div id="report"></div>
</form>

View File

@ -0,0 +1,43 @@

@{
ViewData["Title"] = "ListWorks";
}
<section>
<h2>Список работ:</h2>
<table class="table">
<thead class="thead-dark">
<tr style="height: 31px">
<th>
Название работы
</th>
<th>
Статус работы
</th>
<th>
Стоимость работы
</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
<div class="flex-column justify-content-md-center">
<div class="text-center">
<a asp-controller="Home" asp-action="CreateWork" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Добавить</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="UpdateWork" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Изменить</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="AddSparepartToWork" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Добавить запчасть</a>
</div>
&nbsp;
<div class="text-center">
<a asp-controller="Home" asp-action="DeleteWork" class="btn btn-outline-dark text-center d-flex justify-content-md-center">Удалить</a>
</div>
</div>
</section>

View File

@ -0,0 +1,39 @@
@using ServiceStationContracts.ViewModels
@model GuarantorViewModel
@{
ViewData["Title"] = "Privacy";
}
<div class="text-center">
<h2 class="display-4">Ваши данные</h2>
</div>
<form method="post">
<div class="container d-flex justify-content-center align-items-center">
<div class="card-body">
<div class="form-group pb-3">
<label>Номер телефона</label>
<input type="text" name="number" class="form-control" placeholder="Введите номер телефона" />
</div>
<div class="form-group pb-3">
<label>Электронная почта</label>
<input type="text" name="email" class="form-control" placeholder="Введите электронную почту" />
</div>
<div class="form-group pb-3">
<label>ФИО</label>
<input type="text" name="FIO" class="form-control" placeholder="Введите ФИО" />
</div>
<div class="form-group pb-3">
<label>Пароль</label>
<input type="text" name="password" class="form-control" placeholder="Введите пароль" />
</div>
<div class="form-group d-flex justify-content-center">
<input type="submit" value="Сохранить" class="btn btn-outline-dark" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,38 @@
@{
ViewData["Title"] = "Register";
}
<div class="text-center">
<h2 class="display-4">Регистрация</h2>
</div>
<form method="post">
<div class="container d-flex justify-content-center align-items-center">
<div class="card-body">
<div class="form-group pb-3">
<label>Номер телефона</label>
<input type="text" name="number" class="form-control" placeholder="Введите номер телефона" />
</div>
<div class="form-group pb-3">
<label>Электронная почта</label>
<input type="text" name="email" class="form-control" placeholder="Введите электронную почту" />
</div>
<div class="form-group pb-3">
<label>ФИО</label>
<input type="text" name="FIO" class="form-control" placeholder="Введите ФИО" />
</div>
<div class="form-group pb-3">
<label>Пароль</label>
<input type="text" name="password" class="form-control" placeholder="Введите пароль" />
</div>
<div class="form-group d-flex justify-content-center">
<button type="submit" class="btn btn-outline-dark">Зарегистрироваться</button>
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,41 @@

@{
ViewData["Title"] = "UpdateRepair";
}
<form method="post">
<div class="container d-flex justify-content-center align-items-center w-50">
<div class="card-body ">
<div class="form-group">
<label>Ремонт: </label>
<select id="repair" name="repair" class="form-control"></select>
</div>
<div class="form-group">
<label>Название ремонта</label>
<input type="text" id="repairName" placeholder="Введите название ремонта" name="repairName" class="form-control" />
</div>
<div class="form-group">
<label>Стоимость ремонта</label>
<input type="number" min="100" step="100" id="repairPrice" placeholder="Введите стоимость ремонта" name="repairPrice" class="form-control" />
</div>
<table class="table">
<thead>
<tr>
<th scope="col">Название запчасти</th>
<th scope="col">Стоимость запчасти</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
<br>
<div class="text-center pb-3">
<input type="submit" value="Сохранить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,30 @@

@{
ViewData["Title"] = "UpdateSparePart";
}
<form method="post">
<div class="container d-flex justify-content-center align-items-center w-25">
<div class="card-body ">
<div class="form-group">
<label>Запчасти: </label>
<select id="sparepart" name="sparepart" class="form-control"></select>
</div>
<div class="form-group">
<label>Название запчасти</label>
<input type="text" id="sparepartName" placeholder="Введите название запчасти" name="sparepartName" class="form-control" />
</div>
<div class="form-group">
<label>Стоимость запчасти</label>
<input type="text" id="sparepartPrice" placeholder="Введите стоимость запчасти" name="sparepartPriced" class="form-control" step="1" />
</div>
<br>
<div class="text-center pb-3">
<input type="submit" value="Сохранить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,42 @@

@{
ViewData["Title"] = "UpdateWork";
}
<form method="post">
<div class="container d-flex justify-content-center align-items-center w-50">
<div class="card-body ">
<div class="form-group">
<label>Работа: </label>
<select id="work" name="work" class="form-control"></select>
</div>
<div class="form-group">
<label>Название работы</label>
<input type="text" id="workName" placeholder="Введите название работы" name="workName" class="form-control" />
</div>
<div class="form-group">
<label>Стоимость работы</label>
<input type="number" min="100" step="100" id="workPrice" placeholder="Введите стоимость работы" name="workPrice" class="form-control" />
</div>
<table class="table">
<thead>
<tr>
<th scope="col">Название запчасти</th>
<th scope="col">Стоимость запчасти</th>
</tr>
</thead>
<tbody>
@* тут будет код *@
</tbody>
</table>
<br>
<div class="text-center pb-3">
<input type="submit" value="Сохранить" class="btn btn-outline-dark text-center w-100" />
</div>
<div class="text-center">
<input type="submit" value="Назад" class="btn btn-outline-dark text-center w-100" />
</div>
</div>
</div>
</form>

View File

@ -0,0 +1,25 @@
@model ErrorViewModel
@{
ViewData["Title"] = "Error";
}
<h1 class="text-danger">Error.</h1>
<h2 class="text-danger">An error occurred while processing your request.</h2>
@if (Model.ShowRequestId)
{
<p>
<strong>Request ID:</strong> <code>@Model.RequestId</code>
</p>
}
<h3>Development Mode</h3>
<p>
Swapping to <strong>Development</strong> environment will display more detailed information about the error that occurred.
</p>
<p>
<strong>The Development environment shouldn't be enabled for deployed applications.</strong>
It can result in displaying sensitive information from exceptions to end users.
For local debugging, enable the <strong>Development</strong> environment by setting the <strong>ASPNETCORE_ENVIRONMENT</strong> environment variable to <strong>Development</strong>
and restarting the app.
</p>

View File

@ -0,0 +1,76 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>@ViewData["Title"] - ServiceStationGuarantorApp</title>
<link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.min.css" />
<link rel="stylesheet" href="~/css/site.css" asp-append-version="true" />
<link rel="stylesheet" href="~/ServiceStationGuarantorApp.styles.css" asp-append-version="true" />
</head>
<body>
<header>
<nav class="navbar navbar-expand-sm navbar-toggleable-sm navbar-light bg-white border-bottom box-shadow mb-3">
<div class="container">
<a class="navbar-brand" asp-area="" asp-controller="Home" asp-action="Index">СТО "Руки-Крюки"</a>
<button class="navbar-toggler" type="button" datatoggle="collapse" data-target=".navbar-collapse" ariacontrols="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="navbar-collapse collapse d-sm-inline-flex flex-smrow-reverse">
<ul class="navbar-nav flex-grow-1">
<li class="nav-item">
<a class="nav-link text-dark" asparea="" asp-controller="Home" asp-action="Index">Главная</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle text-dark" href="#" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Отчёты
</a>
<ul class="dropdown-menu">
<li><a class="dropdown-item text-dark" asp-area="" asp-controller="Home" asp-action="ListDefectSparePartToFile">Отчёт (Word/Excel)</a></li>
<li><a class="dropdown-item text-dark" asp-area="" asp-controller="Home" asp-action="ListSparePartsToPdfFile">Отчёт (Pdf)</a></li>
</ul>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle text-dark" href="#" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Справочники
</a>
<ul class="dropdown-menu">
<li><a class="dropdown-item text-dark" asp-area="" asp-controller="Home" asp-action="ListSpareParts">Запчасти</a></li>
<li><a class="dropdown-item text-dark" asp-area="" asp-controller="Home" asp-action="ListRepairs">Ремонты</a></li>
<li><a class="dropdown-item text-dark" asp-area="" asp-controller="Home" asp-action="ListWorks">Работы</a></li>
</ul>
</li>
<li class="nav-item">
<a class="nav-link text-dark" asparea="" asp-controller="Home" asp-action="BindingRepairToDefects">Привязка к неисправностям</a>
</li>
<li class="nav-item">
<a class="nav-link text-dark" asparea="" asp-controller="Home" asp-action="Privacy">Личные данные</a>
</li>
<li class="nav-item">
<a class="nav-link text-dark" asparea="" asp-controller="Home" asp-action="Enter">Вход</a>
</li>
<li class="nav-item">
<a class="nav-link text-dark" asparea="" asp-controller="Home" asp-action="Register">Регистрация</a>
</li>
</ul>
</div>
</div>
</nav>
</header>
<div class="container">
<main role="main" class="pb-3">
@RenderBody()
</main>
</div>
<footer class="border-top footer text-muted">
<div class="container">
&copy; 2024 - ServiceStationGuarantorApp - <a asp-area="" asp-controller="Home" asp-action="Privacy">Личнные данные</a>
</div>
</footer>
<script src="~/lib/jquery/dist/jquery.min.js"></script>
<script src="~/lib/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
<script src="~/js/site.js" asp-append-version="true"></script>
@await RenderSectionAsync("Scripts", required: false)
</body>
</html>

View File

@ -0,0 +1,48 @@
/* Please see documentation at https://docs.microsoft.com/aspnet/core/client-side/bundling-and-minification
for details on configuring this project to bundle and minify static web assets. */
a.navbar-brand {
white-space: normal;
text-align: center;
word-break: break-all;
}
a {
color: #0077cc;
}
.btn-primary {
color: #fff;
background-color: #1b6ec2;
border-color: #1861ac;
}
.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
color: #fff;
background-color: #1b6ec2;
border-color: #1861ac;
}
.border-top {
border-top: 1px solid #e5e5e5;
}
.border-bottom {
border-bottom: 1px solid #e5e5e5;
}
.box-shadow {
box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .05);
}
button.accept-policy {
font-size: 1rem;
line-height: inherit;
}
.footer {
position: absolute;
bottom: 0;
width: 100%;
white-space: nowrap;
line-height: 60px;
}

View File

@ -0,0 +1,2 @@
<script src="~/lib/jquery-validation/dist/jquery.validate.min.js"></script>
<script src="~/lib/jquery-validation-unobtrusive/jquery.validate.unobtrusive.min.js"></script>

View File

@ -0,0 +1,3 @@
@using ServiceStationGuarantorApp
@using ServiceStationGuarantorApp.Models
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers

View File

@ -0,0 +1,3 @@
@{
Layout = "_Layout";
}

View File

@ -0,0 +1,8 @@
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
}
}

View File

@ -0,0 +1,10 @@
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*",
"IPAddress": "http://localhost:5244/"
}

View File

@ -0,0 +1,18 @@
html {
font-size: 14px;
}
@media (min-width: 768px) {
html {
font-size: 16px;
}
}
html {
position: relative;
min-height: 100%;
}
body {
margin-bottom: 60px;
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.3 KiB

View File

@ -0,0 +1,4 @@
// Please see documentation at https://docs.microsoft.com/aspnet/core/client-side/bundling-and-minification
// for details on configuring this project to bundle and minify static web assets.
// Write your JavaScript code.

View File

@ -0,0 +1,22 @@
The MIT License (MIT)
Copyright (c) 2011-2021 Twitter, Inc.
Copyright (c) 2011-2021 The Bootstrap Authors
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,427 @@
/*!
* Bootstrap Reboot v5.1.0 (https://getbootstrap.com/)
* Copyright 2011-2021 The Bootstrap Authors
* Copyright 2011-2021 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md)
*/
*,
*::before,
*::after {
box-sizing: border-box;
}
@media (prefers-reduced-motion: no-preference) {
:root {
scroll-behavior: smooth;
}
}
body {
margin: 0;
font-family: var(--bs-body-font-family);
font-size: var(--bs-body-font-size);
font-weight: var(--bs-body-font-weight);
line-height: var(--bs-body-line-height);
color: var(--bs-body-color);
text-align: var(--bs-body-text-align);
background-color: var(--bs-body-bg);
-webkit-text-size-adjust: 100%;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
hr {
margin: 1rem 0;
color: inherit;
background-color: currentColor;
border: 0;
opacity: 0.25;
}
hr:not([size]) {
height: 1px;
}
h6, h5, h4, h3, h2, h1 {
margin-top: 0;
margin-bottom: 0.5rem;
font-weight: 500;
line-height: 1.2;
}
h1 {
font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
h1 {
font-size: 2.5rem;
}
}
h2 {
font-size: calc(1.325rem + 0.9vw);
}
@media (min-width: 1200px) {
h2 {
font-size: 2rem;
}
}
h3 {
font-size: calc(1.3rem + 0.6vw);
}
@media (min-width: 1200px) {
h3 {
font-size: 1.75rem;
}
}
h4 {
font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
h4 {
font-size: 1.5rem;
}
}
h5 {
font-size: 1.25rem;
}
h6 {
font-size: 1rem;
}
p {
margin-top: 0;
margin-bottom: 1rem;
}
abbr[title],
abbr[data-bs-original-title] {
-webkit-text-decoration: underline dotted;
text-decoration: underline dotted;
cursor: help;
-webkit-text-decoration-skip-ink: none;
text-decoration-skip-ink: none;
}
address {
margin-bottom: 1rem;
font-style: normal;
line-height: inherit;
}
ol,
ul {
padding-left: 2rem;
}
ol,
ul,
dl {
margin-top: 0;
margin-bottom: 1rem;
}
ol ol,
ul ul,
ol ul,
ul ol {
margin-bottom: 0;
}
dt {
font-weight: 700;
}
dd {
margin-bottom: 0.5rem;
margin-left: 0;
}
blockquote {
margin: 0 0 1rem;
}
b,
strong {
font-weight: bolder;
}
small {
font-size: 0.875em;
}
mark {
padding: 0.2em;
background-color: #fcf8e3;
}
sub,
sup {
position: relative;
font-size: 0.75em;
line-height: 0;
vertical-align: baseline;
}
sub {
bottom: -0.25em;
}
sup {
top: -0.5em;
}
a {
color: #0d6efd;
text-decoration: underline;
}
a:hover {
color: #0a58ca;
}
a:not([href]):not([class]), a:not([href]):not([class]):hover {
color: inherit;
text-decoration: none;
}
pre,
code,
kbd,
samp {
font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 1em;
direction: ltr /* rtl:ignore */;
unicode-bidi: bidi-override;
}
pre {
display: block;
margin-top: 0;
margin-bottom: 1rem;
overflow: auto;
font-size: 0.875em;
}
pre code {
font-size: inherit;
color: inherit;
word-break: normal;
}
code {
font-size: 0.875em;
color: #d63384;
word-wrap: break-word;
}
a > code {
color: inherit;
}
kbd {
padding: 0.2rem 0.4rem;
font-size: 0.875em;
color: #fff;
background-color: #212529;
border-radius: 0.2rem;
}
kbd kbd {
padding: 0;
font-size: 1em;
font-weight: 700;
}
figure {
margin: 0 0 1rem;
}
img,
svg {
vertical-align: middle;
}
table {
caption-side: bottom;
border-collapse: collapse;
}
caption {
padding-top: 0.5rem;
padding-bottom: 0.5rem;
color: #6c757d;
text-align: left;
}
th {
text-align: inherit;
text-align: -webkit-match-parent;
}
thead,
tbody,
tfoot,
tr,
td,
th {
border-color: inherit;
border-style: solid;
border-width: 0;
}
label {
display: inline-block;
}
button {
border-radius: 0;
}
button:focus:not(:focus-visible) {
outline: 0;
}
input,
button,
select,
optgroup,
textarea {
margin: 0;
font-family: inherit;
font-size: inherit;
line-height: inherit;
}
button,
select {
text-transform: none;
}
[role=button] {
cursor: pointer;
}
select {
word-wrap: normal;
}
select:disabled {
opacity: 1;
}
[list]::-webkit-calendar-picker-indicator {
display: none;
}
button,
[type=button],
[type=reset],
[type=submit] {
-webkit-appearance: button;
}
button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
cursor: pointer;
}
::-moz-focus-inner {
padding: 0;
border-style: none;
}
textarea {
resize: vertical;
}
fieldset {
min-width: 0;
padding: 0;
margin: 0;
border: 0;
}
legend {
float: left;
width: 100%;
padding: 0;
margin-bottom: 0.5rem;
font-size: calc(1.275rem + 0.3vw);
line-height: inherit;
}
@media (min-width: 1200px) {
legend {
font-size: 1.5rem;
}
}
legend + * {
clear: left;
}
::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-minute,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-year-field {
padding: 0;
}
::-webkit-inner-spin-button {
height: auto;
}
[type=search] {
outline-offset: -2px;
-webkit-appearance: textfield;
}
/* rtl:raw:
[type="tel"],
[type="url"],
[type="email"],
[type="number"] {
direction: ltr;
}
*/
::-webkit-search-decoration {
-webkit-appearance: none;
}
::-webkit-color-swatch-wrapper {
padding: 0;
}
::file-selector-button {
font: inherit;
}
::-webkit-file-upload-button {
font: inherit;
-webkit-appearance: button;
}
output {
display: inline-block;
}
iframe {
border: 0;
}
summary {
display: list-item;
cursor: pointer;
}
progress {
vertical-align: baseline;
}
[hidden] {
display: none !important;
}
/*# sourceMappingURL=bootstrap-reboot.css.map */

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,8 @@
/*!
* Bootstrap Reboot v5.1.0 (https://getbootstrap.com/)
* Copyright 2011-2021 The Bootstrap Authors
* Copyright 2011-2021 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md)
*/*,::after,::before{box-sizing:border-box}@media (prefers-reduced-motion:no-preference){:root{scroll-behavior:smooth}}body{margin:0;font-family:var(--bs-body-font-family);font-size:var(--bs-body-font-size);font-weight:var(--bs-body-font-weight);line-height:var(--bs-body-line-height);color:var(--bs-body-color);text-align:var(--bs-body-text-align);background-color:var(--bs-body-bg);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}hr{margin:1rem 0;color:inherit;background-color:currentColor;border:0;opacity:.25}hr:not([size]){height:1px}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:500;line-height:1.2}h1{font-size:calc(1.375rem + 1.5vw)}@media (min-width:1200px){h1{font-size:2.5rem}}h2{font-size:calc(1.325rem + .9vw)}@media (min-width:1200px){h2{font-size:2rem}}h3{font-size:calc(1.3rem + .6vw)}@media (min-width:1200px){h3{font-size:1.75rem}}h4{font-size:calc(1.275rem + .3vw)}@media (min-width:1200px){h4{font-size:1.5rem}}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-top:0;margin-bottom:1rem}abbr[data-bs-original-title],abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul{padding-left:2rem}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:.875em}mark{padding:.2em;background-color:#fcf8e3}sub,sup{position:relative;font-size:.75em;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#0d6efd;text-decoration:underline}a:hover{color:#0a58ca}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em;direction:ltr;unicode-bidi:bidi-override}pre{display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-size:.875em}pre code{font-size:inherit;color:inherit;word-break:normal}code{font-size:.875em;color:#d63384;word-wrap:break-word}a>code{color:inherit}kbd{padding:.2rem .4rem;font-size:.875em;color:#fff;background-color:#212529;border-radius:.2rem}kbd kbd{padding:0;font-size:1em;font-weight:700}figure{margin:0 0 1rem}img,svg{vertical-align:middle}table{caption-side:bottom;border-collapse:collapse}caption{padding-top:.5rem;padding-bottom:.5rem;color:#6c757d;text-align:left}th{text-align:inherit;text-align:-webkit-match-parent}tbody,td,tfoot,th,thead,tr{border-color:inherit;border-style:solid;border-width:0}label{display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}select:disabled{opacity:1}[list]::-webkit-calendar-picker-indicator{display:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}::-moz-focus-inner{padding:0;border-style:none}textarea{resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{float:left;width:100%;padding:0;margin-bottom:.5rem;font-size:calc(1.275rem + .3vw);line-height:inherit}@media (min-width:1200px){legend{font-size:1.5rem}}legend+*{clear:left}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-fields-wrapper,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-text,::-webkit-datetime-edit-year-field{padding:0}::-webkit-inner-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:textfield}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-color-swatch-wrapper{padding:0}::file-selector-button{font:inherit}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}iframe{border:0}summary{display:list-item;cursor:pointer}progress{vertical-align:baseline}[hidden]{display:none!important}
/*# sourceMappingURL=bootstrap-reboot.min.css.map */

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,424 @@
/*!
* Bootstrap Reboot v5.1.0 (https://getbootstrap.com/)
* Copyright 2011-2021 The Bootstrap Authors
* Copyright 2011-2021 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md)
*/
*,
*::before,
*::after {
box-sizing: border-box;
}
@media (prefers-reduced-motion: no-preference) {
:root {
scroll-behavior: smooth;
}
}
body {
margin: 0;
font-family: var(--bs-body-font-family);
font-size: var(--bs-body-font-size);
font-weight: var(--bs-body-font-weight);
line-height: var(--bs-body-line-height);
color: var(--bs-body-color);
text-align: var(--bs-body-text-align);
background-color: var(--bs-body-bg);
-webkit-text-size-adjust: 100%;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
hr {
margin: 1rem 0;
color: inherit;
background-color: currentColor;
border: 0;
opacity: 0.25;
}
hr:not([size]) {
height: 1px;
}
h6, h5, h4, h3, h2, h1 {
margin-top: 0;
margin-bottom: 0.5rem;
font-weight: 500;
line-height: 1.2;
}
h1 {
font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
h1 {
font-size: 2.5rem;
}
}
h2 {
font-size: calc(1.325rem + 0.9vw);
}
@media (min-width: 1200px) {
h2 {
font-size: 2rem;
}
}
h3 {
font-size: calc(1.3rem + 0.6vw);
}
@media (min-width: 1200px) {
h3 {
font-size: 1.75rem;
}
}
h4 {
font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
h4 {
font-size: 1.5rem;
}
}
h5 {
font-size: 1.25rem;
}
h6 {
font-size: 1rem;
}
p {
margin-top: 0;
margin-bottom: 1rem;
}
abbr[title],
abbr[data-bs-original-title] {
-webkit-text-decoration: underline dotted;
text-decoration: underline dotted;
cursor: help;
-webkit-text-decoration-skip-ink: none;
text-decoration-skip-ink: none;
}
address {
margin-bottom: 1rem;
font-style: normal;
line-height: inherit;
}
ol,
ul {
padding-right: 2rem;
}
ol,
ul,
dl {
margin-top: 0;
margin-bottom: 1rem;
}
ol ol,
ul ul,
ol ul,
ul ol {
margin-bottom: 0;
}
dt {
font-weight: 700;
}
dd {
margin-bottom: 0.5rem;
margin-right: 0;
}
blockquote {
margin: 0 0 1rem;
}
b,
strong {
font-weight: bolder;
}
small {
font-size: 0.875em;
}
mark {
padding: 0.2em;
background-color: #fcf8e3;
}
sub,
sup {
position: relative;
font-size: 0.75em;
line-height: 0;
vertical-align: baseline;
}
sub {
bottom: -0.25em;
}
sup {
top: -0.5em;
}
a {
color: #0d6efd;
text-decoration: underline;
}
a:hover {
color: #0a58ca;
}
a:not([href]):not([class]), a:not([href]):not([class]):hover {
color: inherit;
text-decoration: none;
}
pre,
code,
kbd,
samp {
font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
font-size: 1em;
direction: ltr ;
unicode-bidi: bidi-override;
}
pre {
display: block;
margin-top: 0;
margin-bottom: 1rem;
overflow: auto;
font-size: 0.875em;
}
pre code {
font-size: inherit;
color: inherit;
word-break: normal;
}
code {
font-size: 0.875em;
color: #d63384;
word-wrap: break-word;
}
a > code {
color: inherit;
}
kbd {
padding: 0.2rem 0.4rem;
font-size: 0.875em;
color: #fff;
background-color: #212529;
border-radius: 0.2rem;
}
kbd kbd {
padding: 0;
font-size: 1em;
font-weight: 700;
}
figure {
margin: 0 0 1rem;
}
img,
svg {
vertical-align: middle;
}
table {
caption-side: bottom;
border-collapse: collapse;
}
caption {
padding-top: 0.5rem;
padding-bottom: 0.5rem;
color: #6c757d;
text-align: right;
}
th {
text-align: inherit;
text-align: -webkit-match-parent;
}
thead,
tbody,
tfoot,
tr,
td,
th {
border-color: inherit;
border-style: solid;
border-width: 0;
}
label {
display: inline-block;
}
button {
border-radius: 0;
}
button:focus:not(:focus-visible) {
outline: 0;
}
input,
button,
select,
optgroup,
textarea {
margin: 0;
font-family: inherit;
font-size: inherit;
line-height: inherit;
}
button,
select {
text-transform: none;
}
[role=button] {
cursor: pointer;
}
select {
word-wrap: normal;
}
select:disabled {
opacity: 1;
}
[list]::-webkit-calendar-picker-indicator {
display: none;
}
button,
[type=button],
[type=reset],
[type=submit] {
-webkit-appearance: button;
}
button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
cursor: pointer;
}
::-moz-focus-inner {
padding: 0;
border-style: none;
}
textarea {
resize: vertical;
}
fieldset {
min-width: 0;
padding: 0;
margin: 0;
border: 0;
}
legend {
float: right;
width: 100%;
padding: 0;
margin-bottom: 0.5rem;
font-size: calc(1.275rem + 0.3vw);
line-height: inherit;
}
@media (min-width: 1200px) {
legend {
font-size: 1.5rem;
}
}
legend + * {
clear: right;
}
::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-minute,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-year-field {
padding: 0;
}
::-webkit-inner-spin-button {
height: auto;
}
[type=search] {
outline-offset: -2px;
-webkit-appearance: textfield;
}
[type="tel"],
[type="url"],
[type="email"],
[type="number"] {
direction: ltr;
}
::-webkit-search-decoration {
-webkit-appearance: none;
}
::-webkit-color-swatch-wrapper {
padding: 0;
}
::file-selector-button {
font: inherit;
}
::-webkit-file-upload-button {
font: inherit;
-webkit-appearance: button;
}
output {
display: inline-block;
}
iframe {
border: 0;
}
summary {
display: list-item;
cursor: pointer;
}
progress {
vertical-align: baseline;
}
[hidden] {
display: none !important;
}
/*# sourceMappingURL=bootstrap-reboot.rtl.css.map */

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,8 @@
/*!
* Bootstrap Reboot v5.1.0 (https://getbootstrap.com/)
* Copyright 2011-2021 The Bootstrap Authors
* Copyright 2011-2021 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md)
*/*,::after,::before{box-sizing:border-box}@media (prefers-reduced-motion:no-preference){:root{scroll-behavior:smooth}}body{margin:0;font-family:var(--bs-body-font-family);font-size:var(--bs-body-font-size);font-weight:var(--bs-body-font-weight);line-height:var(--bs-body-line-height);color:var(--bs-body-color);text-align:var(--bs-body-text-align);background-color:var(--bs-body-bg);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}hr{margin:1rem 0;color:inherit;background-color:currentColor;border:0;opacity:.25}hr:not([size]){height:1px}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:500;line-height:1.2}h1{font-size:calc(1.375rem + 1.5vw)}@media (min-width:1200px){h1{font-size:2.5rem}}h2{font-size:calc(1.325rem + .9vw)}@media (min-width:1200px){h2{font-size:2rem}}h3{font-size:calc(1.3rem + .6vw)}@media (min-width:1200px){h3{font-size:1.75rem}}h4{font-size:calc(1.275rem + .3vw)}@media (min-width:1200px){h4{font-size:1.5rem}}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-top:0;margin-bottom:1rem}abbr[data-bs-original-title],abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul{padding-right:2rem}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-right:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:.875em}mark{padding:.2em;background-color:#fcf8e3}sub,sup{position:relative;font-size:.75em;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#0d6efd;text-decoration:underline}a:hover{color:#0a58ca}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em;direction:ltr;unicode-bidi:bidi-override}pre{display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-size:.875em}pre code{font-size:inherit;color:inherit;word-break:normal}code{font-size:.875em;color:#d63384;word-wrap:break-word}a>code{color:inherit}kbd{padding:.2rem .4rem;font-size:.875em;color:#fff;background-color:#212529;border-radius:.2rem}kbd kbd{padding:0;font-size:1em;font-weight:700}figure{margin:0 0 1rem}img,svg{vertical-align:middle}table{caption-side:bottom;border-collapse:collapse}caption{padding-top:.5rem;padding-bottom:.5rem;color:#6c757d;text-align:right}th{text-align:inherit;text-align:-webkit-match-parent}tbody,td,tfoot,th,thead,tr{border-color:inherit;border-style:solid;border-width:0}label{display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}select:disabled{opacity:1}[list]::-webkit-calendar-picker-indicator{display:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}::-moz-focus-inner{padding:0;border-style:none}textarea{resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{float:right;width:100%;padding:0;margin-bottom:.5rem;font-size:calc(1.275rem + .3vw);line-height:inherit}@media (min-width:1200px){legend{font-size:1.5rem}}legend+*{clear:right}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-fields-wrapper,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-text,::-webkit-datetime-edit-year-field{padding:0}::-webkit-inner-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:textfield}[type=email],[type=number],[type=tel],[type=url]{direction:ltr}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-color-swatch-wrapper{padding:0}::file-selector-button{font:inherit}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}iframe{border:0}summary{display:list-item;cursor:pointer}progress{vertical-align:baseline}[hidden]{display:none!important}
/*# sourceMappingURL=bootstrap-reboot.rtl.min.css.map */

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

Some files were not shown because too many files have changed in this diff Show More