From cd671cfc0fa794f97dccf7ab286a119a5ac83350 Mon Sep 17 00:00:00 2001 From: Taiji Uchida <63937957+uchi-ta@users.noreply.github.com> Date: Fri, 22 Sep 2023 11:03:48 +0900 Subject: [PATCH] Added new features / Bug fixed MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ・CSVをインポートするAPIを追加。 ・モバイル環境のユーザビリティの向上。 ・APIによるレコード作成時に添付ファイルのサイズチェックが行われない問題を解消。 ・ファイルアップロード時に拡張機能のサイトIDの指定が機能しない問題を解消。 ・ファイルアップロード時にサーバスクリプトのサイト設定の読み込み時が動作しない問題を解消。 --- Implem.CodeDefiner/Implem.CodeDefiner.csproj | 6 +- Implem.DefinitionAccessor/Def.cs | 3 + .../Implem.DefinitionAccessor.csproj | 6 +- .../Implem.DisplayAccessor.csproj | 6 +- Implem.Factory/Implem.Factory.csproj | 6 +- Implem.Libraries/Implem.Libraries.csproj | 6 +- .../Implem.ParameterAccessor.csproj | 6 +- .../Definition_Code/Model_Body.txt | 1 + .../Definition_Code/Model_ImportByApi.json | 5 + .../Model_ImportByApi_Body.txt | 39 + .../Model_Utilities_Import_Body.txt | 336 ++++- .../Controllers/Api/ItemsController.cs | 23 + Implem.Pleasanter/Dockerfile | 6 +- Implem.Pleasanter/Implem.Pleasanter.csproj | 11 +- .../Libraries/Requests/Context.cs | 62 +- .../Libraries/Requests/ImportApi.cs | 12 + .../Libraries/Settings/ImportUtilities.cs | 30 + Implem.Pleasanter/Libraries/Web/Mime.cs | 6 +- .../Models/Binaries/BinaryUtilities.cs | 5 +- .../Models/Binaries/BinaryValidators.cs | 7 + .../Models/Issues/IssueUtilities.cs | 336 ++++- Implem.Pleasanter/Models/Items/ItemModel.cs | 40 + .../Models/Results/ResultUtilities.cs | 336 ++++- .../wwwroot/content/responsive.css | 1152 +++++++++++++++-- .../wwwroot/content/responsive.min.css | 2 +- .../wwwroot/scripts/responsive.js | 101 +- .../wwwroot/scripts/sitepackage.js | 6 + Implem.Pleasanter/wwwroot/scripts/template.js | 3 + Implem.Pleasanter/wwwroot/scripts/viewmode.js | 3 + .../wwwroot/styles/responsive.css | 1152 +++++++++++++++-- .../implem.TestAutomation.csproj | 6 +- Rds/Implem.IRds/Implem.IRds.csproj | 6 +- .../Implem.PostgreSql.csproj | 6 +- Rds/Implem.SqlServer/Implem.SqlServer.csproj | 6 +- 34 files changed, 3472 insertions(+), 265 deletions(-) create mode 100644 Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi.json create mode 100644 Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi_Body.txt create mode 100644 Implem.Pleasanter/Libraries/Requests/ImportApi.cs diff --git a/Implem.CodeDefiner/Implem.CodeDefiner.csproj b/Implem.CodeDefiner/Implem.CodeDefiner.csproj index 80b547049..7e935a492 100644 --- a/Implem.CodeDefiner/Implem.CodeDefiner.csproj +++ b/Implem.CodeDefiner/Implem.CodeDefiner.csproj @@ -5,9 +5,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 This program does the automatic code creation and merging of existing code based on the definition. Also it will make the configuration change of sql server database. - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 Linux diff --git a/Implem.DefinitionAccessor/Def.cs b/Implem.DefinitionAccessor/Def.cs index f0bacb61b..d92bdead4 100644 --- a/Implem.DefinitionAccessor/Def.cs +++ b/Implem.DefinitionAccessor/Def.cs @@ -478,6 +478,7 @@ public static void SetCodeDefinition() case "Model_ImageLibCases": Code.Model_ImageLibCases = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_ImageLibCases, definitionRow, CodeXls); break; case "Model_ImageLibJsonCases": Code.Model_ImageLibJsonCases = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_ImageLibJsonCases, definitionRow, CodeXls); break; case "Model_ImageLibNextCases": Code.Model_ImageLibNextCases = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_ImageLibNextCases, definitionRow, CodeXls); break; + case "Model_ImportByApi": Code.Model_ImportByApi = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_ImportByApi, definitionRow, CodeXls); break; case "Model_ImportCases": Code.Model_ImportCases = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_ImportCases, definitionRow, CodeXls); break; case "Model_IndexCases": Code.Model_IndexCases = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_IndexCases, definitionRow, CodeXls); break; case "Model_IndexJsonCases": Code.Model_IndexJsonCases = definitionRow[1].ToString().NoSpace(definitionRow["NoSpace"].ToBool()); SetCodeTable(CodeTable.Model_IndexJsonCases, definitionRow, CodeXls); break; @@ -6924,6 +6925,7 @@ public class CodeColumn2nd public string Model_ImageLibCases; public string Model_ImageLibJsonCases; public string Model_ImageLibNextCases; + public string Model_ImportByApi; public string Model_ImportCases; public string Model_IndexCases; public string Model_IndexJsonCases; @@ -7721,6 +7723,7 @@ public class CodeTable public CodeDefinition Model_ImageLibCases = new CodeDefinition(); public CodeDefinition Model_ImageLibJsonCases = new CodeDefinition(); public CodeDefinition Model_ImageLibNextCases = new CodeDefinition(); + public CodeDefinition Model_ImportByApi = new CodeDefinition(); public CodeDefinition Model_ImportCases = new CodeDefinition(); public CodeDefinition Model_IndexCases = new CodeDefinition(); public CodeDefinition Model_IndexJsonCases = new CodeDefinition(); diff --git a/Implem.DefinitionAccessor/Implem.DefinitionAccessor.csproj b/Implem.DefinitionAccessor/Implem.DefinitionAccessor.csproj index 3810a42c5..668826221 100644 --- a/Implem.DefinitionAccessor/Implem.DefinitionAccessor.csproj +++ b/Implem.DefinitionAccessor/Implem.DefinitionAccessor.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Implem.DisplayAccessor/Implem.DisplayAccessor.csproj b/Implem.DisplayAccessor/Implem.DisplayAccessor.csproj index 378a29b06..868e0ea86 100644 --- a/Implem.DisplayAccessor/Implem.DisplayAccessor.csproj +++ b/Implem.DisplayAccessor/Implem.DisplayAccessor.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Implem.Factory/Implem.Factory.csproj b/Implem.Factory/Implem.Factory.csproj index 318e9c6af..9ca7077a5 100644 --- a/Implem.Factory/Implem.Factory.csproj +++ b/Implem.Factory/Implem.Factory.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Implem.Libraries/Implem.Libraries.csproj b/Implem.Libraries/Implem.Libraries.csproj index 219eec2e4..b875590f5 100644 --- a/Implem.Libraries/Implem.Libraries.csproj +++ b/Implem.Libraries/Implem.Libraries.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Implem.ParameterAccessor/Implem.ParameterAccessor.csproj b/Implem.ParameterAccessor/Implem.ParameterAccessor.csproj index 4960ea457..2f062727e 100644 --- a/Implem.ParameterAccessor/Implem.ParameterAccessor.csproj +++ b/Implem.ParameterAccessor/Implem.ParameterAccessor.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Body.txt b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Body.txt index 7fc8b641b..8370fe7d2 100644 --- a/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Body.txt +++ b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Body.txt @@ -93,6 +93,7 @@ namespace Implem.Pleasanter.Models + diff --git a/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi.json b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi.json new file mode 100644 index 000000000..9579e2d77 --- /dev/null +++ b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi.json @@ -0,0 +1,5 @@ +{ + "Id": "Model_ImportByApi", + "Indent": "2", + "Include": "Items" +} \ No newline at end of file diff --git a/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi_Body.txt b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi_Body.txt new file mode 100644 index 000000000..9e7a7e700 --- /dev/null +++ b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_ImportByApi_Body.txt @@ -0,0 +1,39 @@ +public ContentResultInheritance ImportByApi(Context context) +{ + SetSite( + context: context, + initSiteSettings: true, + setSiteIntegration: true, + setAllChoices: true); + if (!Site.WithinApiLimits(context: context)) + { + return ApiResults.Get(ApiResponses.OverLimitApi( + context: context, + siteId: Site.SiteId, + limitPerSite: context.ContractSettings.ApiLimit())); + } + switch (Site.ReferenceType) + { + case "Issues": + if (SiteId == ReferenceId) + { + return IssueUtilities.ImportByApi( + context: context, + ss: Site.SiteSettings, + siteModel: Site); + } + break; + case "Results": + if (SiteId == ReferenceId) + { + return ResultUtilities.ImportByApi( + context: context, + ss: Site.SiteSettings, + siteModel: Site); + } + break; + default: + return ApiResults.Get(ApiResponses.BadRequest(context: context)); + } + return ApiResults.Get(ApiResponses.BadRequest(context: context)); +} \ No newline at end of file diff --git a/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Utilities_Import_Body.txt b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Utilities_Import_Body.txt index 27a47a2f7..465532292 100644 --- a/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Utilities_Import_Body.txt +++ b/Implem.Pleasanter/App_Data/Definitions/Definition_Code/Model_Utilities_Import_Body.txt @@ -60,14 +60,7 @@ } var invalidColumn = Imports.ColumnValidate(context, ss, columnHash.Values.Select(o => o.Column.ColumnName)); if (invalidColumn != null) return invalidColumn; - Repository.ExecuteNonQuery( - context: context, - transactional: true, - statements: new List() - .OnImportingExtendedSqls( - context: context, - siteId: ss.SiteId) - .ToArray()); + ImportUtilities.SetOnImportingExtendedSqls(context, ss); var #modelName#Hash = new Dictionary(); var importKeyColumnName = context.Forms.Data("Key"); var importKeyColumn = columnHash @@ -217,14 +210,7 @@ insertCount++; } } - Repository.ExecuteNonQuery( - context: context, - transactional: true, - statements: new List() - .OnImportedExtendedSqls( - context: context, - siteId: ss.SiteId) - .ToArray()); + ImportUtilities.SetOnImportedExtendedSqls(context, ss); ss.Notifications.ForEach(notification => { var body = new System.Text.StringBuilder(); @@ -267,4 +253,322 @@ { return Messages.ResponseFileNotFound(context: context).ToJson(); } +} + +public static ContentResultInheritance ImportByApi( + Context context, + SiteSettings ss, + SiteModel siteModel) +{ + if (!Mime.ValidateOnApi(contentType: context.ContentType, multipart: true)) + { + return ApiResults.BadRequest(context: context); + } + if (context.ContractSettings.Import == false) + { + return null; + } + var invalid = #ModelName#Validators.OnImporting( + context: context, + ss: ss, + api: true); + switch (invalid.Type) + { + case Error.Types.None: break; + default:return ApiResults.Error( + context: context, + errorData: invalid); + } + var api = context.RequestDataString.Deserialize(); + var updatableImport = api.UpdatableImport; + var encoding = api.Encoding; + var key = api.Key; + Csv csv; + try + { + csv = new Csv( + csv: context.PostedFiles.FirstOrDefault().Byte(), + encoding: encoding); + } + catch + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.FailedReadFile(context: context).Text)); + } + var count = csv.Rows.Count(); + if (Parameters.General.ImportMax > 0 && Parameters.General.ImportMax < count) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Error.Types.ImportMax.Message( + context: context, + data: Parameters.General.ImportMax.ToString()).Text)); + } + if (context.ContractSettings.ItemsLimit( + context: context, + siteId: ss.SiteId, + number: count)) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Error.Types.ItemsLimit.Message(context: context).Text)); + } + if (csv != null && count > 0) + { + var columnHash = ImportUtilities.GetColumnHash(ss, csv); + var idColumn = columnHash + .Where(o => o.Value.Column.ColumnName == "#ModelName#Id") + .Select(o => new { Id = o.Key }) + .FirstOrDefault()?.Id ?? -1; + if (updatableImport && idColumn > -1) + { + var exists = ExistsLockedRecord( + context: context, + ss: ss, + targets: csv.Rows.Select(o => o[idColumn].ToLong()).ToList()); + switch (exists.Type) + { + case Error.Types.None: break; + default: return ApiResults.Error( + context: context, + errorData: exists); + } + } + var invalidColumn = Imports.ColumnValidate(context, ss, columnHash.Values.Select(o => o.Column.ColumnName)); + if (invalidColumn != null) return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: invalidColumn)); + ImportUtilities.SetOnImportingExtendedSqls(context, ss); + var #modelName#Hash = new Dictionary(); + var importKeyColumnName = key; + var importKeyColumn = columnHash + .FirstOrDefault(column => column.Value.Column.ColumnName == importKeyColumnName); + if (updatableImport && importKeyColumn.Value == null) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.NotContainKeyColumn(context: context).Text)); + } + var csvRows = csv.Rows + .Select((o, i) => new { Index = i, Row = o }) + .ToDictionary(o => o.Index, o => o.Row); + foreach (var data in csvRows) + { + var #modelName#Model = new #ModelName#Model( + context: context, + ss: ss); + if (updatableImport + && !data.Value[importKeyColumn.Key].IsNullOrEmpty()) + { + var view = new View(); + view.AddColumnFilterHash( + context: context, + ss: ss, + column: importKeyColumn.Value.Column, + objectValue: data.Value[importKeyColumn.Key]); + view.AddColumnFilterSearchTypes( + columnName: importKeyColumnName, + searchType: Column.SearchTypes.ExactMatch); + var model = new #ModelName#Model( + context: context, + ss: ss, + #modelName#Id: 0, + view: view); + if (model.AccessStatus == Databases.AccessStatuses.Selected) + { + #modelName#Model = model; + } + else if (model.AccessStatus == Databases.AccessStatuses.Overlap) + { + return ApiResults.Error( + context: context, + errorData: new ErrorData( + type: Error.Types.OverlapCsvImport, + data: new string[] { + (data.Key + 1).ToString(), + importKeyColumn.Value.Column.GridLabelText, + data.Value[importKeyColumn.Key]})); + } + } + #modelName#Model.SetByCsvRow( + context: context, + ss: ss, + columnHash: columnHash, + row: data.Value); + #modelName#Hash.Add(data.Key, #modelName#Model); + } + var inputErrorData = #ModelName#Validators.OnInputValidating( + context: context, + ss: ss, + #modelName#Hash: #modelName#Hash).FirstOrDefault(); + switch (inputErrorData.Type) + { + case Error.Types.None: break; + default: return ApiResults.Error( + context: context, + errorData: inputErrorData); + } + var insertCount = 0; + var updateCount = 0; + foreach (var data in #modelName#Hash) + { + var #modelName#Model = data.Value; + if (#modelName#Model.AccessStatus == Databases.AccessStatuses.Selected) + { + ErrorData errorData = null; + while (errorData?.Type != Error.Types.None) + { + switch (errorData?.Type) + { + case Error.Types.Duplicated: + var duplicatedColumn = ss.GetColumn( + context: context, + columnName: errorData.ColumnName); + return ApiResults.Duplicated( + context: context, + message: duplicatedColumn?.MessageWhenDuplicated.IsNullOrEmpty() != false + ? Displays.Duplicated( + context: context, + data: duplicatedColumn?.LabelText) + : duplicatedColumn?.MessageWhenDuplicated); + case null: + case Error.Types.UpdateConflicts: + #modelName#Model = new #ModelName#Model( + context: context, + ss: ss, + #modelName#Id: #modelName#Model.#ModelName#Id); + var previousTitle = #modelName#Model.Title.DisplayValue; + #modelName#Model.SetByCsvRow( + context: context, + ss: ss, + columnHash: columnHash, + row: csvRows.Get(data.Key)); + switch (#modelName#Model.AccessStatus) + { + case Databases.AccessStatuses.Selected: + if (#modelName#Model.Updated(context: context)) + { + #modelName#Model.VerUp = Versions.MustVerUp( + context: context, + ss: ss, + baseModel: #modelName#Model); + errorData = #modelName#Model.Update( + context: context, + ss: ss, + extendedSqls: false, + previousTitle: previousTitle, + get: false); + updateCount++; + } + else + { + errorData = new ErrorData(type: Error.Types.None); + } + break; + case Databases.AccessStatuses.NotFound: + #modelName#Model.#ModelName#Id = 0; + #modelName#Model.Ver = 1; + errorData = #modelName#Model.Create( + context: context, + ss: ss, + extendedSqls: false); + insertCount++; + break; + default: + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.UpdateConflicts(context: context).Text)); + } + break; + default: + return ApiResults.Error( + context: context, + errorData: errorData); + } + } + } + else + { + #modelName#Model.#ModelName#Id = 0; + #modelName#Model.Ver = 1; + var errorData = #modelName#Model.Create( + context: context, + ss: ss, + extendedSqls: false); + switch (errorData.Type) + { + case Error.Types.None: + break; + case Error.Types.Duplicated: + var duplicatedColumn = ss.GetColumn( + context: context, + columnName: errorData.ColumnName); + return ApiResults.Duplicated( + context: context, + message: duplicatedColumn?.MessageWhenDuplicated.IsNullOrEmpty() != false + ? Displays.Duplicated( + context: context, + data: duplicatedColumn?.LabelText) + : duplicatedColumn?.MessageWhenDuplicated); + default: + return ApiResults.Error( + context: context, + errorData: errorData); + } + insertCount++; + } + } + ImportUtilities.SetOnImportedExtendedSqls(context, ss); + ss.Notifications.ForEach(notification => + { + var body = new System.Text.StringBuilder(); + body.Append(Locations.ItemIndexAbsoluteUri( + context: context, + ss.SiteId) + "\n"); + body.Append( + $"{Displays.#TableName#_Updator(context: context)}: ", + $"{context.User.Name}\n"); + if (notification.AfterImport != false) + { + notification.Send( + context: context, + ss: ss, + title: Displays.Imported( + context: context, + data: new string[] + { + ss.Title, + insertCount.ToString(), + updateCount.ToString() + }), + body: body.ToString()); + } + }); + return ApiResults.Success( + id: context.Id, + limitPerDate: context.ContractSettings.ApiLimit(), + limitRemaining: context.ContractSettings.ApiLimit() - ss.ApiCount, + message: Messages.Imported( + context: context, + data: new string[] + { + ss.Title, + insertCount.ToString(), + updateCount.ToString() + }).Text); + } + else + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.FileNotFound(context: context).Text)); + } } \ No newline at end of file diff --git a/Implem.Pleasanter/Controllers/Api/ItemsController.cs b/Implem.Pleasanter/Controllers/Api/ItemsController.cs index e9e533dee..b0736e71d 100644 --- a/Implem.Pleasanter/Controllers/Api/ItemsController.cs +++ b/Implem.Pleasanter/Controllers/Api/ItemsController.cs @@ -1,11 +1,16 @@ using Implem.Libraries.Utilities; using Implem.Pleasanter.Libraries.Requests; using Implem.Pleasanter.Libraries.Responses; +using Implem.Pleasanter.Libraries.Web; using Implem.Pleasanter.Models; using Implem.PleasanterFilters; using Microsoft.AspNetCore.Authorization; +using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; +using System.Collections.Generic; using System.IO; +using System.Linq; + namespace Implem.Pleasanter.Controllers.Api { [CheckApiContextAttributes] @@ -128,6 +133,24 @@ public ContentResult BulkDelete(long id) return result.ToHttpResponse(request: Request); } + [HttpPost("{id}/Import")] + public ContentResult Import(long id) + { + var body = Request.Form["parameters"]; + var contentType = Request.ContentType.Split(';')[0].Trim(); + var context = new Context( + apiRequestBody: body, + files: Request.Form.Files.ToList(), + contentType: contentType, + api: true); + var log = new SysLogModel(context: context); + var result = context.Authenticated + ? new ItemModel(context: context, referenceId: id).ImportByApi(context: context) + : ApiResults.Unauthorized(context: context); + log.Finish(context: context, responseSize: result.Content.Length); + return result.ToHttpResponse(request: Request); + } + [HttpPost("{id}/Export")] public ContentResult Export(long id) { diff --git a/Implem.Pleasanter/Dockerfile b/Implem.Pleasanter/Dockerfile index 15b2d185a..a1f6677e7 100644 --- a/Implem.Pleasanter/Dockerfile +++ b/Implem.Pleasanter/Dockerfile @@ -1,7 +1,7 @@ #See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging. FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base -RUN apt-get update && apt-get install -y libgdiplus +RUN apt-get update && apt-get install -y libgdiplus curl WORKDIR /app EXPOSE 80 @@ -24,9 +24,9 @@ WORKDIR "/src/Implem.Pleasanter" RUN dotnet build "Implem.Pleasanter.csproj" -c Release -o /app/build FROM build AS publish -RUN apt-get update && apt-get install -y jq RUN dotnet publish "Implem.Pleasanter.csproj" -c Release -o /app/publish -RUN cat App_Data/Parameters/Rds.json \ +RUN curl -o /usr/bin/jq -L https://github.com/stedolan/jq/releases/download/jq-1.6/jq-linux64 && chmod +x /usr/bin/jq && \ + cat App_Data/Parameters/Rds.json \ | jq '.Dbms|="PostgreSQL" | .SaConnectionString|=null | .OwnerConnectionString|=null | .UserConnectionString|=null' \ > /app/publish/App_Data/Parameters/Rds.json diff --git a/Implem.Pleasanter/Implem.Pleasanter.csproj b/Implem.Pleasanter/Implem.Pleasanter.csproj index 1c786b9be..cbb0c0539 100644 --- a/Implem.Pleasanter/Implem.Pleasanter.csproj +++ b/Implem.Pleasanter/Implem.Pleasanter.csproj @@ -1,13 +1,13 @@ - + net6.0 Copyright © Implem Inc 2014 - 2023 Business application platform Implem.Pleasanter - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable Linux ..\docker-compose.dcproj @@ -64,7 +64,7 @@ - + @@ -94,6 +94,7 @@ + diff --git a/Implem.Pleasanter/Libraries/Requests/Context.cs b/Implem.Pleasanter/Libraries/Requests/Context.cs index e6e3790d3..b6b830974 100644 --- a/Implem.Pleasanter/Libraries/Requests/Context.cs +++ b/Implem.Pleasanter/Libraries/Requests/Context.cs @@ -192,9 +192,9 @@ public Context( SetTenantCaches(); } - public Context(ICollection files, string apiRequestBody = null, bool api = false) + public Context(ICollection files, string apiRequestBody = null, string contentType = null, bool api = false) { - Set(apiRequestBody: apiRequestBody); + Set(apiRequestBody: apiRequestBody, contentType: contentType); SetPostedFiles(files: files); Api = api; } @@ -318,36 +318,40 @@ public void SetItemProperties() { switch (Controller) { + case "binaries": case "items": case "publishes": - Repository.ExecuteTable( - context: this, - statements: Rds.SelectItems( - column: Rds.ItemsColumn() - .SiteId() - .ReferenceId() - .Title(), - where: Rds.ItemsWhere() - .Add(or: Rds.ItemsWhere() - .ReferenceId(Id) - .ReferenceId(sub: Rds.SelectItems( - column: Rds.ItemsColumn().SiteId(), - where: Rds.ItemsWhere().ReferenceId(Id)))), - distinct: true)) - .AsEnumerable() - .ForEach(dataRow => - { - if (dataRow.Long("SiteId") == dataRow.Long("ReferenceId")) - { - SiteId = dataRow.Long("ReferenceId"); - SiteTitle = dataRow.String("Title"); - } - else + if (Id > 0) + { + Repository.ExecuteTable( + context: this, + statements: Rds.SelectItems( + column: Rds.ItemsColumn() + .SiteId() + .ReferenceId() + .Title(), + where: Rds.ItemsWhere() + .Add(or: Rds.ItemsWhere() + .ReferenceId(Id) + .ReferenceId(sub: Rds.SelectItems( + column: Rds.ItemsColumn().SiteId(), + where: Rds.ItemsWhere().ReferenceId(Id)))), + distinct: true)) + .AsEnumerable() + .ForEach(dataRow => { - RecordTitle = dataRow.String("Title"); - } - TargetTenantId = dataRow.Int("TenantId"); - }); + if (dataRow.Long("SiteId") == dataRow.Long("ReferenceId")) + { + SiteId = dataRow.Long("ReferenceId"); + SiteTitle = dataRow.String("Title"); + } + else + { + RecordTitle = dataRow.String("Title"); + } + TargetTenantId = dataRow.Int("TenantId"); + }); + } Page = Controller + "/" + SiteId + (TrashboxActions() diff --git a/Implem.Pleasanter/Libraries/Requests/ImportApi.cs b/Implem.Pleasanter/Libraries/Requests/ImportApi.cs new file mode 100644 index 000000000..3e22594cf --- /dev/null +++ b/Implem.Pleasanter/Libraries/Requests/ImportApi.cs @@ -0,0 +1,12 @@ +using Implem.Pleasanter.Libraries.Settings; +using System; +namespace Implem.Pleasanter.Libraries.Requests +{ + [Serializable] + public class ImportApi : Api + { + public bool UpdatableImport { get; set; } + public string Encoding { get; set; } + public string Key {get; set;} + } +} \ No newline at end of file diff --git a/Implem.Pleasanter/Libraries/Settings/ImportUtilities.cs b/Implem.Pleasanter/Libraries/Settings/ImportUtilities.cs index 681cb4858..3dcaaf4a0 100644 --- a/Implem.Pleasanter/Libraries/Settings/ImportUtilities.cs +++ b/Implem.Pleasanter/Libraries/Settings/ImportUtilities.cs @@ -1,5 +1,9 @@ using Implem.Libraries.Classes; +using Implem.Libraries.DataSources.SqlServer; using Implem.Libraries.Utilities; +using Implem.Pleasanter.Libraries.DataSources; +using Implem.Pleasanter.Libraries.General; +using Implem.Pleasanter.Libraries.Requests; using System.Collections.Generic; using System.Linq; namespace Implem.Pleasanter.Libraries.Settings @@ -88,5 +92,31 @@ public static string RecordingData( : string.Empty; } } + + public static int SetOnImportingExtendedSqls(Context context, SiteSettings ss) + { + return Repository.ExecuteNonQuery( + context: context, + transactional: true, + statements: new List() + .OnImportingExtendedSqls( + context: context, + siteId: ss.SiteId) + .ToArray()); + } + + public static int SetOnImportedExtendedSqls(Context context, SiteSettings ss) + { + return Repository.ExecuteNonQuery( + context: context, + transactional: true, + statements: new List() + .OnImportedExtendedSqls( + context: context, + siteId: ss.SiteId) + .ToArray()); + } + + } } diff --git a/Implem.Pleasanter/Libraries/Web/Mime.cs b/Implem.Pleasanter/Libraries/Web/Mime.cs index 83431451f..f6e657ea0 100644 --- a/Implem.Pleasanter/Libraries/Web/Mime.cs +++ b/Implem.Pleasanter/Libraries/Web/Mime.cs @@ -8,14 +8,16 @@ public static string Type(string fileDownloadName) return MimeKit.MimeTypes.GetMimeType(fileDownloadName); } - public static bool ValidateOnApi(string contentType) + public static bool ValidateOnApi(string contentType, bool multipart = false) { if (Parameters.Security.MimeTypeCheckOnApi) { switch (contentType?.ToLower()) { case "application/json": - return true; + return !multipart; + case "multipart/form-data": + return multipart; default: return false; } diff --git a/Implem.Pleasanter/Models/Binaries/BinaryUtilities.cs b/Implem.Pleasanter/Models/Binaries/BinaryUtilities.cs index 9806abb74..6fdb104ad 100644 --- a/Implem.Pleasanter/Models/Binaries/BinaryUtilities.cs +++ b/Implem.Pleasanter/Models/Binaries/BinaryUtilities.cs @@ -730,7 +730,10 @@ public static string UploadFile( System.Net.Http.Headers.ContentRangeHeaderValue contentRange ) { var itemModel = new ItemModel(context, id); - var ss = itemModel.GetSite(context, initSiteSettings: true).SiteSettings; + itemModel.SetSite( + context: context, + initSiteSettings: true); + var ss = itemModel.Site.SiteSettings; var column = ss.GetColumn(context, TrimIdSuffix(context.Forms.Get("ColumnName"))); var attachments = context.Forms.Get("AttachmentsData").Deserialize(); var fileHash = context.Forms.Get("FileHash"); diff --git a/Implem.Pleasanter/Models/Binaries/BinaryValidators.cs b/Implem.Pleasanter/Models/Binaries/BinaryValidators.cs index 935eace68..7eb01e99f 100644 --- a/Implem.Pleasanter/Models/Binaries/BinaryValidators.cs +++ b/Implem.Pleasanter/Models/Binaries/BinaryValidators.cs @@ -254,6 +254,13 @@ public static Error.Types OnUploading( { return Error.Types.OverLimitQuantity; } + var errorType = OverLimitSize( + attachments: attachments, + column: column); + if (errorType != Error.Types.None) + { + return errorType; + } switch (BinaryUtilities.BinaryStorageProvider(column)) { case "LocalFolder": diff --git a/Implem.Pleasanter/Models/Issues/IssueUtilities.cs b/Implem.Pleasanter/Models/Issues/IssueUtilities.cs index 4f0122f5e..0bbefff4a 100644 --- a/Implem.Pleasanter/Models/Issues/IssueUtilities.cs +++ b/Implem.Pleasanter/Models/Issues/IssueUtilities.cs @@ -6454,14 +6454,7 @@ public static string Import(Context context, SiteModel siteModel) } var invalidColumn = Imports.ColumnValidate(context, ss, columnHash.Values.Select(o => o.Column.ColumnName), "CompletionTime"); if (invalidColumn != null) return invalidColumn; - Repository.ExecuteNonQuery( - context: context, - transactional: true, - statements: new List() - .OnImportingExtendedSqls( - context: context, - siteId: ss.SiteId) - .ToArray()); + ImportUtilities.SetOnImportingExtendedSqls(context, ss); var issueHash = new Dictionary(); var importKeyColumnName = context.Forms.Data("Key"); var importKeyColumn = columnHash @@ -6662,14 +6655,7 @@ public static string Import(Context context, SiteModel siteModel) insertCount++; } } - Repository.ExecuteNonQuery( - context: context, - transactional: true, - statements: new List() - .OnImportedExtendedSqls( - context: context, - siteId: ss.SiteId) - .ToArray()); + ImportUtilities.SetOnImportedExtendedSqls(context, ss); ss.Notifications.ForEach(notification => { var body = new System.Text.StringBuilder(); @@ -6714,6 +6700,324 @@ public static string Import(Context context, SiteModel siteModel) } } + public static ContentResultInheritance ImportByApi( + Context context, + SiteSettings ss, + SiteModel siteModel) + { + if (!Mime.ValidateOnApi(contentType: context.ContentType, multipart: true)) + { + return ApiResults.BadRequest(context: context); + } + if (context.ContractSettings.Import == false) + { + return null; + } + var invalid = IssueValidators.OnImporting( + context: context, + ss: ss, + api: true); + switch (invalid.Type) + { + case Error.Types.None: break; + default:return ApiResults.Error( + context: context, + errorData: invalid); + } + var api = context.RequestDataString.Deserialize(); + var updatableImport = api.UpdatableImport; + var encoding = api.Encoding; + var key = api.Key; + Csv csv; + try + { + csv = new Csv( + csv: context.PostedFiles.FirstOrDefault().Byte(), + encoding: encoding); + } + catch + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.FailedReadFile(context: context).Text)); + } + var count = csv.Rows.Count(); + if (Parameters.General.ImportMax > 0 && Parameters.General.ImportMax < count) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Error.Types.ImportMax.Message( + context: context, + data: Parameters.General.ImportMax.ToString()).Text)); + } + if (context.ContractSettings.ItemsLimit( + context: context, + siteId: ss.SiteId, + number: count)) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Error.Types.ItemsLimit.Message(context: context).Text)); + } + if (csv != null && count > 0) + { + var columnHash = ImportUtilities.GetColumnHash(ss, csv); + var idColumn = columnHash + .Where(o => o.Value.Column.ColumnName == "IssueId") + .Select(o => new { Id = o.Key }) + .FirstOrDefault()?.Id ?? -1; + if (updatableImport && idColumn > -1) + { + var exists = ExistsLockedRecord( + context: context, + ss: ss, + targets: csv.Rows.Select(o => o[idColumn].ToLong()).ToList()); + switch (exists.Type) + { + case Error.Types.None: break; + default: return ApiResults.Error( + context: context, + errorData: exists); + } + } + var invalidColumn = Imports.ColumnValidate(context, ss, columnHash.Values.Select(o => o.Column.ColumnName), "CompletionTime"); + if (invalidColumn != null) return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: invalidColumn)); + ImportUtilities.SetOnImportingExtendedSqls(context, ss); + var issueHash = new Dictionary(); + var importKeyColumnName = key; + var importKeyColumn = columnHash + .FirstOrDefault(column => column.Value.Column.ColumnName == importKeyColumnName); + if (updatableImport && importKeyColumn.Value == null) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.NotContainKeyColumn(context: context).Text)); + } + var csvRows = csv.Rows + .Select((o, i) => new { Index = i, Row = o }) + .ToDictionary(o => o.Index, o => o.Row); + foreach (var data in csvRows) + { + var issueModel = new IssueModel( + context: context, + ss: ss); + if (updatableImport + && !data.Value[importKeyColumn.Key].IsNullOrEmpty()) + { + var view = new View(); + view.AddColumnFilterHash( + context: context, + ss: ss, + column: importKeyColumn.Value.Column, + objectValue: data.Value[importKeyColumn.Key]); + view.AddColumnFilterSearchTypes( + columnName: importKeyColumnName, + searchType: Column.SearchTypes.ExactMatch); + var model = new IssueModel( + context: context, + ss: ss, + issueId: 0, + view: view); + if (model.AccessStatus == Databases.AccessStatuses.Selected) + { + issueModel = model; + } + else if (model.AccessStatus == Databases.AccessStatuses.Overlap) + { + return ApiResults.Error( + context: context, + errorData: new ErrorData( + type: Error.Types.OverlapCsvImport, + data: new string[] { + (data.Key + 1).ToString(), + importKeyColumn.Value.Column.GridLabelText, + data.Value[importKeyColumn.Key]})); + } + } + issueModel.SetByCsvRow( + context: context, + ss: ss, + columnHash: columnHash, + row: data.Value); + issueHash.Add(data.Key, issueModel); + } + var inputErrorData = IssueValidators.OnInputValidating( + context: context, + ss: ss, + issueHash: issueHash).FirstOrDefault(); + switch (inputErrorData.Type) + { + case Error.Types.None: break; + default: return ApiResults.Error( + context: context, + errorData: inputErrorData); + } + var insertCount = 0; + var updateCount = 0; + foreach (var data in issueHash) + { + var issueModel = data.Value; + if (issueModel.AccessStatus == Databases.AccessStatuses.Selected) + { + ErrorData errorData = null; + while (errorData?.Type != Error.Types.None) + { + switch (errorData?.Type) + { + case Error.Types.Duplicated: + var duplicatedColumn = ss.GetColumn( + context: context, + columnName: errorData.ColumnName); + return ApiResults.Duplicated( + context: context, + message: duplicatedColumn?.MessageWhenDuplicated.IsNullOrEmpty() != false + ? Displays.Duplicated( + context: context, + data: duplicatedColumn?.LabelText) + : duplicatedColumn?.MessageWhenDuplicated); + case null: + case Error.Types.UpdateConflicts: + issueModel = new IssueModel( + context: context, + ss: ss, + issueId: issueModel.IssueId); + var previousTitle = issueModel.Title.DisplayValue; + issueModel.SetByCsvRow( + context: context, + ss: ss, + columnHash: columnHash, + row: csvRows.Get(data.Key)); + switch (issueModel.AccessStatus) + { + case Databases.AccessStatuses.Selected: + if (issueModel.Updated(context: context)) + { + issueModel.VerUp = Versions.MustVerUp( + context: context, + ss: ss, + baseModel: issueModel); + errorData = issueModel.Update( + context: context, + ss: ss, + extendedSqls: false, + previousTitle: previousTitle, + get: false); + updateCount++; + } + else + { + errorData = new ErrorData(type: Error.Types.None); + } + break; + case Databases.AccessStatuses.NotFound: + issueModel.IssueId = 0; + issueModel.Ver = 1; + errorData = issueModel.Create( + context: context, + ss: ss, + extendedSqls: false); + insertCount++; + break; + default: + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.UpdateConflicts(context: context).Text)); + } + break; + default: + return ApiResults.Error( + context: context, + errorData: errorData); + } + } + } + else + { + issueModel.IssueId = 0; + issueModel.Ver = 1; + var errorData = issueModel.Create( + context: context, + ss: ss, + extendedSqls: false); + switch (errorData.Type) + { + case Error.Types.None: + break; + case Error.Types.Duplicated: + var duplicatedColumn = ss.GetColumn( + context: context, + columnName: errorData.ColumnName); + return ApiResults.Duplicated( + context: context, + message: duplicatedColumn?.MessageWhenDuplicated.IsNullOrEmpty() != false + ? Displays.Duplicated( + context: context, + data: duplicatedColumn?.LabelText) + : duplicatedColumn?.MessageWhenDuplicated); + default: + return ApiResults.Error( + context: context, + errorData: errorData); + } + insertCount++; + } + } + ImportUtilities.SetOnImportedExtendedSqls(context, ss); + ss.Notifications.ForEach(notification => + { + var body = new System.Text.StringBuilder(); + body.Append(Locations.ItemIndexAbsoluteUri( + context: context, + ss.SiteId) + "\n"); + body.Append( + $"{Displays.Issues_Updator(context: context)}: ", + $"{context.User.Name}\n"); + if (notification.AfterImport != false) + { + notification.Send( + context: context, + ss: ss, + title: Displays.Imported( + context: context, + data: new string[] + { + ss.Title, + insertCount.ToString(), + updateCount.ToString() + }), + body: body.ToString()); + } + }); + return ApiResults.Success( + id: context.Id, + limitPerDate: context.ContractSettings.ApiLimit(), + limitRemaining: context.ContractSettings.ApiLimit() - ss.ApiCount, + message: Messages.Imported( + context: context, + data: new string[] + { + ss.Title, + insertCount.ToString(), + updateCount.ToString() + }).Text); + } + else + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.FileNotFound(context: context).Text)); + } + } + public static string OpenExportSelectorDialog( Context context, SiteSettings ss, SiteModel siteModel) { diff --git a/Implem.Pleasanter/Models/Items/ItemModel.cs b/Implem.Pleasanter/Models/Items/ItemModel.cs index 67308d3c3..ffcb32065 100644 --- a/Implem.Pleasanter/Models/Items/ItemModel.cs +++ b/Implem.Pleasanter/Models/Items/ItemModel.cs @@ -211,6 +211,46 @@ public ContentResultInheritance ExportByApi(Context context) return ApiResults.Get(ApiResponses.BadRequest(context: context)); } + public ContentResultInheritance ImportByApi(Context context) + { + SetSite( + context: context, + initSiteSettings: true, + setSiteIntegration: true, + setAllChoices: true); + if (!Site.WithinApiLimits(context: context)) + { + return ApiResults.Get(ApiResponses.OverLimitApi( + context: context, + siteId: Site.SiteId, + limitPerSite: context.ContractSettings.ApiLimit())); + } + switch (Site.ReferenceType) + { + case "Issues": + if (SiteId == ReferenceId) + { + return IssueUtilities.ImportByApi( + context: context, + ss: Site.SiteSettings, + siteModel: Site); + } + break; + case "Results": + if (SiteId == ReferenceId) + { + return ResultUtilities.ImportByApi( + context: context, + ss: Site.SiteSettings, + siteModel: Site); + } + break; + default: + return ApiResults.Get(ApiResponses.BadRequest(context: context)); + } + return ApiResults.Get(ApiResponses.BadRequest(context: context)); + } + public string Index(Context context) { if (ReferenceId == 0) diff --git a/Implem.Pleasanter/Models/Results/ResultUtilities.cs b/Implem.Pleasanter/Models/Results/ResultUtilities.cs index c549b3c23..8b7757d80 100644 --- a/Implem.Pleasanter/Models/Results/ResultUtilities.cs +++ b/Implem.Pleasanter/Models/Results/ResultUtilities.cs @@ -6121,14 +6121,7 @@ public static string Import(Context context, SiteModel siteModel) } var invalidColumn = Imports.ColumnValidate(context, ss, columnHash.Values.Select(o => o.Column.ColumnName)); if (invalidColumn != null) return invalidColumn; - Repository.ExecuteNonQuery( - context: context, - transactional: true, - statements: new List() - .OnImportingExtendedSqls( - context: context, - siteId: ss.SiteId) - .ToArray()); + ImportUtilities.SetOnImportingExtendedSqls(context, ss); var resultHash = new Dictionary(); var importKeyColumnName = context.Forms.Data("Key"); var importKeyColumn = columnHash @@ -6322,14 +6315,7 @@ public static string Import(Context context, SiteModel siteModel) insertCount++; } } - Repository.ExecuteNonQuery( - context: context, - transactional: true, - statements: new List() - .OnImportedExtendedSqls( - context: context, - siteId: ss.SiteId) - .ToArray()); + ImportUtilities.SetOnImportedExtendedSqls(context, ss); ss.Notifications.ForEach(notification => { var body = new System.Text.StringBuilder(); @@ -6374,6 +6360,324 @@ public static string Import(Context context, SiteModel siteModel) } } + public static ContentResultInheritance ImportByApi( + Context context, + SiteSettings ss, + SiteModel siteModel) + { + if (!Mime.ValidateOnApi(contentType: context.ContentType, multipart: true)) + { + return ApiResults.BadRequest(context: context); + } + if (context.ContractSettings.Import == false) + { + return null; + } + var invalid = ResultValidators.OnImporting( + context: context, + ss: ss, + api: true); + switch (invalid.Type) + { + case Error.Types.None: break; + default:return ApiResults.Error( + context: context, + errorData: invalid); + } + var api = context.RequestDataString.Deserialize(); + var updatableImport = api.UpdatableImport; + var encoding = api.Encoding; + var key = api.Key; + Csv csv; + try + { + csv = new Csv( + csv: context.PostedFiles.FirstOrDefault().Byte(), + encoding: encoding); + } + catch + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.FailedReadFile(context: context).Text)); + } + var count = csv.Rows.Count(); + if (Parameters.General.ImportMax > 0 && Parameters.General.ImportMax < count) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Error.Types.ImportMax.Message( + context: context, + data: Parameters.General.ImportMax.ToString()).Text)); + } + if (context.ContractSettings.ItemsLimit( + context: context, + siteId: ss.SiteId, + number: count)) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Error.Types.ItemsLimit.Message(context: context).Text)); + } + if (csv != null && count > 0) + { + var columnHash = ImportUtilities.GetColumnHash(ss, csv); + var idColumn = columnHash + .Where(o => o.Value.Column.ColumnName == "ResultId") + .Select(o => new { Id = o.Key }) + .FirstOrDefault()?.Id ?? -1; + if (updatableImport && idColumn > -1) + { + var exists = ExistsLockedRecord( + context: context, + ss: ss, + targets: csv.Rows.Select(o => o[idColumn].ToLong()).ToList()); + switch (exists.Type) + { + case Error.Types.None: break; + default: return ApiResults.Error( + context: context, + errorData: exists); + } + } + var invalidColumn = Imports.ColumnValidate(context, ss, columnHash.Values.Select(o => o.Column.ColumnName)); + if (invalidColumn != null) return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: invalidColumn)); + ImportUtilities.SetOnImportingExtendedSqls(context, ss); + var resultHash = new Dictionary(); + var importKeyColumnName = key; + var importKeyColumn = columnHash + .FirstOrDefault(column => column.Value.Column.ColumnName == importKeyColumnName); + if (updatableImport && importKeyColumn.Value == null) + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.NotContainKeyColumn(context: context).Text)); + } + var csvRows = csv.Rows + .Select((o, i) => new { Index = i, Row = o }) + .ToDictionary(o => o.Index, o => o.Row); + foreach (var data in csvRows) + { + var resultModel = new ResultModel( + context: context, + ss: ss); + if (updatableImport + && !data.Value[importKeyColumn.Key].IsNullOrEmpty()) + { + var view = new View(); + view.AddColumnFilterHash( + context: context, + ss: ss, + column: importKeyColumn.Value.Column, + objectValue: data.Value[importKeyColumn.Key]); + view.AddColumnFilterSearchTypes( + columnName: importKeyColumnName, + searchType: Column.SearchTypes.ExactMatch); + var model = new ResultModel( + context: context, + ss: ss, + resultId: 0, + view: view); + if (model.AccessStatus == Databases.AccessStatuses.Selected) + { + resultModel = model; + } + else if (model.AccessStatus == Databases.AccessStatuses.Overlap) + { + return ApiResults.Error( + context: context, + errorData: new ErrorData( + type: Error.Types.OverlapCsvImport, + data: new string[] { + (data.Key + 1).ToString(), + importKeyColumn.Value.Column.GridLabelText, + data.Value[importKeyColumn.Key]})); + } + } + resultModel.SetByCsvRow( + context: context, + ss: ss, + columnHash: columnHash, + row: data.Value); + resultHash.Add(data.Key, resultModel); + } + var inputErrorData = ResultValidators.OnInputValidating( + context: context, + ss: ss, + resultHash: resultHash).FirstOrDefault(); + switch (inputErrorData.Type) + { + case Error.Types.None: break; + default: return ApiResults.Error( + context: context, + errorData: inputErrorData); + } + var insertCount = 0; + var updateCount = 0; + foreach (var data in resultHash) + { + var resultModel = data.Value; + if (resultModel.AccessStatus == Databases.AccessStatuses.Selected) + { + ErrorData errorData = null; + while (errorData?.Type != Error.Types.None) + { + switch (errorData?.Type) + { + case Error.Types.Duplicated: + var duplicatedColumn = ss.GetColumn( + context: context, + columnName: errorData.ColumnName); + return ApiResults.Duplicated( + context: context, + message: duplicatedColumn?.MessageWhenDuplicated.IsNullOrEmpty() != false + ? Displays.Duplicated( + context: context, + data: duplicatedColumn?.LabelText) + : duplicatedColumn?.MessageWhenDuplicated); + case null: + case Error.Types.UpdateConflicts: + resultModel = new ResultModel( + context: context, + ss: ss, + resultId: resultModel.ResultId); + var previousTitle = resultModel.Title.DisplayValue; + resultModel.SetByCsvRow( + context: context, + ss: ss, + columnHash: columnHash, + row: csvRows.Get(data.Key)); + switch (resultModel.AccessStatus) + { + case Databases.AccessStatuses.Selected: + if (resultModel.Updated(context: context)) + { + resultModel.VerUp = Versions.MustVerUp( + context: context, + ss: ss, + baseModel: resultModel); + errorData = resultModel.Update( + context: context, + ss: ss, + extendedSqls: false, + previousTitle: previousTitle, + get: false); + updateCount++; + } + else + { + errorData = new ErrorData(type: Error.Types.None); + } + break; + case Databases.AccessStatuses.NotFound: + resultModel.ResultId = 0; + resultModel.Ver = 1; + errorData = resultModel.Create( + context: context, + ss: ss, + extendedSqls: false); + insertCount++; + break; + default: + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.UpdateConflicts(context: context).Text)); + } + break; + default: + return ApiResults.Error( + context: context, + errorData: errorData); + } + } + } + else + { + resultModel.ResultId = 0; + resultModel.Ver = 1; + var errorData = resultModel.Create( + context: context, + ss: ss, + extendedSqls: false); + switch (errorData.Type) + { + case Error.Types.None: + break; + case Error.Types.Duplicated: + var duplicatedColumn = ss.GetColumn( + context: context, + columnName: errorData.ColumnName); + return ApiResults.Duplicated( + context: context, + message: duplicatedColumn?.MessageWhenDuplicated.IsNullOrEmpty() != false + ? Displays.Duplicated( + context: context, + data: duplicatedColumn?.LabelText) + : duplicatedColumn?.MessageWhenDuplicated); + default: + return ApiResults.Error( + context: context, + errorData: errorData); + } + insertCount++; + } + } + ImportUtilities.SetOnImportedExtendedSqls(context, ss); + ss.Notifications.ForEach(notification => + { + var body = new System.Text.StringBuilder(); + body.Append(Locations.ItemIndexAbsoluteUri( + context: context, + ss.SiteId) + "\n"); + body.Append( + $"{Displays.Results_Updator(context: context)}: ", + $"{context.User.Name}\n"); + if (notification.AfterImport != false) + { + notification.Send( + context: context, + ss: ss, + title: Displays.Imported( + context: context, + data: new string[] + { + ss.Title, + insertCount.ToString(), + updateCount.ToString() + }), + body: body.ToString()); + } + }); + return ApiResults.Success( + id: context.Id, + limitPerDate: context.ContractSettings.ApiLimit(), + limitRemaining: context.ContractSettings.ApiLimit() - ss.ApiCount, + message: Messages.Imported( + context: context, + data: new string[] + { + ss.Title, + insertCount.ToString(), + updateCount.ToString() + }).Text); + } + else + { + return ApiResults.Get(new ApiResponse( + id: context.Id, + statusCode: 500, + message: Messages.FileNotFound(context: context).Text)); + } + } + public static string OpenExportSelectorDialog( Context context, SiteSettings ss, SiteModel siteModel) { diff --git a/Implem.Pleasanter/wwwroot/content/responsive.css b/Implem.Pleasanter/wwwroot/content/responsive.css index 18b46e9cb..5b1d8e0fd 100644 --- a/Implem.Pleasanter/wwwroot/content/responsive.css +++ b/Implem.Pleasanter/wwwroot/content/responsive.css @@ -62,11 +62,6 @@ margin: 10px 0px; float: left; } - @media screen and (max-width: 600px) and (min-width: 0px) { - #LoginFieldSet .field-wide { - min-height: 10vw !important; - } - } #StartGuide { display: none; } @@ -74,7 +69,7 @@ word-break: break-all; } div[role="dialog"] { - width: 100% !important; + width: 98% !important; z-index: 999; } #EnterPriseBanner, #SupportBanner, #CasesBanner { @@ -113,7 +108,10 @@ #ViewFilters>.field-auto-thin>.field-control { width: 100%;} #ViewFilters>.field-auto-thin>.field-label { width: 30%; text-align: left;} #ViewFilters>.field-auto-thin>.field-label+.field-control { width: 70%; } - .ui-multiselect { width: 98%!important; height: 6vw; } + .ui-multiselect { + width: 100% !important; + height: 6vw; + } .field-auto-thin input[type="checkbox"], .field-auto-thin input[type="radio"] { height: 2.6vw; width: 2.6vw; margin-right: 1vw; } @@ -156,8 +154,9 @@ .field-normal .control-text{ width: 100%; height: auto; padding: 1%; line-height: 1; } .control-textbox { height: auto; } -.ui-widget.ui-widget-content { background: #fff; font-size: 2.6vw; } - +.ui-widget.ui-widget-content { + font-size: 2.6vw; +} #Guide { font-size: 2.6vw; } .alert-success, @@ -171,14 +170,12 @@ .ui-tabs .ui-tabs-nav li { margin-bottom: 1%; padding-bottom: 0; -border:1px solid #111; -border-radius: 4px; + border-radius: 4px; } .ui-tabs .ui-tabs-nav li.ui-tabs-active { margin-bottom: 1%; padding-bottom: 0; -border:1px solid #111; -border-radius: 4px; + border-radius: 4px; } .message { bottom: 140px; } } @@ -188,7 +185,6 @@ border-radius: 4px; body { min-width: 320px!important; } #Header { height: auto; position: relative; } - #Header #Logo { padding-bottom: 2%; } #CorpLogo { float: none; width: 30%;} #MainContainer { min-height: 100vh; } @@ -239,16 +235,6 @@ transition: .5s; background: none; } -#Header .ui-widget-header{ -background: #f3f3f3; -color:#111; -} - -.ui-widget-header{ -background: #817865; -color:#fff; -} - #NavigationMenu { float: none; margin-right: 0; @@ -261,32 +247,28 @@ color:#fff; color: #000; } -#NavigationMenu>li { -width: 100%; -height: auto; -display: block; -float: none; -position: relative; -color:#333; -} - -#NavigationMenu>li>div { -height: auto; -text-align: left; -line-height: 7vw; -color: #333; -font-weight: bold; -} - -#NavigationMenu>li>div:hover { background:none;} - -#NavigationMenu>li>div>a { -height: auto; -display: block; -color: #333; -text-decoration: none; -font-weight: bold; -} + #NavigationMenu > li { + width: 100%; + height: auto; + display: block; + float: none; + position: relative; + } + #NavigationMenu > li > div { + height: auto; + text-align: left; + line-height: 7vw; + font-weight: bold; + } + #NavigationMenu > li > div:hover { + background: none; + } + #NavigationMenu > li > div > a { + height: auto; + display: block; + text-decoration: none; + font-weight: bold; + } #NavigationMenu .menu { width: 100%; @@ -306,13 +288,6 @@ font-weight: normal; text-decoration: none; } -.ui-widget.ui-widget-content { -} - -.ui-widget-content { -color: #333; -} - .ui-menu .ui-menu-item { border-top: 1px solid #d19405; } @@ -332,8 +307,6 @@ border: 1px solid #d19405; width: 20vw; height: 20vw; text-align: center; -background-color: white; -border: solid 2px silver; border-radius: 0.5vw; float: none; margin: 6%; @@ -350,7 +323,6 @@ margin: 6%; width: 20vw!important; height: 20vw!important; background: #fff; -border: solid 2px #ffa500; border-radius: 5px;} @@ -358,8 +330,6 @@ border-radius: 5px;} width: 8vw; height: 3vw; top: -3vw; -background-color: #f8da4c; -border: solid 2px #ffa500; } #SiteMenu .nav-site.sites.to-parent{ @@ -615,18 +585,1056 @@ overflow: hidden; #KambanBody .grid>tbody td { min-width: 10vw; white-space: nowrap; } } -@media screen and (min-width: 981px) { +@media screen and (max-width: 980px) and (min-width: 0px) { + #Header { + padding: 0 calc(5vw); + } + #Header a#navtgl { + right: 5vw; + } + #Application, + #Footer { + padding-left: 5vw; + padding-right: 5vw; + } + #SiteMenu .nav-site { + margin: 5%; + } + :not(td) > div.field-control .container-normal { + margin-left: 0; + } + * { + line-height: 1.4; + } + .field-normal .control-textbox, + .field-normal .control-dropdown, + .field-normal .control-text, .field-control .control-textbox, + .field-control .control-dropdown, + .field-control .control-text, .container-normal .control-textbox, + .container-normal .control-dropdown, + .container-normal .control-text { + min-height: unset; + height: 6vw; + line-height: 6vw; + padding-top: 0; + padding-bottom: 0; + } + body { + font-size: 16px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #HeaderTitle { + font-size: 16px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .command-center { + padding: 0; + } + .ui-dialog .ui-dialog-titlebar-close { + top: 0; + bottom: 0; + width: 5vw; + height: 5vw; + margin: auto 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewSelector { + font-size: 2.6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Logo a { + align-items: center; + display: flex; + } + #Logo #ProductLogo { + font-size: 18px; + padding-left: 8px; + } + #CorpLogo { + float: none; + height: calc(8vw + 10px); + width: unset; + margin-top: 0; + } +} -.grid>thead>tr:first-child>th:first-child {width: 20px;} -#CrosstabBody .grid>thead>tr:first-child>th:first-child, -#KambanBody .grid>thead>tr:first-child>th:first-child {width: auto;} +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor .field-control .container-normal { + width: calc(100% - 20px); + } + #Editor .field-control .ui-icon.ui-icon-clock.current-time { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + top: calc(3vw - 3.5px); + right: -16px; + } + #Editor .field-control .ui-icon.ui-icon-person.current-user { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + top: calc(3vw - 3.5px); + right: -16px; + } +} -.grid>thead>tr:first-child>th:not(:first-child) { white-space: nowrap; } -#CrosstabBody .grid>thead>tr:first-child>th:not(:first-child), -#KambanBody .grid>thead>tr:first-child>th:not(:first-child) { white-space: inherit; } +@media screen and (max-width: 980px) and (min-width: 0px) { + #FieldSetAddressBook #OutgoingMailDestinationForm .container-left { + width: 38vw; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right .command-left { + float: unset; + padding: 0; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right .command-left button { + margin: 2px; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right .container-selectable .wrapper { + height: 40vw; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right > * { + margin-left: 40vw; + } +} -.grid>tbody>tr td:not(:first-child) {white-space: nowrap; min-width: 40px;} -#CrosstabBody .grid>tbody>tr td:not(:first-child), -#KambanBody .grid>tbody>tr td:not(:first-child) { white-space: inherit; min-width:auto; } +@media screen and (max-width: 980px) and (min-width: 0px) { + #Issues_WorkValue { + width: 100px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + body::before { + content: ''; + position: fixed; + width: 5vw; + height: 50vh; + top: 0; + left: 0; + background: white; + z-index: 200; + } + body::after { + content: ''; + position: fixed; + width: 5vw; + height: 50vh; + top: 0; + right: 0; + background: white; + z-index: 700; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Users_LoginId, + #Users_Password { + height: 40px; + } + #LoginMessage span { + font-size: 3.5vw; + } + #PortalLink { + font-size: 3.5vw; + top: 3vw; + } + #LoginFieldSet { + margin: 65px auto 20px auto; + } + #LoginFieldSet input[type=checkbox] { + margin: auto 0; + margin-left: 1.2vw; + } + #LoginFieldSet button { + margin-top: 0; + } + #LoginFieldSet .field-wide, + #LoginFieldSet .field-normal { + margin: 0px 0px; + } + #LoginFieldSet .field-normal .control-checkbox + label { + margin: auto 0; + margin-left: 4vw; + padding: 0; + } + #Logins .field-label { + width: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor .field-markdown > .field-label > label { + font-weight: bold; + } + #Editor .field-control .unit { + font-size: 2.6vw; + padding-top: calc((18px - 1.4em) / 2); + } + #Editor .ui-spinner .control-spinner { + height: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #GridCheckAll { + margin-top: 0; + } + label[for="GridCheckAll"] { + margin: 0; + } + #Footer { + font-size: 2.8vw; + height: auto; + } + #MainCommandsContainer { + bottom: calc(2.8vw * 1.4 + 10px); + } + body > thead > tr { + font-size: 0.75em; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #SiteImageSettingsEditor .field-auto-thin, #GridSettingsEditor .field-auto-thin, #FiltersSettingsEditor .field-auto-thin, #EditorSettingsEditor .field-auto-thin, + #LinksSettingsEditor .field-auto-thin, #HistoriesSettingsEditor .field-auto-thin, #FormulasSettingsEditor .field-auto-thin, #ViewsSettingsEditor .field-auto-thin, + #ImportsSettingsEditor .field-auto-thin, #ExportsSettingsEditor .field-auto-thin, #CalendarSettingsEditor .field-auto-thin, #CrosstabSettingsEditor .field-auto-thin, + #GanttSettingsEditor .field-auto-thin, #BurnDownSettingsEditor .field-auto-thin, #TimeSeriesSettingsEditor .field-auto-thin, #KambanSettingsEditor .field-auto-thin, + #ImageLibSettingsEditor .field-auto-thin, #SearchSettingsEditor .field-auto-thin, #StylesSettingsEditor .field-auto-thin, #ScriptsSettingsEditor .field-auto-thin, + #PublishSettingsEditor .field-auto-thin, #FieldSetSiteAccessControl .field-auto-thin { + padding-right: 0; + height: auto; + display: flex; + align-items: center; + clear: both; + } + #SiteImageSettingsEditor .field-auto-thin .container-normal, #GridSettingsEditor .field-auto-thin .container-normal, #FiltersSettingsEditor .field-auto-thin .container-normal, #EditorSettingsEditor .field-auto-thin .container-normal, + #LinksSettingsEditor .field-auto-thin .container-normal, #HistoriesSettingsEditor .field-auto-thin .container-normal, #FormulasSettingsEditor .field-auto-thin .container-normal, #ViewsSettingsEditor .field-auto-thin .container-normal, + #ImportsSettingsEditor .field-auto-thin .container-normal, #ExportsSettingsEditor .field-auto-thin .container-normal, #CalendarSettingsEditor .field-auto-thin .container-normal, #CrosstabSettingsEditor .field-auto-thin .container-normal, + #GanttSettingsEditor .field-auto-thin .container-normal, #BurnDownSettingsEditor .field-auto-thin .container-normal, #TimeSeriesSettingsEditor .field-auto-thin .container-normal, #KambanSettingsEditor .field-auto-thin .container-normal, + #ImageLibSettingsEditor .field-auto-thin .container-normal, #SearchSettingsEditor .field-auto-thin .container-normal, #StylesSettingsEditor .field-auto-thin .container-normal, #ScriptsSettingsEditor .field-auto-thin .container-normal, + #PublishSettingsEditor .field-auto-thin .container-normal, #FieldSetSiteAccessControl .field-auto-thin .container-normal { + width: 100%; + } + #SiteImageSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #GridSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #FiltersSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #EditorSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #LinksSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #HistoriesSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #FormulasSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #ViewsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #ImportsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #ExportsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #CalendarSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #CrosstabSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #GanttSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #BurnDownSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #TimeSeriesSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #KambanSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #ImageLibSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #SearchSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #StylesSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #ScriptsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #PublishSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #FieldSetSiteAccessControl .field-auto-thin .container-normal .control-checkbox ~ label { + display: unset; + float: unset; + width: auto; + } + #SiteImageSettingsEditor .field-auto-thin .field-label ~ .field-control, #GridSettingsEditor .field-auto-thin .field-label ~ .field-control, #FiltersSettingsEditor .field-auto-thin .field-label ~ .field-control, #EditorSettingsEditor .field-auto-thin .field-label ~ .field-control, + #LinksSettingsEditor .field-auto-thin .field-label ~ .field-control, #HistoriesSettingsEditor .field-auto-thin .field-label ~ .field-control, #FormulasSettingsEditor .field-auto-thin .field-label ~ .field-control, #ViewsSettingsEditor .field-auto-thin .field-label ~ .field-control, + #ImportsSettingsEditor .field-auto-thin .field-label ~ .field-control, #ExportsSettingsEditor .field-auto-thin .field-label ~ .field-control, #CalendarSettingsEditor .field-auto-thin .field-label ~ .field-control, #CrosstabSettingsEditor .field-auto-thin .field-label ~ .field-control, + #GanttSettingsEditor .field-auto-thin .field-label ~ .field-control, #BurnDownSettingsEditor .field-auto-thin .field-label ~ .field-control, #TimeSeriesSettingsEditor .field-auto-thin .field-label ~ .field-control, #KambanSettingsEditor .field-auto-thin .field-label ~ .field-control, + #ImageLibSettingsEditor .field-auto-thin .field-label ~ .field-control, #SearchSettingsEditor .field-auto-thin .field-label ~ .field-control, #StylesSettingsEditor .field-auto-thin .field-label ~ .field-control, #ScriptsSettingsEditor .field-auto-thin .field-label ~ .field-control, + #PublishSettingsEditor .field-auto-thin .field-label ~ .field-control, #FieldSetSiteAccessControl .field-auto-thin .field-label ~ .field-control { + margin-left: 10px; + } + #SiteImageSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #GridSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #FiltersSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #EditorSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #LinksSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #HistoriesSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #FormulasSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #ViewsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #ImportsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #ExportsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #CalendarSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #CrosstabSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #GanttSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #BurnDownSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #TimeSeriesSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #KambanSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #ImageLibSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #SearchSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #StylesSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #ScriptsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #PublishSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #FieldSetSiteAccessControl .field-auto-thin .field-label ~ .field-control .container-normal { + width: 100%; + } + #FieldSetGeneral .field-control .container-normal .control-checkbox ~ label { + width: auto; + } + #GridSettingsEditor #GridEditorType { + max-width: unset; + } + #SiteImageSettingsEditor #SiteImage { + width: 100%; + height: 7vw; + } + #SiteImageSettingsEditor #SetSiteImage { + margin-right: 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Aggregations { + display: flex; + flex-wrap: wrap; + row-gap: 5px; + justify-content: flex-start; + align-items: center; + } + #Aggregations span.label { + flex: 1 0 auto; + margin: 0; + text-align: center; + align-self: stretch; + display: flex; + align-items: center; + justify-content: flex-start; + } + #Aggregations span.data { + flex: 1 0 auto; + margin: 0; + align-self: stretch; + display: flex; + align-items: center; + justify-content: flex-start; + height: auto; + } + #Aggregations span.data.no-choice { + flex-basis: auto; + align-self: stretch; + } + #Aggregations span.data.link span { + font-weight: bold; + } + #Aggregations #ReduceAggregations { + width: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .grid { + vertical-align: middle; + } + #ViewModeContainer .grid tr td:first-child { + padding: 6px; + } + input[type='checkbox'], .field-auto-thin input[type='checkbox'] { + width: 3vw; + height: 3vw; + } + .field-auto-thin input[type='checkbox'] + label { + padding-top: 2px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #SearchField #Search { + font-size: 3vw; + width: 100%; + } + #SearchField #Search::placeholder { + font-size: 3vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewFilters #ViewFilters_Reset { + margin-left: auto; + margin-right: 0; + } + #ViewFilters .field-auto-thin { + width: 50%; + } + #ViewFilters .field-auto-thin .field-control .container-normal { + display: flex; + align-items: center; + } + #ViewFilters .field-auto-thin .field-control .container-normal input[type='checkbox'] { + margin-right: 4px; + margin-top: 1px; + } + #ViewFilters .field-auto-thin .field-control .container-normal .ui-widget.ui-state-default.ui-multiselect, #ViewFilters .field-auto-thin .field-control .container-normal .control-textbox { + height: 6vw; + font-size: 2.6vw; + } + #ViewFilters #ViewFilters_SearchField { + width: 100%; + } + #ViewFilters #ViewFilters_SearchField p.field-label { + width: 17%; + } + #ViewFilters #ViewFilters_SearchField .field-control { + width: 100%; + } + #ViewFilters > .field-auto-thin:nth-child(odd) { + padding-right: 2px; + } + #ViewFilters > .field-auto-thin:nth-child(even) { + padding-left: 2px; + } + .ui-multiselect-menu .ui-helper-reset { + position: relative; + } + .ui-multiselect-menu .ui-helper-reset li { + width: 100%; + } + .ui-multiselect-menu .ui-helper-reset li > label span { + position: relative; + top: -4px; + } + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-all, + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-none { + width: 100%; + display: flex; + align-items: center; + } + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-all span:last-child, + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-none span:last-child { + padding-left: 10px; + } + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-close { + position: absolute; + top: 8px; + right: 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorTabsContainer .legend.applied { + display: flex; + align-items: center; + font-weight: bold; + } + #EditorTabsContainer #PermissionEditor .field-vertical:first-child > .field-control { + border-bottom: 1px solid #d19405; + padding-bottom: 2vw; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left { + display: flex; + align-items: center; + flex-wrap: wrap; + width: 100%; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #SearchPermissionElements { + margin: 2px 1vw 2px 6vw; + height: 7vw; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left button { + align-self: stretch; + display: flex; + align-items: center; + justify-content: center; + white-space: nowrap; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left button .ui-icon { + position: relative; + top: 0.5vw; + width: 18px; + height: 18px; + margin-right: 0px; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #OpenPermissionsDialog, + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #DeletePermissions { + line-height: 1.5; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable #CurrentPermissionsWrapper { + min-height: 15vw; + } +} +@media screen and (max-width: 980px) and (min-width: 0px) { + thead > tr.ui-widget-header th div > span { + font-size: 2.8vw; + white-space: nowrap; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorTabsContainer .field-control .container-normal .ui-icon.ui-icon-pencil.button-edit-markdown { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + top: 8px; + right: 4px; + } + #EditorTabsContainer .field-control .container-normal .ui-icon.ui-icon-image.button-upload-image { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + position: relative; + left: -1px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorTabsContainer { + overflow: auto; + } + #EditorComments { + padding: 0; + margin: 0; + } + #EditorComments #CommentField .control-textarea { + height: 15vw; + } + #EditorComments #CommentField .control-textarea::placeholder { + font-size: 2.6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .is-showMenu { + overflow: hidden; + } + .is-showMenu body { + position: fixed; + overflow: hidden; + } + .bg-overlay { + background: rgba(0, 0, 0, 0.5); + position: fixed; + top: 0; + left: 0; + z-index: 301; + width: 100%; + height: 100%; + display: none; + } + #MainContainer { + overflow: hidden; + } + header#Header { + position: fixed; + top: 0; + z-index: 1000; + background-color: #fff; + transition: all 0.5s ease; + } + header#Header a#navtgl { + top: 8px; + z-index: 1000; + transition: all 0.5s ease; + } + header#Header a#navtgl::after { + transition: all 0.5s ease; + } + header#Header a#navtgl.on { + transition: all 0.5s ease; + position: fixed; + } + header#Header a#navtgl.on::before { + transition: all 0.5s ease; + border-top: none; + transform: translate(12.5%, 50%) rotate(50deg); + } + header#Header a#navtgl.on::after { + transition: all 0.5s ease; + transform: translate(12.5%, 0%) rotate(126deg); + } + #Navigations { + transition: all 0.5s ease; + max-height: 100vh; + height: 100vh; + position: absolute; + top: 0; + right: -1000px; + z-index: 999; + padding: 5%; + width: 70%; + padding-top: 112px; + opacity: 0; + } + #Navigations.open { + opacity: 1; + padding-top: 112px; + right: 0; + height: 100vh; + margin: 0; + position: fixed; + top: 0; + z-index: 1000; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #OutgoingMailsForm { + width: 100%; + font-size: 2.6vw; + } + #OutgoingMailsForm .item h3.title-header { + height: auto; + } + #OutgoingMailsForm .item .content { + padding: 0.2em; + margin: 0; + } + #OutgoingMailsForm .item .content .field-auto, + #OutgoingMailsForm .item .content .field-auto-thin { + width: 100%; + margin-right: 0; + padding-right: 0; + padding-bottom: 0; + display: flex; + flex-direction: column; + height: auto; + } + #OutgoingMailsForm .item .content .field-auto .field-label, + #OutgoingMailsForm .item .content .field-auto-thin .field-label { + float: none; + padding: 7px 7px 7px 0; + width: 100%; + text-align: left; + display: block; + } + #OutgoingMailsForm .item .content .field-auto .field-label label, + #OutgoingMailsForm .item .content .field-auto-thin .field-label label { + font-weight: bold; + } + #OutgoingMailsForm .item .content .field-auto .field-control, + #OutgoingMailsForm .item .content .field-auto-thin .field-control { + float: none; + width: 100%; + } + #OutgoingMailsForm .item .content .field-auto .field-control .container-normal, + #OutgoingMailsForm .item .content .field-auto-thin .field-control .container-normal { + margin-right: 0; + width: 100%; + } + #OutgoingMailsForm .item .content .field-auto .field-control .container-normal .control-text, + #OutgoingMailsForm .item .content .field-auto-thin .field-control .container-normal .control-text { + min-height: 0; + height: auto; + } + #OutgoingMailsForm .item .content .field-auto-thin { + margin-left: 0; + } + #OutgoingMailsForm .item .content .field-wide { + display: flex; + flex-direction: column; + padding: 0; + } + #OutgoingMailsForm .item .content .field-wide .field-label { + padding: 7px 0; + } + #OutgoingMailsForm .item .content .field-wide .field-control .container-normal { + margin-right: 0; + width: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #SiteMenu li.ui-sortable-handle { + touch-action: unset; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .message .close { + top: unset; + bottom: calc(50% - 8px); + margin: auto; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorComments #CommentField .ui-icon.ui-icon-image.button-upload-image { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + position: relative; + left: 0px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Navigations.open { + overflow-y: scroll; + } + #Navigations #NavigationMenu #NewMenuContainer { + background: unset; + border: none; + } + #Navigations #NavigationMenu #NewMenuContainer a { + line-height: 7vw; + } + #Navigations #NavigationMenu li.sub-menu .ui-menu-item .ui-menu-item-wrapper { + font-size: 3vw; + padding-left: 6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor .field-normal .field-control .container-normal input[type='checkbox'].control-checkbox { + position: relative; + margin-right: 6px; + margin-top: .3vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor #EditorTabsContainer .field-normal, #Editor #EditorTabsContainer .field-wide, #Editor #EditorTabsContainer .field-markdown { + display: inline-block; + margin-top: 8px; + padding-bottom: 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer #Calendar.both select { + font-size: 2.6vw; + } + #ViewModeContainer #Calendar.both .field-label { + min-width: 30%; + margin-right: 15px; + } + #ViewModeContainer #Calendar.both .field-auto-thin .field-control .container-normal { + display: flex; + align-items: center; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) { + flex: 0 1 calc(64%); + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) .field-label { + min-width: 22%; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) .field-control { + width: 74%; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) { + flex: 0 1 calc(33% + 1px); + padding-top: 2%; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) .field-control .container-normal { + justify-content: flex-end; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) .field-control .container-normal #CalendarDate { + margin-right: 0; + width: 98%; + font-size: 2.6vw; + } + #ViewModeContainer #Calendar.both button { + flex: 1 0 calc((100% / 3) - 32px); + margin: 2% 10px 2% 10px; + } + #ViewModeContainer .grid.fixed { + width: 100%; + } + #ViewModeContainer .grid.fixed tbody tr td.container .item { + touch-action: auto; + min-height: 50px; + } + #ViewModeContainer .grid.fixed tbody tr td.container .item .title .ui-icon.ui-icon-pencil { + margin-right: 5px; + background-image: url(""); + background-position: center; + width: 36px; + height: 36px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + } + #ViewModeContainer .grid.fixed tbody tr td.container .item .connection { + min-height: 50px; + } + #ViewModeContainer .grid.fixed tbody tr td.container .dummy { + height: 50px; + } + #ViewModeContainer .grid.fixed tbody tr td.container:first-child .item { + margin-top: 0; + margin-bottom: 5px; + } + #ViewModeContainer .grid.fixed tbody tr td.container:not(:first-child) .item { + margin-top: 5px; + } + thead th.calendar-header { + overflow-x: hidden; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .both { + column-gap: 16px; + } + #ViewModeContainer .both .field-auto-thin:first-child, #ViewModeContainer .both .field-auto-thin:nth-child(2) { + flex: 0 1 calc(50% - 8px); + } + #ViewModeContainer .both .field-auto-thin:first-child .field-control, #ViewModeContainer .both .field-auto-thin:nth-child(2) .field-control { + flex: 1; + } + #ViewModeContainer .both .field-auto-thin:first-child .field-control select, #ViewModeContainer .both .field-auto-thin:nth-child(2) .field-control select { + max-width: 100%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) { + row-gap: 12px; + flex-wrap: wrap; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) .field-label { + min-width: 15%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin { + display: flex; + align-items: center; + flex: 1 0 100%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin #GanttStartDate { + width: 100%; + font-size: 2.6vw; + margin-right: 0; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) button { + flex: 1; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) button:last-child { + margin-right: 8px; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) { + width: 100%; + padding-top: 12px; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control { + width: 100%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal { + width: 100%; + display: flex; + align-items: center; + column-gap: 32px; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal #GanttPeriod\,ui { + width: 99%; + margin-top: 0; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal #GanttPeriod { + margin: 0; + } + #GanttBody { + max-height: 70vh; + } + #GanttBody text { + font-size: 2.6vw; + } + #GanttBody .title text.summary { + font-size: 3vw; + } + #GanttBody #GanttAxis { + left: auto; + position: sticky; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer #Kamban.both .field-auto-thin select { + font-size: 2.6vw; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1), #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2), #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3), #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField { + width: 100%; + flex: 0 1 calc(50% - 8px); + flex-wrap: wrap; + display: flex; + row-gap: 0; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1) .field-label, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2) .field-label, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) .field-label, #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField .field-label { + width: 100%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1) select, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2) select, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) select, #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField select { + max-width: 100%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) { + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField { + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) { + display: block; + width: 100%; + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) .field-label { + min-width: 50%; + margin-right: 10px; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) select { + max-width: 100%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(6), #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(7) { + width: calc(50% - 8px); + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(6) .container-normal, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(7) .container-normal { + display: flex; + align-items: center; + } + #ViewModeContainer #Kamban.both #KambanBody #Grid tbody .kamban-row .kamban-container .kamban-item { + overflow: hidden; + padding: 6px 30px 6px 5px; + white-space: pre-line; + touch-action: auto; + display: -webkit-box; + -webkit-line-clamp: 1; + -webkit-box-orient: vertical; + } + #ViewModeContainer #Kamban.both #KambanBody #Grid tbody .kamban-row .kamban-container .kamban-item .ui-icon.ui-icon-pencil { + background-image: url(""); + background-position: center; + width: 36px; + height: 36px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + margin-right: 0; + top: -7px; + right: -11px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #RecordSwitchers { + display: flex; + align-items: center; + } + #RecordSwitchers #CurrentIndex { + height: 7.5vw; + display: flex; + align-items: center; + } +} + +@media screen and (max-width: 980px) and (min-width: 0) { + #Editor #RecordHeader .user { + display: flex; + align-items: center; + } + #Editor #RecordHeader .user .ui-icon-person { + margin-right: 0.6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #OutgoingMailDialog .field-wide { + padding-bottom: 5px; + } + #OutgoingMailDialog .field-wide .field-label { + width: auto; + } + #OutgoingMailDialog .field-wide .field-control { + float: none; + } + #OutgoingMailDialog .field-wide .control-basket, + #OutgoingMailDialog .field-wide .container-normal { + margin-left: 15vw; + } + #OutgoingMailDialog textarea { + height: 20vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .show-password { + top: calc(50% - 10px); + right: 10px; + } + #LoginFieldSet input[type=checkbox] { + transform: scale(1.2); + } + #LoginFieldSet input, + #LoginFieldSet select { + font-size: 4vw; + } + #Users_RememberMeField .container-normal { + display: flex; + align-items: center; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Navigations.open { + padding-top: 18vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .field-auto-thin > .field-label { + padding: 7px 2vw 7px 0; + } + #CrosstabValueField .field-control { + width: 70%; + } + #Crosstab .field-auto-thin p { + margin-right: 0%; + } + #ViewModeContainer #Crosstab .field-auto-thin { + width: 100%; + flex: 0 1 calc(100%); + padding-top: 1vw; + } + #ViewModeContainer #Crosstab .field-auto-thin .field-label { + width: 30%; + } + #ViewModeContainer #Crosstab .field-auto-thin .field-control { + width: 70%; + } + #ViewModeContainer #Crosstab .field-auto-thin .field-control input[type='checkbox'], + #ViewModeContainer #Crosstab .field-auto-thin .field-control .field-auto-thin input[type='checkbox'] { + width: 4vw; + height: 4vw; + margin-left: 2px; + } + #CrosstabBody .grid > thead > tr:first-child > th:not(:first-child), + #KambanBody .grid > thead > tr:first-child > th:not(:first-child) { + white-space: nowrap; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ImportSettingsDialog .control-checkbox + label { + margin: 1.8vw 0 0 1vw; + } + #ImportSettingsDialog .control-checkbox { + margin: 2vw 0 2vw 2px; + } + #ImportSettingsDialog .control-textbox { + height: 7vw; + line-height: 6.5vw; + } + #ImportSettingsDialog .command-center { + padding: 2vw 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ExportSelectorDialog .command-center { + padding: 2vw 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer #Grid .datepicker { + width: 35vw; + font-size: 4vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .both #TimeSeriesValueField, + #ViewModeContainer .both #TimeSeriesChartTypeField, + #ViewModeContainer .both #TimeSeriesHorizontalAxisField { + width: 100%; + } + #ViewModeContainer .both #TimeSeriesValueField .field-label, + #ViewModeContainer .both #TimeSeriesChartTypeField .field-label, + #ViewModeContainer .both #TimeSeriesHorizontalAxisField .field-label { + min-width: 30%; + } + #ViewModeContainer .both .field-auto-thin:first-child, + #ViewModeContainer .both .field-auto-thin:nth-child(2) { + flex: 0 1 calc(100%); + } + #ViewModeContainer .both .field-auto-thin:first-child .field-label, + #ViewModeContainer .both .field-auto-thin:nth-child(2) .field-label { + min-width: 30%; + } + #ViewModeContainer .both .field-auto-thin select { + max-width: 100%; + } + #ViewModeContainer .both .field-auto-thin > .field-control { + min-width: 68%; + } } \ No newline at end of file diff --git a/Implem.Pleasanter/wwwroot/content/responsive.min.css b/Implem.Pleasanter/wwwroot/content/responsive.min.css index 7376014e9..88f929d1f 100644 --- a/Implem.Pleasanter/wwwroot/content/responsive.min.css +++ b/Implem.Pleasanter/wwwroot/content/responsive.min.css @@ -1 +1 @@ -@media screen and (max-width:980px) and (min-width:0){#LoginFieldSet{width:100%;padding:10px;font-size:4vw}#LoginFieldSet input,#LoginFieldSet select{font-size:5vw;padding:10px}#LoginFieldSet input[type=checkbox]{transform:scale(2);margin:20px 0 0 10px}#LoginFieldSet button{font-size:4vw}#LoginFieldSet .container-normal{margin-left:0}#LoginFieldSet .field-wide,#LoginFieldSet .field-normal{width:100%;margin:10px 0;float:left}#LoginFieldSet .field-normal .control-checkbox+label{width:auto;margin:0 0 0 30px}#Logins .field-label{width:auto;padding:4px}#LoginMessage{width:100%}#Demo{width:100%;padding:10px;font-size:4vw}#DemoFields .field-label{width:auto;padding:4px}#DemoFields input{font-size:5vw;padding:10px}#DemoFields button{font-size:4vw;float:right;margin-top:10px}#DemoFields .container-normal{margin-left:0}#DemoFields .field-normal{width:100%;margin:10px 0;float:left}@media screen and (max-width:600px) and (min-width:0){#LoginFieldSet .field-wide{min-height:10vw !important}}#StartGuide{display:none}.container-normal>#ApiKey{word-break:break-all}div[role="dialog"]{width:100% !important;z-index:999}#EnterPriseBanner,#SupportBanner,#CasesBanner{display:none}#EditorTabsContainer>fieldset{display:contents}#EditorTabsContainer>fieldset>fieldset{display:contents}#TenantImage{width:100%}#Search{width:auto;height:auto}#Breadcrumb{display:none}#CopyToClipboards{display:none}#ViewSelectorField{position:relative;margin-bottom:5px;font-size:2.8vw}#HeaderTitleContainer{margin-bottom:3%}#ViewFilters{font-size:2.6vw;padding-bottom:2%}#Aggregations{font-size:2.6vw}#ViewFilters_Reset{float:none}#ViewFilters.reduced,#Aggregations.reduced{border-bottom:1px solid #aaa;margin-bottom:2%;padding:2%}#Aggregations .label{height:auto}#ViewFilters>.field-auto-thin{height:6vw;padding:0;margin:2% 0 0 0;line-height:1;width:49%;display:flex;justify-content:start;align-items:center}#ViewFilters>.field-auto-thin>.field-control{width:100%}#ViewFilters>.field-auto-thin>.field-label{width:30%;text-align:left}#ViewFilters>.field-auto-thin>.field-label+.field-control{width:70%}.ui-multiselect{width:98%!important;height:6vw}.field-auto-thin input[type="checkbox"],.field-auto-thin input[type="radio"]{height:2.6vw;width:2.6vw;margin-right:1vw}.control-checkbox{margin:0}.control-checkbox+label{margin:0}.field-auto-thin>.field-label{padding:0}#RecordInfo div{clear:both;margin-right:0}#RecordInfo div p{font-size:2.6vw}#Application{padding-bottom:15%}#MainForm{display:flex;flex-direction:column}#RecordInfo{margin-bottom:2%}#RecordSwitchers{font-size:2.6vw;width:100%}.ui-button,#RecordSwitchers .current{height:auto;padding:2%!important;line-height:1;margin-right:2%}#EditorComments{width:100%;order:3;font-size:2.6vw}#EditorTabsContainer{width:100%}.fieldset.ui-tabs-panel.ui-widget-content{font-size:2.6vw}.ui-tabs .ui-tabs-panel{padding:1%}.field-wide,.field-markdown{width:100%;min-height:5vw;float:none;padding:0 0 3% 0;clear:both}.field-normal{width:100%;height:auto;padding:0}.field-normal.right-align{text-align:left}.field-markdown>.field-label,.field-normal>.field-label,.field-wide>.field-label{width:100%;clear:both;margin-left:0;padding:1%;font-weight:bold;text-align:left;text-align-last:left}.field-normal>.field-label label,.field-wide>.field-label label{font-weight:bold}.field-normal .container-normal,.field-control .container-normal{margin-left:0}.control-dropdown{height:auto}.ui-spinner a.ui-spinner-button{height:50%}.field-normal .control-text{width:100%;height:auto;padding:1%;line-height:1}.control-textbox{height:auto}.ui-widget.ui-widget-content{background:#fff;font-size:2.6vw}#Guide{font-size:2.6vw}.alert-success,.alert-warning,.alert-error{height:auto;font-size:2.6vw}#MainCommandsContainer{height:auto;padding:2vw 0;font-size:2.6vw;z-index:200}#Footer{z-index:102}.ui-tabs .ui-tabs-nav{padding:1%;font-size:2.6vw}.ui-tabs .ui-tabs-nav li{margin-bottom:1%;padding-bottom:0;border:1px solid #111;border-radius:4px}.ui-tabs .ui-tabs-nav li.ui-tabs-active{margin-bottom:1%;padding-bottom:0;border:1px solid #111;border-radius:4px}.message{bottom:140px}}@media screen and (max-width:980px) and (min-width:0){body{min-width:320px!important}#Header{height:auto;position:relative}#Header #Logo{padding-bottom:2%}#CorpLogo{float:none;width:30%}#MainContainer{min-height:100vh}#Header a#navtgl{position:absolute;display:block;padding:1.6vw 1.4vw;border:.4vw solid #d19405;border-radius:1vw;top:1.4vw;right:4vw;height:8vw;width:8vw;z-index:101;background:#fece2f}#Header a#navtgl::before{content:'';display:block;height:1.3vw;border-top:.4vw solid #333;border-bottom:.4vw solid #333}#Header a#navtgl::after{content:'';display:block;height:1.4vw;border-bottom:.4vw solid #333}* #Navigations{box-sizing:border-box}#Navigations{width:100%;max-height:0;overflow:hidden;margin:0;padding:0 5%;border:none;position:relative;top:0;right:0;border-radius:0;z-index:100;font-size:3.2vw;line-height:7vw;transition:.5s}#Navigations.open{max-height:none;height:auto;overflow:visible;margin-top:2%;margin-bottom:5%;padding:5%;transition:.5s}#NavigationMenu>li.sub-menu>div.hover{background:none}#Header .ui-widget-header{background:#f3f3f3;color:#111}.ui-widget-header{background:#817865;color:#fff}#NavigationMenu{float:none;margin-right:0;margin-bottom:3%}#SearchField{float:none;margin:0;color:#000}#NavigationMenu>li{width:100%;height:auto;display:block;float:none;position:relative;color:#333}#NavigationMenu>li>div{height:auto;text-align:left;line-height:7vw;color:#333;font-weight:bold}#NavigationMenu>li>div:hover{background:none}#NavigationMenu>li>div>a{height:auto;display:block;color:#333;text-decoration:none;font-weight:bold}#NavigationMenu .menu{width:100%;border-top:none !important;position:relative;top:0;right:0;border-radius:0;z-index:3}.pc-dn{display:block!important}#NavigationMenu .menu>li>a.ui-state-active{font-weight:normal;text-decoration:none}.ui-widget-content{color:#333}.ui-menu .ui-menu-item{border-top:1px solid #d19405}#NewMenuContainer{border:1px solid #d19405;background:#fff}}@media screen and (max-width:980px) and (min-width:0){#SiteMenu .nav-site{width:20vw;height:20vw;text-align:center;background-color:#fff;border:solid 2px #c0c0c0;border-radius:.5vw;float:none;margin:6%}#SiteMenu .sortable{display:flex;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap}#SiteMenu .nav-site.sites{width:20vw!important;height:20vw!important;background:#fff;border:solid 2px #ffa500;border-radius:5px}#SiteMenu .nav-site .heading{width:8vw;height:3vw;top:-3vw;background-color:#f8da4c;border:solid 2px #ffa500}#SiteMenu .nav-site.sites.to-parent{height:auto!important;box-shadow:none;margin-top:3%;margin-bottom:0}#SiteMenu .nav-site.sites.to-parent span.title{position:relative;top:0;text-align:left;width:100%;margin-left:0}#SiteMenu .nav-site.sites.to-parent .heading{display:none}#SiteMenu .nav-site a{padding:0;overflow:inherit}#SiteMenu .nav-site .site-image-thumbnail{position:relative;top:inherit;left:inherit;max-width:inherit;border-radius:unset;width:90%;z-index:1;margin:0 auto;display:block}#SiteMenu .nav-site span.title::before{content:'';display:block;height:0}#SiteMenu .nav-site span.title{margin-left:0;font-size:14px}#SiteMenu .nav-site.has-image a{padding:1vw 0 0}#SiteMenu .nav-site .conditions{position:absolute;top:-2.4vw;right:-2.4vw;z-index:2}#SiteMenu .nav-site .conditions .elapsed-time{display:none}#SiteMenu .nav-site .conditions .count{display:none}#SiteMenu .nav-site .conditions .overdue{height:6vw;min-width:6vw;line-height:6vw;font-size:2.6vw;border-radius:3vw;font-weight:bold;padding:0}#SiteMenu .nav-site[data-type="Wikis"]{border-radius:2px;position:relative;width:20vw;border:2px solid #ccc}#SiteMenu .nav-site[data-type="Wikis"] a::before,#SiteMenu .nav-site[data-type="Wikis"] a::after{content:'';display:block;position:absolute;height:20%;width:80%;left:10%;border-top:2px solid #ccc;border-bottom:2px solid #ccc}#SiteMenu .nav-site[data-type="Wikis"] a::before{top:20%}#SiteMenu .nav-site[data-type="Wikis"] a::after{top:60%}#SiteMenu .nav-site[data-type="Wikis"] a img{margin-top:15%}#SiteMenu .nav-site.sites.to-parent{height:auto!important;border:none;background:none;text-align:left}#SiteMenu .nav-site.to-parent .ui-icon{display:none}#SiteMenu .nav-site.to-parent a{position:relative;display:inline-block;padding:0 0 0 16px;color:#000;vertical-align:middle;text-decoration:none;font-size:15px}#SiteMenu .nav-site.to-parent a::before,#SiteMenu .nav-site.to-parent a::after{position:absolute;top:0;bottom:0;left:0;margin:auto;content:"";vertical-align:middle}#SiteMenu .nav-site.to-parent a::before{left:5px;width:7px;height:3px;background:#7a0}#SiteMenu .nav-site.to-parent a::after{left:2px;width:6px;height:6px;border-bottom:3px solid #7a0;border-left:3px solid #7a0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}#SiteMenu .nav-site span.title{margin-left:0;font-size:2.6vw;top:22vw;position:absolute;display:block;text-align:center;width:140%;margin-left:-20%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#SiteMenu .nav-site .stacking1{width:20vw;height:20vw;border-bottom:solid 1px #c0c0c0;border-right:solid 1px #c0c0c0;position:absolute;top:1px;left:1px;border-radius:5px}#SiteMenu .nav-site .stacking2{width:20vw;height:20vw;border-bottom:solid 1px #c0c0c0;border-right:solid 1px #c0c0c0;position:absolute;top:4px;left:4px;border-radius:5px}#SiteMenu .nav-sites .to-parent a img{display:none}#SiteMenu .nav-site.to-parent.has-image a{padding:0 0 0 15px}}@media screen and (max-width:980px) and (min-width:0){#FieldSetStandard{display:flex;flex-direction:column}.legend{order:2}#StandardTemplatesViewer{order:3}.template-selectable{order:1;float:none}.template-viewer-container{float:none;margin:0}.template-viewer{margin:0}.template-selectable{width:100%}.template-tab-container{min-height:10px}.field-vertical{width:100%;float:none;padding:0 0 20px 0}.container-selectable .wrapper{min-height:auto}.h350{height:auto}#EditInDialogBody{padding-bottom:15%}.links{overflow:auto}@media screen and (max-width:980px) and (min-width:0){#FieldSetHistories{overflow:auto;width:100%}#ViewModeContainer{overflow:auto;width:100%;padding-top:1%}#CrosstabBody{overflow:auto;width:100%}#GanttBody{overflow:auto;width:100%;padding-top:5%}.grid{font-size:2.8vw;width:98%}.grid>thead th{min-width:10vw;white-space:nowrap}.grid>tbody td{min-width:10vw;white-space:nowrap}.grid>thead th:nth-child(1),.grid>tbody td:nth-child(1){min-width:1vw}.grid>tbody td p{white-space:nowrap}#Calendar{font-size:2.6vw}#Calendar button{margin-bottom:2%}#CalendarBody #Grid thead{background:#fff}#CalendarMonth{display:block}#Calendar .field-auto-thin{display:flex;align-items:center;width:33%;margin:0;padding:0;margin-bottom:2%!important}#Calendar .field-auto-thin p{margin-right:1%}#Calendar .field-auto-thin select{max-width:none}#CalendarTimePeriod,#CalendarFromTo,#CalendarMonth{height:auto}#CalendarMonth{margin-bottom:2%}.w100{width:auto}#CrosstabBody{margin-top:3%}#CrosstabBody #Grid{table-layout:auto}#CrosstabBody .grid>thead>tr>th,#CrosstabBody .grid>tbody>tr>th{white-space:nowrap}#CrosstabBody .grid>thead th{min-width:10vw;white-space:nowrap}#CrosstabBody .grid>tbody td{min-width:10vw;white-space:nowrap}#Crosstab{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}#Crosstab .field-auto-thin{display:flex;align-items:center;width:48%;margin:0;padding:0;font-size:2.6vw}#Crosstab .field-auto-thin#CrosstabTimePeriodField{width:48%}#Crosstab .field-auto-thin p{width:100%;margin-right:2%;white-space:nowrap}#Crosstab .field-auto-thin select{max-width:none}#Crosstab #CrosstabMonth{width:48%;margin-top:2%;margin-right:0;font-size:2.6vw}#Crosstab button{font-size:2.6vw;margin-top:1%}.svg-crosstab{display:block}#ViewModeContainer .both{display:flex;align-items:center;flex-wrap:wrap}#ViewModeContainer .both .field-auto-thin{display:flex;align-items:center;width:48%;margin:0;padding:0;font-size:2.6vw;height:auto;padding-top:2%}#ViewModeContainer .both .field-auto-thin .field-auto-thin{width:30%}#ViewModeContainer .both .field-auto-thin:nth-child(3){width:100%}#ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin{width:48%;display:block}#ViewModeContainer .field-auto-thin p{margin-right:2%;white-space:nowrap;text-align:left}#GanttAxis{width:1500px;position:relative;left:0;bottom:0}#Gantt{width:1500px}#BurnDown{width:1500px}#TimeSeriesBody{padding-top:5%;margin-left:-5%;width:1500px}#TimeSeries{width:1500px}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3){width:48%}#ViewModeContainer #Kamban.both .field-auto-thin .field-control{width:100%}#KambanBody{margin-top:3%}#KambanBody #Grid{table-layout:auto}#KambanBody .grid>thead>tr>th,#KambanBody .grid>tbody>tr>th{white-space:nowrap}#KambanBody .grid>thead th{min-width:10vw;white-space:nowrap}#KambanBody .grid>tbody td{min-width:10vw;white-space:nowrap}}@media screen and (min-width:981px){.grid>thead>tr:first-child>th:first-child{width:20px}#CrosstabBody .grid>thead>tr:first-child>th:first-child,#KambanBody .grid>thead>tr:first-child>th:first-child{width:auto}.grid>thead>tr:first-child>th:not(:first-child){white-space:nowrap}#CrosstabBody .grid>thead>tr:first-child>th:not(:first-child),#KambanBody .grid>thead>tr:first-child>th:not(:first-child){white-space:inherit}.grid>tbody>tr td:not(:first-child){white-space:nowrap;min-width:40px}#CrosstabBody .grid>tbody>tr td:not(:first-child),#KambanBody .grid>tbody>tr td:not(:first-child){white-space:inherit;min-width:auto}} \ No newline at end of file +@media screen and (max-width:980px) and (min-width:0){#LoginFieldSet{width:100%;padding:10px;font-size:4vw}#LoginFieldSet input,#LoginFieldSet select{font-size:5vw;padding:10px}#LoginFieldSet input[type=checkbox]{transform:scale(2);margin:20px 0 0 10px}#LoginFieldSet button{font-size:4vw}#LoginFieldSet .container-normal{margin-left:0}#LoginFieldSet .field-wide,#LoginFieldSet .field-normal{width:100%;margin:10px 0;float:left}#LoginFieldSet .field-normal .control-checkbox+label{width:auto;margin:0 0 0 30px}#Logins .field-label{width:auto;padding:4px}#LoginMessage{width:100%}#Demo{width:100%;padding:10px;font-size:4vw}#DemoFields .field-label{width:auto;padding:4px}#DemoFields input{font-size:5vw;padding:10px}#DemoFields button{font-size:4vw;float:right;margin-top:10px}#DemoFields .container-normal{margin-left:0}#DemoFields .field-normal{width:100%;margin:10px 0;float:left}#StartGuide{display:none}.container-normal>#ApiKey{word-break:break-all}div[role="dialog"]{width:98% !important;z-index:999}#EnterPriseBanner,#SupportBanner,#CasesBanner{display:none}#EditorTabsContainer>fieldset{display:contents}#EditorTabsContainer>fieldset>fieldset{display:contents}#TenantImage{width:100%}#Search{width:auto;height:auto}#Breadcrumb{display:none}#CopyToClipboards{display:none}#ViewSelectorField{position:relative;margin-bottom:5px;font-size:2.8vw}#HeaderTitleContainer{margin-bottom:3%}#ViewFilters{font-size:2.6vw;padding-bottom:2%}#Aggregations{font-size:2.6vw}#ViewFilters_Reset{float:none}#ViewFilters.reduced,#Aggregations.reduced{border-bottom:1px solid #aaa;margin-bottom:2%;padding:2%}#Aggregations .label{height:auto}#ViewFilters>.field-auto-thin{height:6vw;padding:0;margin:2% 0 0 0;line-height:1;width:49%;display:flex;justify-content:start;align-items:center}#ViewFilters>.field-auto-thin>.field-control{width:100%}#ViewFilters>.field-auto-thin>.field-label{width:30%;text-align:left}#ViewFilters>.field-auto-thin>.field-label+.field-control{width:70%}.ui-multiselect{width:100% !important;height:6vw}.field-auto-thin input[type="checkbox"],.field-auto-thin input[type="radio"]{height:2.6vw;width:2.6vw;margin-right:1vw}.control-checkbox{margin:0}.control-checkbox+label{margin:0}.field-auto-thin>.field-label{padding:0}#RecordInfo div{clear:both;margin-right:0}#RecordInfo div p{font-size:2.6vw}#Application{padding-bottom:15%}#MainForm{display:flex;flex-direction:column}#RecordInfo{margin-bottom:2%}#RecordSwitchers{font-size:2.6vw;width:100%}.ui-button,#RecordSwitchers .current{height:auto;padding:2%!important;line-height:1;margin-right:2%}#EditorComments{width:100%;order:3;font-size:2.6vw}#EditorTabsContainer{width:100%}.fieldset.ui-tabs-panel.ui-widget-content{font-size:2.6vw}.ui-tabs .ui-tabs-panel{padding:1%}.field-wide,.field-markdown{width:100%;min-height:5vw;float:none;padding:0 0 3% 0;clear:both}.field-normal{width:100%;height:auto;padding:0}.field-normal.right-align{text-align:left}.field-markdown>.field-label,.field-normal>.field-label,.field-wide>.field-label{width:100%;clear:both;margin-left:0;padding:1%;font-weight:bold;text-align:left;text-align-last:left}.field-normal>.field-label label,.field-wide>.field-label label{font-weight:bold}.field-normal .container-normal,.field-control .container-normal{margin-left:0}.control-dropdown{height:auto}.ui-spinner a.ui-spinner-button{height:50%}.field-normal .control-text{width:100%;height:auto;padding:1%;line-height:1}.control-textbox{height:auto}.ui-widget.ui-widget-content{font-size:2.6vw}#Guide{font-size:2.6vw}.alert-success,.alert-warning,.alert-error{height:auto;font-size:2.6vw}#MainCommandsContainer{height:auto;padding:2vw 0;font-size:2.6vw;z-index:200}#Footer{z-index:102}.ui-tabs .ui-tabs-nav{padding:1%;font-size:2.6vw}.ui-tabs .ui-tabs-nav li{margin-bottom:1%;padding-bottom:0;border-radius:4px}.ui-tabs .ui-tabs-nav li.ui-tabs-active{margin-bottom:1%;padding-bottom:0;border-radius:4px}.message{bottom:140px}}@media screen and (max-width:980px) and (min-width:0){body{min-width:320px!important}#Header{height:auto;position:relative}#CorpLogo{float:none;width:30%}#MainContainer{min-height:100vh}#Header a#navtgl{position:absolute;display:block;padding:1.6vw 1.4vw;border:.4vw solid #d19405;border-radius:1vw;top:1.4vw;right:4vw;height:8vw;width:8vw;z-index:101;background:#fece2f}#Header a#navtgl::before{content:'';display:block;height:1.3vw;border-top:.4vw solid #333;border-bottom:.4vw solid #333}#Header a#navtgl::after{content:'';display:block;height:1.4vw;border-bottom:.4vw solid #333}* #Navigations{box-sizing:border-box}#Navigations{width:100%;max-height:0;overflow:hidden;margin:0;padding:0 5%;border:none;position:relative;top:0;right:0;border-radius:0;z-index:100;font-size:3.2vw;line-height:7vw;transition:.5s}#Navigations.open{max-height:none;height:auto;overflow:visible;margin-top:2%;margin-bottom:5%;padding:5%;transition:.5s}#NavigationMenu>li.sub-menu>div.hover{background:none}#NavigationMenu{float:none;margin-right:0;margin-bottom:3%}#SearchField{float:none;margin:0;color:#000}#NavigationMenu>li{width:100%;height:auto;display:block;float:none;position:relative}#NavigationMenu>li>div{height:auto;text-align:left;line-height:7vw;font-weight:bold}#NavigationMenu>li>div:hover{background:none}#NavigationMenu>li>div>a{height:auto;display:block;text-decoration:none;font-weight:bold}#NavigationMenu .menu{width:100%;border-top:none !important;position:relative;top:0;right:0;border-radius:0;z-index:3}.pc-dn{display:block!important}#NavigationMenu .menu>li>a.ui-state-active{font-weight:normal;text-decoration:none}.ui-menu .ui-menu-item{border-top:1px solid #d19405}#NewMenuContainer{border:1px solid #d19405;background:#fff}}@media screen and (max-width:980px) and (min-width:0){#SiteMenu .nav-site{width:20vw;height:20vw;text-align:center;border-radius:.5vw;float:none;margin:6%}#SiteMenu .sortable{display:flex;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap}#SiteMenu .nav-site.sites{width:20vw!important;height:20vw!important;background:#fff;border-radius:5px}#SiteMenu .nav-site .heading{width:8vw;height:3vw;top:-3vw}#SiteMenu .nav-site.sites.to-parent{height:auto!important;box-shadow:none;margin-top:3%;margin-bottom:0}#SiteMenu .nav-site.sites.to-parent span.title{position:relative;top:0;text-align:left;width:100%;margin-left:0}#SiteMenu .nav-site.sites.to-parent .heading{display:none}#SiteMenu .nav-site a{padding:0;overflow:inherit}#SiteMenu .nav-site .site-image-thumbnail{position:relative;top:inherit;left:inherit;max-width:inherit;border-radius:unset;width:90%;z-index:1;margin:0 auto;display:block}#SiteMenu .nav-site span.title::before{content:'';display:block;height:0}#SiteMenu .nav-site span.title{margin-left:0;font-size:14px}#SiteMenu .nav-site.has-image a{padding:1vw 0 0}#SiteMenu .nav-site .conditions{position:absolute;top:-2.4vw;right:-2.4vw;z-index:2}#SiteMenu .nav-site .conditions .elapsed-time{display:none}#SiteMenu .nav-site .conditions .count{display:none}#SiteMenu .nav-site .conditions .overdue{height:6vw;min-width:6vw;line-height:6vw;font-size:2.6vw;border-radius:3vw;font-weight:bold;padding:0}#SiteMenu .nav-site[data-type="Wikis"]{border-radius:2px;position:relative;width:20vw;border:2px solid #ccc}#SiteMenu .nav-site[data-type="Wikis"] a::before,#SiteMenu .nav-site[data-type="Wikis"] a::after{content:'';display:block;position:absolute;height:20%;width:80%;left:10%;border-top:2px solid #ccc;border-bottom:2px solid #ccc}#SiteMenu .nav-site[data-type="Wikis"] a::before{top:20%}#SiteMenu .nav-site[data-type="Wikis"] a::after{top:60%}#SiteMenu .nav-site[data-type="Wikis"] a img{margin-top:15%}#SiteMenu .nav-site.sites.to-parent{height:auto!important;border:none;background:none;text-align:left}#SiteMenu .nav-site.to-parent .ui-icon{display:none}#SiteMenu .nav-site.to-parent a{position:relative;display:inline-block;padding:0 0 0 16px;color:#000;vertical-align:middle;text-decoration:none;font-size:15px}#SiteMenu .nav-site.to-parent a::before,#SiteMenu .nav-site.to-parent a::after{position:absolute;top:0;bottom:0;left:0;margin:auto;content:"";vertical-align:middle}#SiteMenu .nav-site.to-parent a::before{left:5px;width:7px;height:3px;background:#7a0}#SiteMenu .nav-site.to-parent a::after{left:2px;width:6px;height:6px;border-bottom:3px solid #7a0;border-left:3px solid #7a0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}#SiteMenu .nav-site span.title{margin-left:0;font-size:2.6vw;top:22vw;position:absolute;display:block;text-align:center;width:140%;margin-left:-20%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#SiteMenu .nav-site .stacking1{width:20vw;height:20vw;border-bottom:solid 1px #c0c0c0;border-right:solid 1px #c0c0c0;position:absolute;top:1px;left:1px;border-radius:5px}#SiteMenu .nav-site .stacking2{width:20vw;height:20vw;border-bottom:solid 1px #c0c0c0;border-right:solid 1px #c0c0c0;position:absolute;top:4px;left:4px;border-radius:5px}#SiteMenu .nav-sites .to-parent a img{display:none}#SiteMenu .nav-site.to-parent.has-image a{padding:0 0 0 15px}}@media screen and (max-width:980px) and (min-width:0){#FieldSetStandard{display:flex;flex-direction:column}.legend{order:2}#StandardTemplatesViewer{order:3}.template-selectable{order:1;float:none}.template-viewer-container{float:none;margin:0}.template-viewer{margin:0}.template-selectable{width:100%}.template-tab-container{min-height:10px}.field-vertical{width:100%;float:none;padding:0 0 20px 0}.container-selectable .wrapper{min-height:auto}.h350{height:auto}#EditInDialogBody{padding-bottom:15%}.links{overflow:auto}@media screen and (max-width:980px) and (min-width:0){#FieldSetHistories{overflow:auto;width:100%}#ViewModeContainer{overflow:auto;width:100%;padding-top:1%}#CrosstabBody{overflow:auto;width:100%}#GanttBody{overflow:auto;width:100%;padding-top:5%}.grid{font-size:2.8vw;width:98%}.grid>thead th{min-width:10vw;white-space:nowrap}.grid>tbody td{min-width:10vw;white-space:nowrap}.grid>thead th:nth-child(1),.grid>tbody td:nth-child(1){min-width:1vw}.grid>tbody td p{white-space:nowrap}#Calendar{font-size:2.6vw}#Calendar button{margin-bottom:2%}#CalendarBody #Grid thead{background:#fff}#CalendarMonth{display:block}#Calendar .field-auto-thin{display:flex;align-items:center;width:33%;margin:0;padding:0;margin-bottom:2%!important}#Calendar .field-auto-thin p{margin-right:1%}#Calendar .field-auto-thin select{max-width:none}#CalendarTimePeriod,#CalendarFromTo,#CalendarMonth{height:auto}#CalendarMonth{margin-bottom:2%}.w100{width:auto}#CrosstabBody{margin-top:3%}#CrosstabBody #Grid{table-layout:auto}#CrosstabBody .grid>thead>tr>th,#CrosstabBody .grid>tbody>tr>th{white-space:nowrap}#CrosstabBody .grid>thead th{min-width:10vw;white-space:nowrap}#CrosstabBody .grid>tbody td{min-width:10vw;white-space:nowrap}#Crosstab{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}#Crosstab .field-auto-thin{display:flex;align-items:center;width:48%;margin:0;padding:0;font-size:2.6vw}#Crosstab .field-auto-thin#CrosstabTimePeriodField{width:48%}#Crosstab .field-auto-thin p{width:100%;margin-right:2%;white-space:nowrap}#Crosstab .field-auto-thin select{max-width:none}#Crosstab #CrosstabMonth{width:48%;margin-top:2%;margin-right:0;font-size:2.6vw}#Crosstab button{font-size:2.6vw;margin-top:1%}.svg-crosstab{display:block}#ViewModeContainer .both{display:flex;align-items:center;flex-wrap:wrap}#ViewModeContainer .both .field-auto-thin{display:flex;align-items:center;width:48%;margin:0;padding:0;font-size:2.6vw;height:auto;padding-top:2%}#ViewModeContainer .both .field-auto-thin .field-auto-thin{width:30%}#ViewModeContainer .both .field-auto-thin:nth-child(3){width:100%}#ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin{width:48%;display:block}#ViewModeContainer .field-auto-thin p{margin-right:2%;white-space:nowrap;text-align:left}#GanttAxis{width:1500px;position:relative;left:0;bottom:0}#Gantt{width:1500px}#BurnDown{width:1500px}#TimeSeriesBody{padding-top:5%;margin-left:-5%;width:1500px}#TimeSeries{width:1500px}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3){width:48%}#ViewModeContainer #Kamban.both .field-auto-thin .field-control{width:100%}#KambanBody{margin-top:3%}#KambanBody #Grid{table-layout:auto}#KambanBody .grid>thead>tr>th,#KambanBody .grid>tbody>tr>th{white-space:nowrap}#KambanBody .grid>thead th{min-width:10vw;white-space:nowrap}#KambanBody .grid>tbody td{min-width:10vw;white-space:nowrap}}@media screen and (max-width:980px) and (min-width:0){#Header{padding:0 calc(5vw)}#Header a#navtgl{right:5vw}#Application,#Footer{padding-left:5vw;padding-right:5vw}#SiteMenu .nav-site{margin:5%}:not(td)>div.field-control .container-normal{margin-left:0}*{line-height:1.4}.field-normal .control-textbox,.field-normal .control-dropdown,.field-normal .control-text,.field-control .control-textbox,.field-control .control-dropdown,.field-control .control-text,.container-normal .control-textbox,.container-normal .control-dropdown,.container-normal .control-text{min-height:unset;height:6vw;line-height:6vw;padding-top:0;padding-bottom:0}body{font-size:16px}}@media screen and (max-width:980px) and (min-width:0){#HeaderTitle{font-size:16px}}@media screen and (max-width:980px) and (min-width:0){.command-center{padding:0}.ui-dialog .ui-dialog-titlebar-close{top:0;bottom:0;width:5vw;height:5vw;margin:auto 0}}@media screen and (max-width:980px) and (min-width:0){#ViewSelector{font-size:2.6vw}}@media screen and (max-width:980px) and (min-width:0){#Logo a{align-items:center;display:flex}#Logo #ProductLogo{font-size:18px;padding-left:8px}#CorpLogo{float:none;height:calc(8vw + 10px);width:unset;margin-top:0}}@media screen and (max-width:980px) and (min-width:0){#Editor .field-control .container-normal{width:calc(100% - 20px)}#Editor .field-control .ui-icon.ui-icon-clock.current-time{background-image:url("");background-position:center;width:12px;height:12px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%);top:calc(3vw - 3.5px);right:-16px}#Editor .field-control .ui-icon.ui-icon-person.current-user{background-image:url("");background-position:center;width:12px;height:12px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%);top:calc(3vw - 3.5px);right:-16px}}@media screen and (max-width:980px) and (min-width:0){#FieldSetAddressBook #OutgoingMailDestinationForm .container-left{width:38vw}#FieldSetAddressBook #OutgoingMailDestinationForm .container-right .command-left{float:unset;padding:0}#FieldSetAddressBook #OutgoingMailDestinationForm .container-right .command-left button{margin:2px}#FieldSetAddressBook #OutgoingMailDestinationForm .container-right .container-selectable .wrapper{height:40vw}#FieldSetAddressBook #OutgoingMailDestinationForm .container-right>*{margin-left:40vw}}@media screen and (max-width:980px) and (min-width:0){#Issues_WorkValue{width:100px}}@media screen and (max-width:980px) and (min-width:0){body::before{content:'';position:fixed;width:5vw;height:50vh;top:0;left:0;background:#fff;z-index:200}body::after{content:'';position:fixed;width:5vw;height:50vh;top:0;right:0;background:#fff;z-index:700}}@media screen and (max-width:980px) and (min-width:0){#Users_LoginId,#Users_Password{height:40px}#LoginMessage span{font-size:3.5vw}#PortalLink{font-size:3.5vw;top:3vw}#LoginFieldSet{margin:65px auto 20px auto}#LoginFieldSet input[type=checkbox]{margin:auto 0;margin-left:1.2vw}#LoginFieldSet button{margin-top:0}#LoginFieldSet .field-wide,#LoginFieldSet .field-normal{margin:0 0}#LoginFieldSet .field-normal .control-checkbox+label{margin:auto 0;margin-left:4vw;padding:0}#Logins .field-label{width:100%}}@media screen and (max-width:980px) and (min-width:0){#Editor .field-markdown>.field-label>label{font-weight:bold}#Editor .field-control .unit{font-size:2.6vw;padding-top:calc((18px - 1.4em)/2)}#Editor .ui-spinner .control-spinner{height:100%}}@media screen and (max-width:980px) and (min-width:0){#GridCheckAll{margin-top:0}label[for="GridCheckAll"]{margin:0}#Footer{font-size:2.8vw;height:auto}#MainCommandsContainer{bottom:calc(2.8vw*1.4 + 10px)}body>thead>tr{font-size:.75em}}@media screen and (max-width:980px) and (min-width:0){#SiteImageSettingsEditor .field-auto-thin,#GridSettingsEditor .field-auto-thin,#FiltersSettingsEditor .field-auto-thin,#EditorSettingsEditor .field-auto-thin,#LinksSettingsEditor .field-auto-thin,#HistoriesSettingsEditor .field-auto-thin,#FormulasSettingsEditor .field-auto-thin,#ViewsSettingsEditor .field-auto-thin,#ImportsSettingsEditor .field-auto-thin,#ExportsSettingsEditor .field-auto-thin,#CalendarSettingsEditor .field-auto-thin,#CrosstabSettingsEditor .field-auto-thin,#GanttSettingsEditor .field-auto-thin,#BurnDownSettingsEditor .field-auto-thin,#TimeSeriesSettingsEditor .field-auto-thin,#KambanSettingsEditor .field-auto-thin,#ImageLibSettingsEditor .field-auto-thin,#SearchSettingsEditor .field-auto-thin,#StylesSettingsEditor .field-auto-thin,#ScriptsSettingsEditor .field-auto-thin,#PublishSettingsEditor .field-auto-thin,#FieldSetSiteAccessControl .field-auto-thin{padding-right:0;height:auto;display:flex;align-items:center;clear:both}#SiteImageSettingsEditor .field-auto-thin .container-normal,#GridSettingsEditor .field-auto-thin .container-normal,#FiltersSettingsEditor .field-auto-thin .container-normal,#EditorSettingsEditor .field-auto-thin .container-normal,#LinksSettingsEditor .field-auto-thin .container-normal,#HistoriesSettingsEditor .field-auto-thin .container-normal,#FormulasSettingsEditor .field-auto-thin .container-normal,#ViewsSettingsEditor .field-auto-thin .container-normal,#ImportsSettingsEditor .field-auto-thin .container-normal,#ExportsSettingsEditor .field-auto-thin .container-normal,#CalendarSettingsEditor .field-auto-thin .container-normal,#CrosstabSettingsEditor .field-auto-thin .container-normal,#GanttSettingsEditor .field-auto-thin .container-normal,#BurnDownSettingsEditor .field-auto-thin .container-normal,#TimeSeriesSettingsEditor .field-auto-thin .container-normal,#KambanSettingsEditor .field-auto-thin .container-normal,#ImageLibSettingsEditor .field-auto-thin .container-normal,#SearchSettingsEditor .field-auto-thin .container-normal,#StylesSettingsEditor .field-auto-thin .container-normal,#ScriptsSettingsEditor .field-auto-thin .container-normal,#PublishSettingsEditor .field-auto-thin .container-normal,#FieldSetSiteAccessControl .field-auto-thin .container-normal{width:100%}#SiteImageSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#GridSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#FiltersSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#EditorSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#LinksSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#HistoriesSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#FormulasSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#ViewsSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#ImportsSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#ExportsSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#CalendarSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#CrosstabSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#GanttSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#BurnDownSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#TimeSeriesSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#KambanSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#ImageLibSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#SearchSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#StylesSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#ScriptsSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#PublishSettingsEditor .field-auto-thin .container-normal .control-checkbox~label,#FieldSetSiteAccessControl .field-auto-thin .container-normal .control-checkbox~label{display:unset;float:unset;width:auto}#SiteImageSettingsEditor .field-auto-thin .field-label~.field-control,#GridSettingsEditor .field-auto-thin .field-label~.field-control,#FiltersSettingsEditor .field-auto-thin .field-label~.field-control,#EditorSettingsEditor .field-auto-thin .field-label~.field-control,#LinksSettingsEditor .field-auto-thin .field-label~.field-control,#HistoriesSettingsEditor .field-auto-thin .field-label~.field-control,#FormulasSettingsEditor .field-auto-thin .field-label~.field-control,#ViewsSettingsEditor .field-auto-thin .field-label~.field-control,#ImportsSettingsEditor .field-auto-thin .field-label~.field-control,#ExportsSettingsEditor .field-auto-thin .field-label~.field-control,#CalendarSettingsEditor .field-auto-thin .field-label~.field-control,#CrosstabSettingsEditor .field-auto-thin .field-label~.field-control,#GanttSettingsEditor .field-auto-thin .field-label~.field-control,#BurnDownSettingsEditor .field-auto-thin .field-label~.field-control,#TimeSeriesSettingsEditor .field-auto-thin .field-label~.field-control,#KambanSettingsEditor .field-auto-thin .field-label~.field-control,#ImageLibSettingsEditor .field-auto-thin .field-label~.field-control,#SearchSettingsEditor .field-auto-thin .field-label~.field-control,#StylesSettingsEditor .field-auto-thin .field-label~.field-control,#ScriptsSettingsEditor .field-auto-thin .field-label~.field-control,#PublishSettingsEditor .field-auto-thin .field-label~.field-control,#FieldSetSiteAccessControl .field-auto-thin .field-label~.field-control{margin-left:10px}#SiteImageSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#GridSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#FiltersSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#EditorSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#LinksSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#HistoriesSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#FormulasSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#ViewsSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#ImportsSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#ExportsSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#CalendarSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#CrosstabSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#GanttSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#BurnDownSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#TimeSeriesSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#KambanSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#ImageLibSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#SearchSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#StylesSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#ScriptsSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#PublishSettingsEditor .field-auto-thin .field-label~.field-control .container-normal,#FieldSetSiteAccessControl .field-auto-thin .field-label~.field-control .container-normal{width:100%}#FieldSetGeneral .field-control .container-normal .control-checkbox~label{width:auto}#GridSettingsEditor #GridEditorType{max-width:unset}#SiteImageSettingsEditor #SiteImage{width:100%;height:7vw}#SiteImageSettingsEditor #SetSiteImage{margin-right:0}}@media screen and (max-width:980px) and (min-width:0){#Aggregations{display:flex;flex-wrap:wrap;row-gap:5px;justify-content:flex-start;align-items:center}#Aggregations span.label{flex:1 0 auto;margin:0;text-align:center;align-self:stretch;display:flex;align-items:center;justify-content:flex-start}#Aggregations span.data{flex:1 0 auto;margin:0;align-self:stretch;display:flex;align-items:center;justify-content:flex-start;height:auto}#Aggregations span.data.no-choice{flex-basis:auto;align-self:stretch}#Aggregations span.data.link span{font-weight:bold}#Aggregations #ReduceAggregations{width:100%}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer .grid{vertical-align:middle}#ViewModeContainer .grid tr td:first-child{padding:6px}input[type='checkbox'],.field-auto-thin input[type='checkbox']{width:3vw;height:3vw}.field-auto-thin input[type='checkbox']+label{padding-top:2px}}@media screen and (max-width:980px) and (min-width:0){#SearchField #Search{font-size:3vw;width:100%}#SearchField #Search::placeholder{font-size:3vw}}@media screen and (max-width:980px) and (min-width:0){#ViewFilters #ViewFilters_Reset{margin-left:auto;margin-right:0}#ViewFilters .field-auto-thin{width:50%}#ViewFilters .field-auto-thin .field-control .container-normal{display:flex;align-items:center}#ViewFilters .field-auto-thin .field-control .container-normal input[type='checkbox']{margin-right:4px;margin-top:1px}#ViewFilters .field-auto-thin .field-control .container-normal .ui-widget.ui-state-default.ui-multiselect,#ViewFilters .field-auto-thin .field-control .container-normal .control-textbox{height:6vw;font-size:2.6vw}#ViewFilters #ViewFilters_SearchField{width:100%}#ViewFilters #ViewFilters_SearchField p.field-label{width:17%}#ViewFilters #ViewFilters_SearchField .field-control{width:100%}#ViewFilters>.field-auto-thin:nth-child(odd){padding-right:2px}#ViewFilters>.field-auto-thin:nth-child(even){padding-left:2px}.ui-multiselect-menu .ui-helper-reset{position:relative}.ui-multiselect-menu .ui-helper-reset li{width:100%}.ui-multiselect-menu .ui-helper-reset li>label span{position:relative;top:-4px}.ui-multiselect-menu .ui-helper-reset li .ui-multiselect-all,.ui-multiselect-menu .ui-helper-reset li .ui-multiselect-none{width:100%;display:flex;align-items:center}.ui-multiselect-menu .ui-helper-reset li .ui-multiselect-all span:last-child,.ui-multiselect-menu .ui-helper-reset li .ui-multiselect-none span:last-child{padding-left:10px}.ui-multiselect-menu .ui-helper-reset li .ui-multiselect-close{position:absolute;top:8px;right:0}}@media screen and (max-width:980px) and (min-width:0){#EditorTabsContainer .legend.applied{display:flex;align-items:center;font-weight:bold}#EditorTabsContainer #PermissionEditor .field-vertical:first-child>.field-control{border-bottom:1px solid #d19405;padding-bottom:2vw}#EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left{display:flex;align-items:center;flex-wrap:wrap;width:100%}#EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #SearchPermissionElements{margin:2px 1vw 2px 6vw;height:7vw}#EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left button{align-self:stretch;display:flex;align-items:center;justify-content:center;white-space:nowrap}#EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left button .ui-icon{position:relative;top:.5vw;width:18px;height:18px;margin-right:0}#EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #OpenPermissionsDialog,#EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #DeletePermissions{line-height:1.5}#EditorTabsContainer #PermissionEditor .field-control .container-selectable #CurrentPermissionsWrapper{min-height:15vw}}@media screen and (max-width:980px) and (min-width:0){thead>tr.ui-widget-header th div>span{font-size:2.8vw;white-space:nowrap}}@media screen and (max-width:980px) and (min-width:0){#EditorTabsContainer .field-control .container-normal .ui-icon.ui-icon-pencil.button-edit-markdown{background-image:url("");background-position:center;width:12px;height:12px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%);top:8px;right:4px}#EditorTabsContainer .field-control .container-normal .ui-icon.ui-icon-image.button-upload-image{background-image:url("");background-position:center;width:12px;height:12px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%);position:relative;left:-1px}}@media screen and (max-width:980px) and (min-width:0){#EditorTabsContainer{overflow:auto}#EditorComments{padding:0;margin:0}#EditorComments #CommentField .control-textarea{height:15vw}#EditorComments #CommentField .control-textarea::placeholder{font-size:2.6vw}}@media screen and (max-width:980px) and (min-width:0){.is-showMenu{overflow:hidden}.is-showMenu body{position:fixed;overflow:hidden}.bg-overlay{background:rgba(0,0,0,.5);position:fixed;top:0;left:0;z-index:301;width:100%;height:100%;display:none}#MainContainer{overflow:hidden}header#Header{position:fixed;top:0;z-index:1000;background-color:#fff;transition:all .5s ease}header#Header a#navtgl{top:8px;z-index:1000;transition:all .5s ease}header#Header a#navtgl::after{transition:all .5s ease}header#Header a#navtgl.on{transition:all .5s ease;position:fixed}header#Header a#navtgl.on::before{transition:all .5s ease;border-top:none;transform:translate(12.5%,50%) rotate(50deg)}header#Header a#navtgl.on::after{transition:all .5s ease;transform:translate(12.5%,0%) rotate(126deg)}#Navigations{transition:all .5s ease;max-height:100vh;height:100vh;position:absolute;top:0;right:-1000px;z-index:999;padding:5%;width:70%;padding-top:112px;opacity:0}#Navigations.open{opacity:1;padding-top:112px;right:0;height:100vh;margin:0;position:fixed;top:0;z-index:1000}}@media screen and (max-width:980px) and (min-width:0){#OutgoingMailsForm{width:100%;font-size:2.6vw}#OutgoingMailsForm .item h3.title-header{height:auto}#OutgoingMailsForm .item .content{padding:.2em;margin:0}#OutgoingMailsForm .item .content .field-auto,#OutgoingMailsForm .item .content .field-auto-thin{width:100%;margin-right:0;padding-right:0;padding-bottom:0;display:flex;flex-direction:column;height:auto}#OutgoingMailsForm .item .content .field-auto .field-label,#OutgoingMailsForm .item .content .field-auto-thin .field-label{float:none;padding:7px 7px 7px 0;width:100%;text-align:left;display:block}#OutgoingMailsForm .item .content .field-auto .field-label label,#OutgoingMailsForm .item .content .field-auto-thin .field-label label{font-weight:bold}#OutgoingMailsForm .item .content .field-auto .field-control,#OutgoingMailsForm .item .content .field-auto-thin .field-control{float:none;width:100%}#OutgoingMailsForm .item .content .field-auto .field-control .container-normal,#OutgoingMailsForm .item .content .field-auto-thin .field-control .container-normal{margin-right:0;width:100%}#OutgoingMailsForm .item .content .field-auto .field-control .container-normal .control-text,#OutgoingMailsForm .item .content .field-auto-thin .field-control .container-normal .control-text{min-height:0;height:auto}#OutgoingMailsForm .item .content .field-auto-thin{margin-left:0}#OutgoingMailsForm .item .content .field-wide{display:flex;flex-direction:column;padding:0}#OutgoingMailsForm .item .content .field-wide .field-label{padding:7px 0}#OutgoingMailsForm .item .content .field-wide .field-control .container-normal{margin-right:0;width:100%}}@media screen and (max-width:980px) and (min-width:0){#SiteMenu li.ui-sortable-handle{touch-action:unset}}@media screen and (max-width:980px) and (min-width:0){.message .close{top:unset;bottom:calc(50% - 8px);margin:auto}}@media screen and (max-width:980px) and (min-width:0){#EditorComments #CommentField .ui-icon.ui-icon-image.button-upload-image{background-image:url("");background-position:center;width:12px;height:12px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%);position:relative;left:0}}@media screen and (max-width:980px) and (min-width:0){#Navigations.open{overflow-y:scroll}#Navigations #NavigationMenu #NewMenuContainer{background:unset;border:none}#Navigations #NavigationMenu #NewMenuContainer a{line-height:7vw}#Navigations #NavigationMenu li.sub-menu .ui-menu-item .ui-menu-item-wrapper{font-size:3vw;padding-left:6vw}}@media screen and (max-width:980px) and (min-width:0){#Editor .field-normal .field-control .container-normal input[type='checkbox'].control-checkbox{position:relative;margin-right:6px;margin-top:.3vw}}@media screen and (max-width:980px) and (min-width:0){#Editor #EditorTabsContainer .field-normal,#Editor #EditorTabsContainer .field-wide,#Editor #EditorTabsContainer .field-markdown{display:inline-block;margin-top:8px;padding-bottom:0}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer #Calendar.both select{font-size:2.6vw}#ViewModeContainer #Calendar.both .field-label{min-width:30%;margin-right:15px}#ViewModeContainer #Calendar.both .field-auto-thin .field-control .container-normal{display:flex;align-items:center}#ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3){flex:0 1 calc(64%)}#ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) .field-label{min-width:22%}#ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) .field-control{width:74%}#ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4){flex:0 1 calc(33% + 1px);padding-top:2%}#ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) .field-control .container-normal{justify-content:flex-end}#ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) .field-control .container-normal #CalendarDate{margin-right:0;width:98%;font-size:2.6vw}#ViewModeContainer #Calendar.both button{flex:1 0 calc((100%/3) - 32px);margin:2% 10px 2% 10px}#ViewModeContainer .grid.fixed{width:100%}#ViewModeContainer .grid.fixed tbody tr td.container .item{touch-action:auto;min-height:50px}#ViewModeContainer .grid.fixed tbody tr td.container .item .title .ui-icon.ui-icon-pencil{margin-right:5px;background-image:url("");background-position:center;width:36px;height:36px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%)}#ViewModeContainer .grid.fixed tbody tr td.container .item .connection{min-height:50px}#ViewModeContainer .grid.fixed tbody tr td.container .dummy{height:50px}#ViewModeContainer .grid.fixed tbody tr td.container:first-child .item{margin-top:0;margin-bottom:5px}#ViewModeContainer .grid.fixed tbody tr td.container:not(:first-child) .item{margin-top:5px}thead th.calendar-header{overflow-x:hidden}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer .both{column-gap:16px}#ViewModeContainer .both .field-auto-thin:first-child,#ViewModeContainer .both .field-auto-thin:nth-child(2){flex:0 1 calc(50% - 8px)}#ViewModeContainer .both .field-auto-thin:first-child .field-control,#ViewModeContainer .both .field-auto-thin:nth-child(2) .field-control{flex:1}#ViewModeContainer .both .field-auto-thin:first-child .field-control select,#ViewModeContainer .both .field-auto-thin:nth-child(2) .field-control select{max-width:100%}#ViewModeContainer .both .field-auto-thin:nth-child(3){row-gap:12px;flex-wrap:wrap}#ViewModeContainer .both .field-auto-thin:nth-child(3) .field-label{min-width:15%}#ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin{display:flex;align-items:center;flex:1 0 100%}#ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin #GanttStartDate{width:100%;font-size:2.6vw;margin-right:0}#ViewModeContainer .both .field-auto-thin:nth-child(3) button{flex:1}#ViewModeContainer .both .field-auto-thin:nth-child(3) button:last-child{margin-right:8px}#ViewModeContainer .both .field-auto-thin:nth-child(4){width:100%;padding-top:12px}#ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control{width:100%}#ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal{width:100%;display:flex;align-items:center;column-gap:32px}#ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal #GanttPeriod\,ui{width:99%;margin-top:0}#ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal #GanttPeriod{margin:0}#GanttBody{max-height:70vh}#GanttBody text{font-size:2.6vw}#GanttBody .title text.summary{font-size:3vw}#GanttBody #GanttAxis{left:auto;position:sticky}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer #Kamban.both .field-auto-thin select{font-size:2.6vw}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1),#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2),#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3),#ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField{width:100%;flex:0 1 calc(50% - 8px);flex-wrap:wrap;display:flex;row-gap:0}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1) .field-label,#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2) .field-label,#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) .field-label,#ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField .field-label{width:100%}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1) select,#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2) select,#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) select,#ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField select{max-width:100%}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3){padding-top:4%}#ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField{padding-top:4%}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5){display:block;width:100%;padding-top:4%}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) .field-label{min-width:50%;margin-right:10px}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) select{max-width:100%}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(6),#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(7){width:calc(50% - 8px);padding-top:4%}#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(6) .container-normal,#ViewModeContainer #Kamban.both .field-auto-thin:nth-child(7) .container-normal{display:flex;align-items:center}#ViewModeContainer #Kamban.both #KambanBody #Grid tbody .kamban-row .kamban-container .kamban-item{overflow:hidden;padding:6px 30px 6px 5px;white-space:pre-line;touch-action:auto;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}#ViewModeContainer #Kamban.both #KambanBody #Grid tbody .kamban-row .kamban-container .kamban-item .ui-icon.ui-icon-pencil{background-image:url("");background-position:center;width:36px;height:36px;filter:invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%);margin-right:0;top:-7px;right:-11px}}@media screen and (max-width:980px) and (min-width:0){#RecordSwitchers{display:flex;align-items:center}#RecordSwitchers #CurrentIndex{height:7.5vw;display:flex;align-items:center}}@media screen and (max-width:980px) and (min-width:0){#Editor #RecordHeader .user{display:flex;align-items:center}#Editor #RecordHeader .user .ui-icon-person{margin-right:.6vw}}@media screen and (max-width:980px) and (min-width:0){#OutgoingMailDialog .field-wide{padding-bottom:5px}#OutgoingMailDialog .field-wide .field-label{width:auto}#OutgoingMailDialog .field-wide .field-control{float:none}#OutgoingMailDialog .field-wide .control-basket,#OutgoingMailDialog .field-wide .container-normal{margin-left:15vw}#OutgoingMailDialog textarea{height:20vw}}@media screen and (max-width:980px) and (min-width:0){.show-password{top:calc(50% - 10px);right:10px}#LoginFieldSet input[type=checkbox]{transform:scale(1.2)}#LoginFieldSet input,#LoginFieldSet select{font-size:4vw}#Users_RememberMeField .container-normal{display:flex;align-items:center}}@media screen and (max-width:980px) and (min-width:0){#Navigations.open{padding-top:18vw}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer .field-auto-thin>.field-label{padding:7px 2vw 7px 0}#CrosstabValueField .field-control{width:70%}#Crosstab .field-auto-thin p{margin-right:0%}#ViewModeContainer #Crosstab .field-auto-thin{width:100%;flex:0 1 calc(100%);padding-top:1vw}#ViewModeContainer #Crosstab .field-auto-thin .field-label{width:30%}#ViewModeContainer #Crosstab .field-auto-thin .field-control{width:70%}#ViewModeContainer #Crosstab .field-auto-thin .field-control input[type='checkbox'],#ViewModeContainer #Crosstab .field-auto-thin .field-control .field-auto-thin input[type='checkbox']{width:4vw;height:4vw;margin-left:2px}#CrosstabBody .grid>thead>tr:first-child>th:not(:first-child),#KambanBody .grid>thead>tr:first-child>th:not(:first-child){white-space:nowrap}}@media screen and (max-width:980px) and (min-width:0){#ImportSettingsDialog .control-checkbox+label{margin:1.8vw 0 0 1vw}#ImportSettingsDialog .control-checkbox{margin:2vw 0 2vw 2px}#ImportSettingsDialog .control-textbox{height:7vw;line-height:6.5vw}#ImportSettingsDialog .command-center{padding:2vw 0}}@media screen and (max-width:980px) and (min-width:0){#ExportSelectorDialog .command-center{padding:2vw 0}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer #Grid .datepicker{width:35vw;font-size:4vw}}@media screen and (max-width:980px) and (min-width:0){#ViewModeContainer .both #TimeSeriesValueField,#ViewModeContainer .both #TimeSeriesChartTypeField,#ViewModeContainer .both #TimeSeriesHorizontalAxisField{width:100%}#ViewModeContainer .both #TimeSeriesValueField .field-label,#ViewModeContainer .both #TimeSeriesChartTypeField .field-label,#ViewModeContainer .both #TimeSeriesHorizontalAxisField .field-label{min-width:30%}#ViewModeContainer .both .field-auto-thin:first-child,#ViewModeContainer .both .field-auto-thin:nth-child(2){flex:0 1 calc(100%)}#ViewModeContainer .both .field-auto-thin:first-child .field-label,#ViewModeContainer .both .field-auto-thin:nth-child(2) .field-label{min-width:30%}#ViewModeContainer .both .field-auto-thin select{max-width:100%}#ViewModeContainer .both .field-auto-thin>.field-control{min-width:68%}} \ No newline at end of file diff --git a/Implem.Pleasanter/wwwroot/scripts/responsive.js b/Implem.Pleasanter/wwwroot/scripts/responsive.js index e265ca479..35b9a3ac7 100644 --- a/Implem.Pleasanter/wwwroot/scripts/responsive.js +++ b/Implem.Pleasanter/wwwroot/scripts/responsive.js @@ -1,16 +1,73 @@ - -$p.openResponsiveMenu = function () { +$p.openResponsiveMenu = function () { var t = document.getElementById('Navigations'); var t2 = document.getElementById('navtgl'); + const $body = $('body'); + const $header = $('#Header'); if (t.classList.contains('open') == true) { t.classList.remove('open'); t2.classList.remove('on'); + $body.removeClass('is-showMenu'); + if ($('.bg-overlay').length) { + $('.bg-overlay').remove(); + } } else { t.classList.add('open'); t2.classList.add('on'); + $body.addClass('is-showMenu'); + if (!$('.bg-overlay').length) { + $header.append(`
`); + } + $('.bg-overlay').css({ + 'display': 'block' + }); + if ($('.bg-overlay').length) { + $('.bg-overlay').on('click', function () { + $p.openResponsiveMenu(); + }); + } } } +$(document).ready(function () { + if ($p.responsive() && screen.width < 981) { + const heightHeader = $('#Header').length > 0 ? $('#Header').height() : 100; + $('#Application').css({ + 'padding-top': `${heightHeader}px` + }); + $(window).scroll(function () { + const scrollPosition = $(this).scrollTop(); + if (scrollPosition === 0) { + $('#Header').css({ + 'box-shadow': 'unset' + }); + } else if (scrollPosition > heightHeader) { + const $headerDummyIndex = $('body thead .ui-widget-header'); + $('#Header').css({ + 'box-shadow': 'rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px' + }); + if (window.location.pathname.includes('index')) { + $('body thead').css({ + 'top': `${heightHeader}px` + }); + $(document).ajaxComplete(function () { + if ($headerDummyIndex.length > 1) { + $($headerDummyIndex[1]).css({ + 'top': '0px', + 'display': 'none' + }); + } else { + $($headerDummyIndex[0]).css({ + 'top': '0px', + 'display': 'none' + }); + } + }); + } + } + }); + } +}); + $p.switchResponsive = function ($control) { var redirect = 1; var data = {}; @@ -44,4 +101,44 @@ if (screen.width < 981) { $p.send($('#ReduceAggregations')); } +$(document).ready(function () { + function handleSMobileViewport() { + if ($('#MainCommandsContainer').length > 0) { + if ($('#Message').length > 0) { + let $heightMainCommand = $('#MainCommandsContainer').outerHeight(); + let $heightFooter = $('#Footer').outerHeight(); + $(document).ajaxComplete(function () { + setTimeout(function () { + $heightMainCommand = $('#MainCommandsContainer').outerHeight(); + $heightFooter = $('#Footer').outerHeight(); + $('#Message').css( + 'bottom', parseInt($heightMainCommand + $heightFooter) + ); + }, 1); + }); + $('#Message').css( + 'bottom', parseInt($heightMainCommand + $heightFooter) + ); + } + } + } + if ($p.responsive() && screen.width < 981) { + handleSMobileViewport(); + } + window.addEventListener('resize', function () { + if ($p.responsive() && screen.width < 981) { + handleSMobileViewport(); + } + }); +}); +if ($p.responsive() && screen.width < 981) { + $('#ViewModeContainer').on('scroll', function () { + let scrollLeft = $(this).scrollLeft(); + if ($(this).scrollLeft() > 0) { + $('body > thead').css({ + 'left': `calc(5vw - ${scrollLeft}px)` + }); + } + }); +} diff --git a/Implem.Pleasanter/wwwroot/scripts/sitepackage.js b/Implem.Pleasanter/wwwroot/scripts/sitepackage.js index 9d1a2e41d..6d35419c3 100644 --- a/Implem.Pleasanter/wwwroot/scripts/sitepackage.js +++ b/Implem.Pleasanter/wwwroot/scripts/sitepackage.js @@ -6,6 +6,9 @@ width: '520px' }); } + if ($p.responsive() && screen.width < 981) { + $p.openResponsiveMenu(); + } } $p.importSitePackage = function ($control) { @@ -44,6 +47,9 @@ $p.openExportSitePackageDialog = function ($control) { } }); } + if ($p.responsive() && screen.width < 981) { + $p.openResponsiveMenu(); + } } $p.exportSitePackage = function () { diff --git a/Implem.Pleasanter/wwwroot/scripts/template.js b/Implem.Pleasanter/wwwroot/scripts/template.js index 1f69f36b2..e0479fd32 100644 --- a/Implem.Pleasanter/wwwroot/scripts/template.js +++ b/Implem.Pleasanter/wwwroot/scripts/template.js @@ -1,5 +1,8 @@ $p.templates = function ($control) { $p.send($control, 'MainForm'); + if ($p.responsive() && screen.width < 981) { + $p.openResponsiveMenu(); + } } $p.setTemplate = function () { diff --git a/Implem.Pleasanter/wwwroot/scripts/viewmode.js b/Implem.Pleasanter/wwwroot/scripts/viewmode.js index 797bc956c..dcff850ea 100644 --- a/Implem.Pleasanter/wwwroot/scripts/viewmode.js +++ b/Implem.Pleasanter/wwwroot/scripts/viewmode.js @@ -3,6 +3,9 @@ .replace('_action_', $control.attr('data-action').toLowerCase()); $p.ajax(url, 'post', $p.getData($control), $control); history.pushState(null, null, url); + if ($p.responsive() && screen.width < 981) { + $p.openResponsiveMenu(); + } } $p.changeViewSelector = function ($control) { diff --git a/Implem.Pleasanter/wwwroot/styles/responsive.css b/Implem.Pleasanter/wwwroot/styles/responsive.css index df66ede63..b1ad0bd02 100644 --- a/Implem.Pleasanter/wwwroot/styles/responsive.css +++ b/Implem.Pleasanter/wwwroot/styles/responsive.css @@ -62,11 +62,6 @@ margin: 10px 0px; float: left; } - @media screen and (max-width: 600px) and (min-width: 0px) { - #LoginFieldSet .field-wide { - min-height: 10vw !important; - } - } #StartGuide { display: none; } @@ -74,7 +69,7 @@ word-break: break-all; } div[role="dialog"] { - width: 100% !important; + width: 98% !important; z-index: 999; } #EnterPriseBanner, #SupportBanner, #CasesBanner { @@ -113,7 +108,10 @@ #ViewFilters>.field-auto-thin>.field-control { width: 100%;} #ViewFilters>.field-auto-thin>.field-label { width: 30%; text-align: left;} #ViewFilters>.field-auto-thin>.field-label+.field-control { width: 70%; } - .ui-multiselect { width: 98%!important; height: 6vw; } + .ui-multiselect { + width: 100% !important; + height: 6vw; + } .field-auto-thin input[type="checkbox"], .field-auto-thin input[type="radio"] { height: 2.6vw; width: 2.6vw; margin-right: 1vw; } @@ -156,8 +154,9 @@ .field-normal .control-text{ width: 100%; height: auto; padding: 1%; line-height: 1; } .control-textbox { height: auto; } -.ui-widget.ui-widget-content { background: #fff; font-size: 2.6vw; } - +.ui-widget.ui-widget-content { + font-size: 2.6vw; +} #Guide { font-size: 2.6vw; } .alert-success, @@ -171,14 +170,12 @@ .ui-tabs .ui-tabs-nav li { margin-bottom: 1%; padding-bottom: 0; -border:1px solid #111; -border-radius: 4px; + border-radius: 4px; } .ui-tabs .ui-tabs-nav li.ui-tabs-active { margin-bottom: 1%; padding-bottom: 0; -border:1px solid #111; -border-radius: 4px; + border-radius: 4px; } .message { bottom: 140px; } } @@ -188,7 +185,6 @@ border-radius: 4px; body { min-width: 320px!important; } #Header { height: auto; position: relative; } - #Header #Logo { padding-bottom: 2%; } #CorpLogo { float: none; width: 30%;} #MainContainer { min-height: 100vh; } @@ -239,16 +235,6 @@ transition: .5s; background: none; } -#Header .ui-widget-header{ -background: #f3f3f3; -color:#111; -} - -.ui-widget-header{ -background: #817865; -color:#fff; -} - #NavigationMenu { float: none; margin-right: 0; @@ -261,32 +247,28 @@ color:#fff; color: #000; } -#NavigationMenu>li { -width: 100%; -height: auto; -display: block; -float: none; -position: relative; -color:#333; -} - -#NavigationMenu>li>div { -height: auto; -text-align: left; -line-height: 7vw; -color: #333; -font-weight: bold; -} - -#NavigationMenu>li>div:hover { background:none;} - -#NavigationMenu>li>div>a { -height: auto; -display: block; -color: #333; -text-decoration: none; -font-weight: bold; -} + #NavigationMenu > li { + width: 100%; + height: auto; + display: block; + float: none; + position: relative; + } + #NavigationMenu > li > div { + height: auto; + text-align: left; + line-height: 7vw; + font-weight: bold; + } + #NavigationMenu > li > div:hover { + background: none; + } + #NavigationMenu > li > div > a { + height: auto; + display: block; + text-decoration: none; + font-weight: bold; + } #NavigationMenu .menu { width: 100%; @@ -306,13 +288,6 @@ font-weight: normal; text-decoration: none; } -.ui-widget.ui-widget-content { -} - -.ui-widget-content { -color: #333; -} - .ui-menu .ui-menu-item { border-top: 1px solid #d19405; } @@ -332,8 +307,6 @@ border: 1px solid #d19405; width: 20vw; height: 20vw; text-align: center; -background-color: white; -border: solid 2px silver; border-radius: 0.5vw; float: none; margin: 6%; @@ -350,7 +323,6 @@ margin: 6%; width: 20vw!important; height: 20vw!important; background: #fff; -border: solid 2px #ffa500; border-radius: 5px;} @@ -358,8 +330,6 @@ border-radius: 5px;} width: 8vw; height: 3vw; top: -3vw; -background-color: #f8da4c; -border: solid 2px #ffa500; } #SiteMenu .nav-site.sites.to-parent{ @@ -615,18 +585,1056 @@ overflow: hidden; #KambanBody .grid>tbody td { min-width: 10vw; white-space: nowrap; } } -@media screen and (min-width: 981px) { +@media screen and (max-width: 980px) and (min-width: 0px) { + #Header { + padding: 0 calc(5vw); + } + #Header a#navtgl { + right: 5vw; + } + #Application, + #Footer { + padding-left: 5vw; + padding-right: 5vw; + } + #SiteMenu .nav-site { + margin: 5%; + } + :not(td) > div.field-control .container-normal { + margin-left: 0; + } + * { + line-height: 1.4; + } + .field-normal .control-textbox, + .field-normal .control-dropdown, + .field-normal .control-text, .field-control .control-textbox, + .field-control .control-dropdown, + .field-control .control-text, .container-normal .control-textbox, + .container-normal .control-dropdown, + .container-normal .control-text { + min-height: unset; + height: 6vw; + line-height: 6vw; + padding-top: 0; + padding-bottom: 0; + } + body { + font-size: 16px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #HeaderTitle { + font-size: 16px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .command-center { + padding: 0; + } + .ui-dialog .ui-dialog-titlebar-close { + top: 0; + bottom: 0; + width: 5vw; + height: 5vw; + margin: auto 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewSelector { + font-size: 2.6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Logo a { + align-items: center; + display: flex; + } + #Logo #ProductLogo { + font-size: 18px; + padding-left: 8px; + } + #CorpLogo { + float: none; + height: calc(8vw + 10px); + width: unset; + margin-top: 0; + } +} -.grid>thead>tr:first-child>th:first-child {width: 20px;} -#CrosstabBody .grid>thead>tr:first-child>th:first-child, -#KambanBody .grid>thead>tr:first-child>th:first-child {width: auto;} +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor .field-control .container-normal { + width: calc(100% - 20px); + } + #Editor .field-control .ui-icon.ui-icon-clock.current-time { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + top: calc(3vw - 3.5px); + right: -16px; + } + #Editor .field-control .ui-icon.ui-icon-person.current-user { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + top: calc(3vw - 3.5px); + right: -16px; + } +} -.grid>thead>tr:first-child>th:not(:first-child) { white-space: nowrap; } -#CrosstabBody .grid>thead>tr:first-child>th:not(:first-child), -#KambanBody .grid>thead>tr:first-child>th:not(:first-child) { white-space: inherit; } +@media screen and (max-width: 980px) and (min-width: 0px) { + #FieldSetAddressBook #OutgoingMailDestinationForm .container-left { + width: 38vw; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right .command-left { + float: unset; + padding: 0; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right .command-left button { + margin: 2px; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right .container-selectable .wrapper { + height: 40vw; + } + #FieldSetAddressBook #OutgoingMailDestinationForm .container-right > * { + margin-left: 40vw; + } +} -.grid>tbody>tr td:not(:first-child) {white-space: nowrap; min-width: 40px;} -#CrosstabBody .grid>tbody>tr td:not(:first-child), -#KambanBody .grid>tbody>tr td:not(:first-child) { white-space: inherit; min-width:auto; } +@media screen and (max-width: 980px) and (min-width: 0px) { + #Issues_WorkValue { + width: 100px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + body::before { + content: ''; + position: fixed; + width: 5vw; + height: 50vh; + top: 0; + left: 0; + background: white; + z-index: 200; + } + body::after { + content: ''; + position: fixed; + width: 5vw; + height: 50vh; + top: 0; + right: 0; + background: white; + z-index: 700; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Users_LoginId, + #Users_Password { + height: 40px; + } + #LoginMessage span { + font-size: 3.5vw; + } + #PortalLink { + font-size: 3.5vw; + top: 3vw; + } + #LoginFieldSet { + margin: 65px auto 20px auto; + } + #LoginFieldSet input[type=checkbox] { + margin: auto 0; + margin-left: 1.2vw; + } + #LoginFieldSet button { + margin-top: 0; + } + #LoginFieldSet .field-wide, + #LoginFieldSet .field-normal { + margin: 0px 0px; + } + #LoginFieldSet .field-normal .control-checkbox + label { + margin: auto 0; + margin-left: 4vw; + padding: 0; + } + #Logins .field-label { + width: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor .field-markdown > .field-label > label { + font-weight: bold; + } + #Editor .field-control .unit { + font-size: 2.6vw; + padding-top: calc((18px - 1.4em) / 2); + } + #Editor .ui-spinner .control-spinner { + height: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #GridCheckAll { + margin-top: 0; + } + label[for="GridCheckAll"] { + margin: 0; + } + #Footer { + font-size: 2.8vw; + height: auto; + } + #MainCommandsContainer { + bottom: calc(2.8vw * 1.4 + 10px); + } + body > thead > tr { + font-size: 0.75em; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #SiteImageSettingsEditor .field-auto-thin, #GridSettingsEditor .field-auto-thin, #FiltersSettingsEditor .field-auto-thin, #EditorSettingsEditor .field-auto-thin, + #LinksSettingsEditor .field-auto-thin, #HistoriesSettingsEditor .field-auto-thin, #FormulasSettingsEditor .field-auto-thin, #ViewsSettingsEditor .field-auto-thin, + #ImportsSettingsEditor .field-auto-thin, #ExportsSettingsEditor .field-auto-thin, #CalendarSettingsEditor .field-auto-thin, #CrosstabSettingsEditor .field-auto-thin, + #GanttSettingsEditor .field-auto-thin, #BurnDownSettingsEditor .field-auto-thin, #TimeSeriesSettingsEditor .field-auto-thin, #KambanSettingsEditor .field-auto-thin, + #ImageLibSettingsEditor .field-auto-thin, #SearchSettingsEditor .field-auto-thin, #StylesSettingsEditor .field-auto-thin, #ScriptsSettingsEditor .field-auto-thin, + #PublishSettingsEditor .field-auto-thin, #FieldSetSiteAccessControl .field-auto-thin { + padding-right: 0; + height: auto; + display: flex; + align-items: center; + clear: both; + } + #SiteImageSettingsEditor .field-auto-thin .container-normal, #GridSettingsEditor .field-auto-thin .container-normal, #FiltersSettingsEditor .field-auto-thin .container-normal, #EditorSettingsEditor .field-auto-thin .container-normal, + #LinksSettingsEditor .field-auto-thin .container-normal, #HistoriesSettingsEditor .field-auto-thin .container-normal, #FormulasSettingsEditor .field-auto-thin .container-normal, #ViewsSettingsEditor .field-auto-thin .container-normal, + #ImportsSettingsEditor .field-auto-thin .container-normal, #ExportsSettingsEditor .field-auto-thin .container-normal, #CalendarSettingsEditor .field-auto-thin .container-normal, #CrosstabSettingsEditor .field-auto-thin .container-normal, + #GanttSettingsEditor .field-auto-thin .container-normal, #BurnDownSettingsEditor .field-auto-thin .container-normal, #TimeSeriesSettingsEditor .field-auto-thin .container-normal, #KambanSettingsEditor .field-auto-thin .container-normal, + #ImageLibSettingsEditor .field-auto-thin .container-normal, #SearchSettingsEditor .field-auto-thin .container-normal, #StylesSettingsEditor .field-auto-thin .container-normal, #ScriptsSettingsEditor .field-auto-thin .container-normal, + #PublishSettingsEditor .field-auto-thin .container-normal, #FieldSetSiteAccessControl .field-auto-thin .container-normal { + width: 100%; + } + #SiteImageSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #GridSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #FiltersSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #EditorSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #LinksSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #HistoriesSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #FormulasSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #ViewsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #ImportsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #ExportsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #CalendarSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #CrosstabSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #GanttSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #BurnDownSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #TimeSeriesSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #KambanSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #ImageLibSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #SearchSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #StylesSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #ScriptsSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, + #PublishSettingsEditor .field-auto-thin .container-normal .control-checkbox ~ label, #FieldSetSiteAccessControl .field-auto-thin .container-normal .control-checkbox ~ label { + display: unset; + float: unset; + width: auto; + } + #SiteImageSettingsEditor .field-auto-thin .field-label ~ .field-control, #GridSettingsEditor .field-auto-thin .field-label ~ .field-control, #FiltersSettingsEditor .field-auto-thin .field-label ~ .field-control, #EditorSettingsEditor .field-auto-thin .field-label ~ .field-control, + #LinksSettingsEditor .field-auto-thin .field-label ~ .field-control, #HistoriesSettingsEditor .field-auto-thin .field-label ~ .field-control, #FormulasSettingsEditor .field-auto-thin .field-label ~ .field-control, #ViewsSettingsEditor .field-auto-thin .field-label ~ .field-control, + #ImportsSettingsEditor .field-auto-thin .field-label ~ .field-control, #ExportsSettingsEditor .field-auto-thin .field-label ~ .field-control, #CalendarSettingsEditor .field-auto-thin .field-label ~ .field-control, #CrosstabSettingsEditor .field-auto-thin .field-label ~ .field-control, + #GanttSettingsEditor .field-auto-thin .field-label ~ .field-control, #BurnDownSettingsEditor .field-auto-thin .field-label ~ .field-control, #TimeSeriesSettingsEditor .field-auto-thin .field-label ~ .field-control, #KambanSettingsEditor .field-auto-thin .field-label ~ .field-control, + #ImageLibSettingsEditor .field-auto-thin .field-label ~ .field-control, #SearchSettingsEditor .field-auto-thin .field-label ~ .field-control, #StylesSettingsEditor .field-auto-thin .field-label ~ .field-control, #ScriptsSettingsEditor .field-auto-thin .field-label ~ .field-control, + #PublishSettingsEditor .field-auto-thin .field-label ~ .field-control, #FieldSetSiteAccessControl .field-auto-thin .field-label ~ .field-control { + margin-left: 10px; + } + #SiteImageSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #GridSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #FiltersSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #EditorSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #LinksSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #HistoriesSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #FormulasSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #ViewsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #ImportsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #ExportsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #CalendarSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #CrosstabSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #GanttSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #BurnDownSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #TimeSeriesSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #KambanSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #ImageLibSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #SearchSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #StylesSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #ScriptsSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, + #PublishSettingsEditor .field-auto-thin .field-label ~ .field-control .container-normal, #FieldSetSiteAccessControl .field-auto-thin .field-label ~ .field-control .container-normal { + width: 100%; + } + #FieldSetGeneral .field-control .container-normal .control-checkbox ~ label { + width: auto; + } + #GridSettingsEditor #GridEditorType { + max-width: unset; + } + #SiteImageSettingsEditor #SiteImage { + width: 100%; + height: 7vw; + } + #SiteImageSettingsEditor #SetSiteImage { + margin-right: 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Aggregations { + display: flex; + flex-wrap: wrap; + row-gap: 5px; + justify-content: flex-start; + align-items: center; + } + #Aggregations span.label { + flex: 1 0 auto; + margin: 0; + text-align: center; + align-self: stretch; + display: flex; + align-items: center; + justify-content: flex-start; + } + #Aggregations span.data { + flex: 1 0 auto; + margin: 0; + align-self: stretch; + display: flex; + align-items: center; + justify-content: flex-start; + height: auto; + } + #Aggregations span.data.no-choice { + flex-basis: auto; + align-self: stretch; + } + #Aggregations span.data.link span { + font-weight: bold; + } + #Aggregations #ReduceAggregations { + width: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .grid { + vertical-align: middle; + } + #ViewModeContainer .grid tr td:first-child { + padding: 6px; + } + input[type='checkbox'], .field-auto-thin input[type='checkbox'] { + width: 3vw; + height: 3vw; + } + .field-auto-thin input[type='checkbox'] + label { + padding-top: 2px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #SearchField #Search { + font-size: 3vw; + width: 100%; + } + #SearchField #Search::placeholder { + font-size: 3vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewFilters #ViewFilters_Reset { + margin-left: auto; + margin-right: 0; + } + #ViewFilters .field-auto-thin { + width: 50%; + } + #ViewFilters .field-auto-thin .field-control .container-normal { + display: flex; + align-items: center; + } + #ViewFilters .field-auto-thin .field-control .container-normal input[type='checkbox'] { + margin-right: 4px; + margin-top: 1px; + } + #ViewFilters .field-auto-thin .field-control .container-normal .ui-widget.ui-state-default.ui-multiselect, #ViewFilters .field-auto-thin .field-control .container-normal .control-textbox { + height: 6vw; + font-size: 2.6vw; + } + #ViewFilters #ViewFilters_SearchField { + width: 100%; + } + #ViewFilters #ViewFilters_SearchField p.field-label { + width: 17%; + } + #ViewFilters #ViewFilters_SearchField .field-control { + width: 100%; + } + #ViewFilters > .field-auto-thin:nth-child(odd) { + padding-right: 2px; + } + #ViewFilters > .field-auto-thin:nth-child(even) { + padding-left: 2px; + } + .ui-multiselect-menu .ui-helper-reset { + position: relative; + } + .ui-multiselect-menu .ui-helper-reset li { + width: 100%; + } + .ui-multiselect-menu .ui-helper-reset li > label span { + position: relative; + top: -4px; + } + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-all, + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-none { + width: 100%; + display: flex; + align-items: center; + } + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-all span:last-child, + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-none span:last-child { + padding-left: 10px; + } + .ui-multiselect-menu .ui-helper-reset li .ui-multiselect-close { + position: absolute; + top: 8px; + right: 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorTabsContainer .legend.applied { + display: flex; + align-items: center; + font-weight: bold; + } + #EditorTabsContainer #PermissionEditor .field-vertical:first-child > .field-control { + border-bottom: 1px solid #d19405; + padding-bottom: 2vw; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left { + display: flex; + align-items: center; + flex-wrap: wrap; + width: 100%; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #SearchPermissionElements { + margin: 2px 1vw 2px 6vw; + height: 7vw; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left button { + align-self: stretch; + display: flex; + align-items: center; + justify-content: center; + white-space: nowrap; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left button .ui-icon { + position: relative; + top: 0.5vw; + width: 18px; + height: 18px; + margin-right: 0px; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #OpenPermissionsDialog, + #EditorTabsContainer #PermissionEditor .field-control .container-selectable .command-left #DeletePermissions { + line-height: 1.5; + } + #EditorTabsContainer #PermissionEditor .field-control .container-selectable #CurrentPermissionsWrapper { + min-height: 15vw; + } +} +@media screen and (max-width: 980px) and (min-width: 0px) { + thead > tr.ui-widget-header th div > span { + font-size: 2.8vw; + white-space: nowrap; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorTabsContainer .field-control .container-normal .ui-icon.ui-icon-pencil.button-edit-markdown { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + top: 8px; + right: 4px; + } + #EditorTabsContainer .field-control .container-normal .ui-icon.ui-icon-image.button-upload-image { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + position: relative; + left: -1px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorTabsContainer { + overflow: auto; + } + #EditorComments { + padding: 0; + margin: 0; + } + #EditorComments #CommentField .control-textarea { + height: 15vw; + } + #EditorComments #CommentField .control-textarea::placeholder { + font-size: 2.6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .is-showMenu { + overflow: hidden; + } + .is-showMenu body { + position: fixed; + overflow: hidden; + } + .bg-overlay { + background: rgba(0, 0, 0, 0.5); + position: fixed; + top: 0; + left: 0; + z-index: 301; + width: 100%; + height: 100%; + display: none; + } + #MainContainer { + overflow: hidden; + } + header#Header { + position: fixed; + top: 0; + z-index: 1000; + background-color: #fff; + transition: all 0.5s ease; + } + header#Header a#navtgl { + top: 8px; + z-index: 1000; + transition: all 0.5s ease; + } + header#Header a#navtgl::after { + transition: all 0.5s ease; + } + header#Header a#navtgl.on { + transition: all 0.5s ease; + position: fixed; + } + header#Header a#navtgl.on::before { + transition: all 0.5s ease; + border-top: none; + transform: translate(12.5%, 50%) rotate(50deg); + } + header#Header a#navtgl.on::after { + transition: all 0.5s ease; + transform: translate(12.5%, 0%) rotate(126deg); + } + #Navigations { + transition: all 0.5s ease; + max-height: 100vh; + height: 100vh; + position: absolute; + top: 0; + right: -1000px; + z-index: 999; + padding: 5%; + width: 70%; + padding-top: 112px; + opacity: 0; + } + #Navigations.open { + opacity: 1; + padding-top: 112px; + right: 0; + height: 100vh; + margin: 0; + position: fixed; + top: 0; + z-index: 1000; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #OutgoingMailsForm { + width: 100%; + font-size: 2.6vw; + } + #OutgoingMailsForm .item h3.title-header { + height: auto; + } + #OutgoingMailsForm .item .content { + padding: 0.2em; + margin: 0; + } + #OutgoingMailsForm .item .content .field-auto, + #OutgoingMailsForm .item .content .field-auto-thin { + width: 100%; + margin-right: 0; + padding-right: 0; + padding-bottom: 0; + display: flex; + flex-direction: column; + height: auto; + } + #OutgoingMailsForm .item .content .field-auto .field-label, + #OutgoingMailsForm .item .content .field-auto-thin .field-label { + float: none; + padding: 7px 7px 7px 0; + width: 100%; + text-align: left; + display: block; + } + #OutgoingMailsForm .item .content .field-auto .field-label label, + #OutgoingMailsForm .item .content .field-auto-thin .field-label label { + font-weight: bold; + } + #OutgoingMailsForm .item .content .field-auto .field-control, + #OutgoingMailsForm .item .content .field-auto-thin .field-control { + float: none; + width: 100%; + } + #OutgoingMailsForm .item .content .field-auto .field-control .container-normal, + #OutgoingMailsForm .item .content .field-auto-thin .field-control .container-normal { + margin-right: 0; + width: 100%; + } + #OutgoingMailsForm .item .content .field-auto .field-control .container-normal .control-text, + #OutgoingMailsForm .item .content .field-auto-thin .field-control .container-normal .control-text { + min-height: 0; + height: auto; + } + #OutgoingMailsForm .item .content .field-auto-thin { + margin-left: 0; + } + #OutgoingMailsForm .item .content .field-wide { + display: flex; + flex-direction: column; + padding: 0; + } + #OutgoingMailsForm .item .content .field-wide .field-label { + padding: 7px 0; + } + #OutgoingMailsForm .item .content .field-wide .field-control .container-normal { + margin-right: 0; + width: 100%; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #SiteMenu li.ui-sortable-handle { + touch-action: unset; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .message .close { + top: unset; + bottom: calc(50% - 8px); + margin: auto; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #EditorComments #CommentField .ui-icon.ui-icon-image.button-upload-image { + background-image: url(""); + background-position: center; + width: 12px; + height: 12px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + position: relative; + left: 0px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Navigations.open { + overflow-y: scroll; + } + #Navigations #NavigationMenu #NewMenuContainer { + background: unset; + border: none; + } + #Navigations #NavigationMenu #NewMenuContainer a { + line-height: 7vw; + } + #Navigations #NavigationMenu li.sub-menu .ui-menu-item .ui-menu-item-wrapper { + font-size: 3vw; + padding-left: 6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor .field-normal .field-control .container-normal input[type='checkbox'].control-checkbox { + position: relative; + margin-right: 6px; + margin-top: .3vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Editor #EditorTabsContainer .field-normal, #Editor #EditorTabsContainer .field-wide, #Editor #EditorTabsContainer .field-markdown { + display: inline-block; + margin-top: 8px; + padding-bottom: 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer #Calendar.both select { + font-size: 2.6vw; + } + #ViewModeContainer #Calendar.both .field-label { + min-width: 30%; + margin-right: 15px; + } + #ViewModeContainer #Calendar.both .field-auto-thin .field-control .container-normal { + display: flex; + align-items: center; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) { + flex: 0 1 calc(64%); + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) .field-label { + min-width: 22%; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(3) .field-control { + width: 74%; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) { + flex: 0 1 calc(33% + 1px); + padding-top: 2%; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) .field-control .container-normal { + justify-content: flex-end; + } + #ViewModeContainer #Calendar.both .field-auto-thin:nth-child(4) .field-control .container-normal #CalendarDate { + margin-right: 0; + width: 98%; + font-size: 2.6vw; + } + #ViewModeContainer #Calendar.both button { + flex: 1 0 calc((100% / 3) - 32px); + margin: 2% 10px 2% 10px; + } + #ViewModeContainer .grid.fixed { + width: 100%; + } + #ViewModeContainer .grid.fixed tbody tr td.container .item { + touch-action: auto; + min-height: 50px; + } + #ViewModeContainer .grid.fixed tbody tr td.container .item .title .ui-icon.ui-icon-pencil { + margin-right: 5px; + background-image: url(""); + background-position: center; + width: 36px; + height: 36px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + } + #ViewModeContainer .grid.fixed tbody tr td.container .item .connection { + min-height: 50px; + } + #ViewModeContainer .grid.fixed tbody tr td.container .dummy { + height: 50px; + } + #ViewModeContainer .grid.fixed tbody tr td.container:first-child .item { + margin-top: 0; + margin-bottom: 5px; + } + #ViewModeContainer .grid.fixed tbody tr td.container:not(:first-child) .item { + margin-top: 5px; + } + thead th.calendar-header { + overflow-x: hidden; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .both { + column-gap: 16px; + } + #ViewModeContainer .both .field-auto-thin:first-child, #ViewModeContainer .both .field-auto-thin:nth-child(2) { + flex: 0 1 calc(50% - 8px); + } + #ViewModeContainer .both .field-auto-thin:first-child .field-control, #ViewModeContainer .both .field-auto-thin:nth-child(2) .field-control { + flex: 1; + } + #ViewModeContainer .both .field-auto-thin:first-child .field-control select, #ViewModeContainer .both .field-auto-thin:nth-child(2) .field-control select { + max-width: 100%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) { + row-gap: 12px; + flex-wrap: wrap; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) .field-label { + min-width: 15%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin { + display: flex; + align-items: center; + flex: 1 0 100%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) .field-auto-thin #GanttStartDate { + width: 100%; + font-size: 2.6vw; + margin-right: 0; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) button { + flex: 1; + } + #ViewModeContainer .both .field-auto-thin:nth-child(3) button:last-child { + margin-right: 8px; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) { + width: 100%; + padding-top: 12px; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control { + width: 100%; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal { + width: 100%; + display: flex; + align-items: center; + column-gap: 32px; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal #GanttPeriod\,ui { + width: 99%; + margin-top: 0; + } + #ViewModeContainer .both .field-auto-thin:nth-child(4) .field-control .container-normal #GanttPeriod { + margin: 0; + } + #GanttBody { + max-height: 70vh; + } + #GanttBody text { + font-size: 2.6vw; + } + #GanttBody .title text.summary { + font-size: 3vw; + } + #GanttBody #GanttAxis { + left: auto; + position: sticky; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer #Kamban.both .field-auto-thin select { + font-size: 2.6vw; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1), #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2), #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3), #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField { + width: 100%; + flex: 0 1 calc(50% - 8px); + flex-wrap: wrap; + display: flex; + row-gap: 0; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1) .field-label, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2) .field-label, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) .field-label, #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField .field-label { + width: 100%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(1) select, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(2) select, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) select, #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField select { + max-width: 100%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(3) { + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin#KambanValueField { + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) { + display: block; + width: 100%; + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) .field-label { + min-width: 50%; + margin-right: 10px; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(5) select { + max-width: 100%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(6), #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(7) { + width: calc(50% - 8px); + padding-top: 4%; + } + #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(6) .container-normal, #ViewModeContainer #Kamban.both .field-auto-thin:nth-child(7) .container-normal { + display: flex; + align-items: center; + } + #ViewModeContainer #Kamban.both #KambanBody #Grid tbody .kamban-row .kamban-container .kamban-item { + overflow: hidden; + padding: 6px 30px 6px 5px; + white-space: pre-line; + touch-action: auto; + display: -webkit-box; + -webkit-line-clamp: 1; + -webkit-box-orient: vertical; + } + #ViewModeContainer #Kamban.both #KambanBody #Grid tbody .kamban-row .kamban-container .kamban-item .ui-icon.ui-icon-pencil { + background-image: url(""); + background-position: center; + width: 36px; + height: 36px; + filter: invert(69%) sepia(77%) saturate(3818%) hue-rotate(12deg) brightness(97%) contrast(96%); + margin-right: 0; + top: -7px; + right: -11px; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #RecordSwitchers { + display: flex; + align-items: center; + } + #RecordSwitchers #CurrentIndex { + height: 7.5vw; + display: flex; + align-items: center; + } +} + +@media screen and (max-width: 980px) and (min-width: 0) { + #Editor #RecordHeader .user { + display: flex; + align-items: center; + } + #Editor #RecordHeader .user .ui-icon-person { + margin-right: 0.6vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #OutgoingMailDialog .field-wide { + padding-bottom: 5px; + } + #OutgoingMailDialog .field-wide .field-label { + width: auto; + } + #OutgoingMailDialog .field-wide .field-control { + float: none; + } + #OutgoingMailDialog .field-wide .control-basket, + #OutgoingMailDialog .field-wide .container-normal { + margin-left: 15vw; + } + #OutgoingMailDialog textarea { + height: 20vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + .show-password { + top: calc(50% - 10px); + right: 10px; + } + #LoginFieldSet input[type=checkbox] { + transform: scale(1.2); + } + #LoginFieldSet input, + #LoginFieldSet select { + font-size: 4vw; + } + #Users_RememberMeField .container-normal { + display: flex; + align-items: center; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #Navigations.open { + padding-top: 18vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .field-auto-thin > .field-label { + padding: 7px 2vw 7px 0; + } + #CrosstabValueField .field-control { + width: 70%; + } + #Crosstab .field-auto-thin p { + margin-right: 0%; + } + #ViewModeContainer #Crosstab .field-auto-thin { + width: 100%; + flex: 0 1 calc(100%); + padding-top: 1vw; + } + #ViewModeContainer #Crosstab .field-auto-thin .field-label { + width: 30%; + } + #ViewModeContainer #Crosstab .field-auto-thin .field-control { + width: 70%; + } + #ViewModeContainer #Crosstab .field-auto-thin .field-control input[type='checkbox'], + #ViewModeContainer #Crosstab .field-auto-thin .field-control .field-auto-thin input[type='checkbox'] { + width: 4vw; + height: 4vw; + margin-left: 2px; + } + #CrosstabBody .grid > thead > tr:first-child > th:not(:first-child), + #KambanBody .grid > thead > tr:first-child > th:not(:first-child) { + white-space: nowrap; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ImportSettingsDialog .control-checkbox + label { + margin: 1.8vw 0 0 1vw; + } + #ImportSettingsDialog .control-checkbox { + margin: 2vw 0 2vw 2px; + } + #ImportSettingsDialog .control-textbox { + height: 7vw; + line-height: 6.5vw; + } + #ImportSettingsDialog .command-center { + padding: 2vw 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ExportSelectorDialog .command-center { + padding: 2vw 0; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer #Grid .datepicker { + width: 35vw; + font-size: 4vw; + } +} + +@media screen and (max-width: 980px) and (min-width: 0px) { + #ViewModeContainer .both #TimeSeriesValueField, + #ViewModeContainer .both #TimeSeriesChartTypeField, + #ViewModeContainer .both #TimeSeriesHorizontalAxisField { + width: 100%; + } + #ViewModeContainer .both #TimeSeriesValueField .field-label, + #ViewModeContainer .both #TimeSeriesChartTypeField .field-label, + #ViewModeContainer .both #TimeSeriesHorizontalAxisField .field-label { + min-width: 30%; + } + #ViewModeContainer .both .field-auto-thin:first-child, + #ViewModeContainer .both .field-auto-thin:nth-child(2) { + flex: 0 1 calc(100%); + } + #ViewModeContainer .both .field-auto-thin:first-child .field-label, + #ViewModeContainer .both .field-auto-thin:nth-child(2) .field-label { + min-width: 30%; + } + #ViewModeContainer .both .field-auto-thin select { + max-width: 100%; + } + #ViewModeContainer .both .field-auto-thin > .field-control { + min-width: 68%; + } } \ No newline at end of file diff --git a/Implem.TestAutomation/implem.TestAutomation.csproj b/Implem.TestAutomation/implem.TestAutomation.csproj index 5c81a3fcf..8629e360a 100644 --- a/Implem.TestAutomation/implem.TestAutomation.csproj +++ b/Implem.TestAutomation/implem.TestAutomation.csproj @@ -4,9 +4,9 @@ Exe net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 Linux
diff --git a/Rds/Implem.IRds/Implem.IRds.csproj b/Rds/Implem.IRds/Implem.IRds.csproj index 378a29b06..868e0ea86 100644 --- a/Rds/Implem.IRds/Implem.IRds.csproj +++ b/Rds/Implem.IRds/Implem.IRds.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Rds/Implem.PostgreSql/Implem.PostgreSql.csproj b/Rds/Implem.PostgreSql/Implem.PostgreSql.csproj index cd6a0c9ef..a0ecc9983 100644 --- a/Rds/Implem.PostgreSql/Implem.PostgreSql.csproj +++ b/Rds/Implem.PostgreSql/Implem.PostgreSql.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable diff --git a/Rds/Implem.SqlServer/Implem.SqlServer.csproj b/Rds/Implem.SqlServer/Implem.SqlServer.csproj index 315a343ba..b7880a036 100644 --- a/Rds/Implem.SqlServer/Implem.SqlServer.csproj +++ b/Rds/Implem.SqlServer/Implem.SqlServer.csproj @@ -3,9 +3,9 @@ net6.0 Copyright © Implem Inc 2014 - 2023 - 1.3.46.1 - 1.3.46.1 - 1.3.46.1 + 1.3.47.0 + 1.3.47.0 + 1.3.47.0 disable