Updated Static Site Files
This commit is contained in:
@ -70,7 +70,7 @@ public class ProcessData : IProcessData
|
||||
ReadOnlyDictionary<int, Record> keyValuePairs = GetWorkItems(workItems);
|
||||
WriteFileStructure(destinationDirectory, keyValuePairs);
|
||||
WriteFiles(fileRead, destinationDirectory, fileInfoCollection, fileNameWithoutExtension, keyValuePairs);
|
||||
WriteKanbanFiles(fileRead, destinationDirectory, cssLines, frontMatterLines, fileInfoCollection, keyValuePairs);
|
||||
WriteKanbanFiles(fileRead, url, cssLines, frontMatterLines, fileInfoCollection, destinationDirectory, keyValuePairs);
|
||||
}
|
||||
|
||||
private static ReadOnlyDictionary<int, Record> GetWorkItems(WorkItem[] workItems)
|
||||
@ -95,7 +95,7 @@ public class ProcessData : IProcessData
|
||||
}
|
||||
}
|
||||
|
||||
private void WriteFiles(IFileRead fileRead, string destinationDirectory, List<FileInfo> fileInfoCollection, string fileNameWithoutExtension, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
private static void WriteFiles(IFileRead fileRead, string destinationDirectory, List<FileInfo> fileInfoCollection, string fileNameWithoutExtension, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
{
|
||||
string old;
|
||||
string json;
|
||||
@ -127,32 +127,34 @@ public class ProcessData : IProcessData
|
||||
|
||||
}
|
||||
|
||||
private void WriteKanbanFiles(IFileRead fileRead, string destinationDirectory, ReadOnlyCollection<string> cssLines, ReadOnlyCollection<string> frontMatterLines, List<FileInfo> fileInfoCollection, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
private static void WriteKanbanFiles(IFileRead fileRead, string url, ReadOnlyCollection<string> cssLines, ReadOnlyCollection<string> frontMatterLines, List<FileInfo> fileInfoCollection, string destinationDirectory, ReadOnlyDictionary<int, Record> keyValuePairs)
|
||||
{
|
||||
string old;
|
||||
string json;
|
||||
Record record;
|
||||
string markdown;
|
||||
string checkFile;
|
||||
string jsonDirectory;
|
||||
string tasksDirectory;
|
||||
string kanbanDirectory;
|
||||
string vscodeDirectory;
|
||||
string[] iterationPaths;
|
||||
string singletonDirectory;
|
||||
List<string> indexLines = new();
|
||||
string iterationPathDirectory;
|
||||
JsonSerializerOptions jsonSerializerOptions = new() { WriteIndented = true };
|
||||
foreach (KeyValuePair<int, Record> keyValuePair in keyValuePairs)
|
||||
{
|
||||
record = keyValuePair.Value;
|
||||
singletonDirectory = destinationDirectory;
|
||||
iterationPathDirectory = destinationDirectory;
|
||||
iterationPaths = record.WorkItem.IterationPath.Split('\\');
|
||||
json = JsonSerializer.Serialize(record, jsonSerializerOptions);
|
||||
foreach (string iterationPath in iterationPaths)
|
||||
{
|
||||
if (iterationPath.Contains("Sprint"))
|
||||
continue;
|
||||
singletonDirectory = Path.Combine(singletonDirectory, iterationPath);
|
||||
iterationPathDirectory = Path.Combine(iterationPathDirectory, iterationPath);
|
||||
}
|
||||
singletonDirectory = Path.Combine(singletonDirectory, record.WorkItem.WorkItemType.Replace(" ", "-"), $"{record.WorkItem.Id}-{record.WorkItem.WorkItemType.Replace(" ", "-")}");
|
||||
singletonDirectory = Path.Combine(iterationPathDirectory, record.WorkItem.WorkItemType.Replace(" ", "-"), $"{record.WorkItem.Id}-{record.WorkItem.WorkItemType.Replace(" ", "-")}");
|
||||
kanbanDirectory = Path.Combine(singletonDirectory, ".kanbn");
|
||||
if (!Directory.Exists(kanbanDirectory))
|
||||
_ = Directory.CreateDirectory(kanbanDirectory);
|
||||
@ -162,35 +164,28 @@ public class ProcessData : IProcessData
|
||||
vscodeDirectory = Path.Combine(singletonDirectory, ".vscode");
|
||||
if (!Directory.Exists(vscodeDirectory))
|
||||
_ = Directory.CreateDirectory(vscodeDirectory);
|
||||
jsonDirectory = Path.Combine(singletonDirectory, record.WorkItem.Id.ToString());
|
||||
if (!Directory.Exists(jsonDirectory))
|
||||
_ = Directory.CreateDirectory(jsonDirectory);
|
||||
checkFile = Path.Combine(vscodeDirectory, "settings.json");
|
||||
if (!File.Exists(checkFile))
|
||||
File.WriteAllText(checkFile, "{ \"[markdown]\": { \"editor.wordWrap\": \"off\" }, \"cSpell.words\": [ \"kanbn\" ] }");
|
||||
indexLines.Clear();
|
||||
indexLines.AddRange(frontMatterLines);
|
||||
indexLines.Add(string.Empty);
|
||||
indexLines.Add($"# {record.WorkItem.Id}");
|
||||
indexLines.Add(string.Empty);
|
||||
indexLines.Add("## Backlog");
|
||||
indexLines.Add(string.Empty);
|
||||
indexLines.Add("## Todo");
|
||||
indexLines.Add(string.Empty);
|
||||
indexLines.Add("## In Progress");
|
||||
indexLines.Add(string.Empty);
|
||||
indexLines.Add("## Done");
|
||||
markdown = GetIndexLines(frontMatterLines, record);
|
||||
checkFile = Path.Combine(kanbanDirectory, "board.css");
|
||||
if (!File.Exists(checkFile))
|
||||
File.WriteAllLines(checkFile, cssLines);
|
||||
checkFile = Path.Combine(kanbanDirectory, "index.md");
|
||||
if (!File.Exists(checkFile))
|
||||
File.WriteAllLines(checkFile, indexLines);
|
||||
checkFile = Path.Combine(kanbanDirectory, ".json");
|
||||
if (File.Exists(checkFile))
|
||||
{
|
||||
old = File.ReadAllText(checkFile);
|
||||
if (old == json)
|
||||
continue;
|
||||
}
|
||||
File.WriteAllText(checkFile, json);
|
||||
File.WriteAllText(checkFile, markdown);
|
||||
checkFile = Path.Combine(jsonDirectory, ".json");
|
||||
old = File.Exists(checkFile) ? File.ReadAllText(checkFile) : string.Empty;
|
||||
if (old != json)
|
||||
File.WriteAllText(checkFile, json);
|
||||
markdown = GetMarkdownLines(url, record, jsonDirectory, iterationPathDirectory);
|
||||
checkFile = Path.Combine(vscodeDirectory, "markdown.md");
|
||||
old = File.Exists(checkFile) ? File.ReadAllText(checkFile) : string.Empty;
|
||||
if (old != markdown)
|
||||
File.WriteAllText(checkFile, markdown);
|
||||
if (!fileRead.IsEAFHosted)
|
||||
fileInfoCollection.Add(new(checkFile));
|
||||
}
|
||||
@ -213,11 +208,11 @@ public class ProcessData : IProcessData
|
||||
try
|
||||
{
|
||||
records = GetKeyValuePairs(keyValuePairs, keyValuePair.Value, nests);
|
||||
record = new(keyValuePair.Value, parentWorkItem, records, null);
|
||||
record = new(keyValuePair.Value, parentWorkItem, records);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
record = new(keyValuePair.Value, parentWorkItem, new(Array.Empty<Record>()), null);
|
||||
record = new(keyValuePair.Value, parentWorkItem, new(Array.Empty<Record>()));
|
||||
}
|
||||
results.Add(keyValuePair.Key, record);
|
||||
}
|
||||
@ -251,6 +246,49 @@ public class ProcessData : IProcessData
|
||||
return new(results.Distinct().ToArray());
|
||||
}
|
||||
|
||||
private static string GetIndexLines(ReadOnlyCollection<string> frontMatterLines, Record record)
|
||||
{
|
||||
List<string> results = new();
|
||||
results.Clear();
|
||||
results.AddRange(frontMatterLines);
|
||||
results.Add(string.Empty);
|
||||
results.Add($"# {record.WorkItem.Id}");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## Backlog");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## Todo");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## In Progress");
|
||||
results.Add(string.Empty);
|
||||
results.Add("## Done");
|
||||
results.Add(string.Empty);
|
||||
return string.Join(Environment.NewLine, results);
|
||||
}
|
||||
|
||||
private static string GetMarkdownLines(string url, Record record, string jsonDirectory, string iterationPathDirectory)
|
||||
{
|
||||
List<string> results = new();
|
||||
string link;
|
||||
string target;
|
||||
results.Add($"# {record.WorkItem.Id}");
|
||||
results.Add(string.Empty);
|
||||
results.Add($"## {record.WorkItem.Title}");
|
||||
results.Add(string.Empty);
|
||||
foreach (Record r in record.Children)
|
||||
results.Add($"- [{r.WorkItem.Id}]({url}{r.WorkItem.Id})");
|
||||
results.Add(string.Empty);
|
||||
results.Add("```bash");
|
||||
foreach (Record r in record.Children)
|
||||
{
|
||||
link = Path.Combine(jsonDirectory, $"{r.WorkItem.Id}-{r.WorkItem.WorkItemType}");
|
||||
target = Path.Combine(iterationPathDirectory, r.WorkItem.WorkItemType, $"{r.WorkItem.Id}-{r.WorkItem.WorkItemType}", r.WorkItem.Id.ToString());
|
||||
results.Add($"mklink /J \"{link}\" \"{target}\"");
|
||||
}
|
||||
results.Add("```");
|
||||
results.Add(string.Empty);
|
||||
return string.Join(Environment.NewLine, results);
|
||||
}
|
||||
|
||||
private static ReadOnlyCollection<Record> GetKeyValuePairs(ReadOnlyDictionary<int, WorkItem> keyValuePairs, WorkItem workItem, List<bool> nests)
|
||||
{
|
||||
List<Record> results = new();
|
||||
@ -283,7 +321,7 @@ public class ProcessData : IProcessData
|
||||
else
|
||||
_ = keyValuePairs.TryGetValue(w.Parent.Value, out parentWorkItem);
|
||||
records = GetKeyValuePairs(keyValuePairs, w, nests);
|
||||
record = new(w, parentWorkItem, records, null);
|
||||
record = new(w, parentWorkItem, records);
|
||||
results.Add(record);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user