diff --git a/Assets/Scenes/Level01.unity b/Assets/Scenes/Level01.unity index f636726fa8078335f12021a99ee86372f2dace01..4d2b26fec68189c23611e05206994ecb36afaf6e 100644 --- a/Assets/Scenes/Level01.unity +++ b/Assets/Scenes/Level01.unity @@ -2659,9 +2659,9 @@ MonoBehaviour: m_OnClick: m_PersistentCalls: m_Calls: - - m_Target: {fileID: 0} - m_TargetAssemblyTypeName: MainMenuManager, Assembly-CSharp - m_MethodName: LoadGame + - m_Target: {fileID: 1664473422} + m_TargetAssemblyTypeName: Nightmare.SaveManager, Assembly-CSharp + m_MethodName: Save m_Mode: 3 m_Arguments: m_ObjectArgument: {fileID: 0} @@ -4360,7 +4360,7 @@ MonoBehaviour: m_Script: {fileID: 11500000, guid: 660127adb6b066043a008b88ccbbe913, type: 3} m_Name: m_EditorClassIdentifier: - countdownDuration: 60 + countdownDuration: 3 countdownText: {fileID: 961404588} --- !u!114 &564408470 MonoBehaviour: @@ -6967,7 +6967,7 @@ GameObject: - component: {fileID: 817289309} - component: {fileID: 817289308} m_Layer: 5 - m_Name: SlotFIlesPanel + m_Name: SlotFilePanel m_TagString: Untagged m_Icon: {fileID: 0} m_NavMeshLayer: 0 @@ -9345,9 +9345,9 @@ MonoBehaviour: m_OnClick: m_PersistentCalls: m_Calls: - - m_Target: {fileID: 0} - m_TargetAssemblyTypeName: MainMenuManager, Assembly-CSharp - m_MethodName: LoadGame + - m_Target: {fileID: 1664473422} + m_TargetAssemblyTypeName: Nightmare.SaveManager, Assembly-CSharp + m_MethodName: Save m_Mode: 3 m_Arguments: m_ObjectArgument: {fileID: 0} @@ -9946,6 +9946,8 @@ Transform: - {fileID: 1967859029} - {fileID: 522075883} - {fileID: 1561614410} + - {fileID: 1664473421} + - {fileID: 1494457707} m_Father: {fileID: 0} m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} --- !u!1 &1171939603 @@ -12135,6 +12137,50 @@ Transform: m_Children: [] m_Father: {fileID: 0} m_LocalEulerAnglesHint: {x: 30, y: 0, z: 0} +--- !u!1 &1494457706 +GameObject: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + serializedVersion: 6 + m_Component: + - component: {fileID: 1494457707} + - component: {fileID: 1494457708} + m_Layer: 0 + m_Name: PlayTimeManager + m_TagString: Untagged + m_Icon: {fileID: 0} + m_NavMeshLayer: 0 + m_StaticEditorFlags: 0 + m_IsActive: 1 +--- !u!4 &1494457707 +Transform: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1494457706} + serializedVersion: 2 + m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} + m_LocalPosition: {x: 0, y: 0, z: 0} + m_LocalScale: {x: 1, y: 1, z: 1} + m_ConstrainProportionsScale: 0 + m_Children: [] + m_Father: {fileID: 1165414997} + m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} +--- !u!114 &1494457708 +MonoBehaviour: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1494457706} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 11500000, guid: c12072774c03cc847a7e2b2a3916116c, type: 3} + m_Name: + m_EditorClassIdentifier: --- !u!1 &1512961169 GameObject: m_ObjectHideFlags: 0 @@ -13338,6 +13384,58 @@ CanvasRenderer: m_PrefabAsset: {fileID: 0} m_GameObject: {fileID: 1652776653} m_CullTransparentMesh: 1 +--- !u!1 &1664473420 +GameObject: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + serializedVersion: 6 + m_Component: + - component: {fileID: 1664473421} + - component: {fileID: 1664473422} + m_Layer: 0 + m_Name: SaveManager + m_TagString: Untagged + m_Icon: {fileID: 0} + m_NavMeshLayer: 0 + m_StaticEditorFlags: 0 + m_IsActive: 1 +--- !u!4 &1664473421 +Transform: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1664473420} + serializedVersion: 2 + m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} + m_LocalPosition: {x: 0, y: 0, z: 0} + m_LocalScale: {x: 1, y: 1, z: 1} + m_ConstrainProportionsScale: 0 + m_Children: [] + m_Father: {fileID: 1165414997} + m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} +--- !u!114 &1664473422 +MonoBehaviour: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1664473420} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 11500000, guid: ee3659762bac6df4c8e4b05db6002eed, type: 3} + m_Name: + m_EditorClassIdentifier: + playerNameTexts: + - {fileID: 227101467} + - {fileID: 568848476} + - {fileID: 50078063} + playTimeTexts: + - {fileID: 326241295} + - {fileID: 1114854962} + - {fileID: 152646569} --- !u!1 &1683328810 GameObject: m_ObjectHideFlags: 0 @@ -15913,6 +16011,7 @@ MonoBehaviour: m_EditorClassIdentifier: starText: {fileID: 374433001} completedText: {fileID: 2023060740} + playerName: {fileID: 758281166} timeTextParent: {fileID: 1683328810} nextButton: {fileID: 794014896} --- !u!1 &1972235736 @@ -16141,9 +16240,9 @@ MonoBehaviour: m_OnClick: m_PersistentCalls: m_Calls: - - m_Target: {fileID: 0} - m_TargetAssemblyTypeName: MainMenuManager, Assembly-CSharp - m_MethodName: LoadGame + - m_Target: {fileID: 1664473422} + m_TargetAssemblyTypeName: Nightmare.SaveManager, Assembly-CSharp + m_MethodName: Save m_Mode: 3 m_Arguments: m_ObjectArgument: {fileID: 0} diff --git a/Assets/Scenes/Level02.unity b/Assets/Scenes/Level02.unity index d1a130e3c02ae6bde75bb5559fbfbd5e3254e43d..fc497872c5821fb6187d873c73f98c10578a0e90 100644 --- a/Assets/Scenes/Level02.unity +++ b/Assets/Scenes/Level02.unity @@ -16183,6 +16183,7 @@ MonoBehaviour: m_EditorClassIdentifier: starText: {fileID: 374433001} completedText: {fileID: 2023060740} + playerName: {fileID: 758281166} timeTextParent: {fileID: 1683328810} nextButton: {fileID: 2665492} --- !u!1 &1978917666 diff --git a/Assets/Scenes/Level03.unity b/Assets/Scenes/Level03.unity index dc2ae800c68b0ef2647e04d29b1ec5e175ebe1b1..71844ce8bd740aaf15e747ade78a2106b9cf0aae 100644 --- a/Assets/Scenes/Level03.unity +++ b/Assets/Scenes/Level03.unity @@ -16617,6 +16617,7 @@ MonoBehaviour: m_EditorClassIdentifier: starText: {fileID: 374433001} completedText: {fileID: 2023060740} + playerName: {fileID: 758281166} timeTextParent: {fileID: 1683328810} nextButton: {fileID: 1850578051} --- !u!1 &1978917666 diff --git a/Assets/Scenes/Level04.unity b/Assets/Scenes/Level04.unity index f3587eba34b0595fac0d79aefc0e59216859663d..951998a1fd2e0640ba11881cdb6096cd932a1e29 100644 --- a/Assets/Scenes/Level04.unity +++ b/Assets/Scenes/Level04.unity @@ -16417,6 +16417,7 @@ MonoBehaviour: m_EditorClassIdentifier: starText: {fileID: 374433001} completedText: {fileID: 2023060740} + playerName: {fileID: 758281166} timeTextParent: {fileID: 1683328810} nextButton: {fileID: 840393620} --- !u!1 &1978917666 diff --git a/Assets/Scripts/Global/CurrentStateData.cs b/Assets/Scripts/Global/CurrentStateData.cs index 96664bf473e49884d2e9459273f1738eb6c65665..774e88b784a520d11560bae396735c8bcadd4d0f 100644 --- a/Assets/Scripts/Global/CurrentStateData.cs +++ b/Assets/Scripts/Global/CurrentStateData.cs @@ -85,7 +85,7 @@ public class CurrentStateData var saveEntry = new SaveEntry { saveName = saveName, - saveDateTime = DateTime.Now, + saveDateTime = DateTime.UtcNow.AddHours(7), playerName = _currentGameData.playerName, playTime = _currentGameData.playTime, star = _currentGameData.star, diff --git a/Assets/Scripts/Managers/HUDCanvasManager.cs b/Assets/Scripts/Managers/HUDCanvasManager.cs index 9adf47e8107570c70323f21118e14e6a00182de2..e1f05f3933b0cf2dd0043bf7bc2151d82e2357d6 100644 --- a/Assets/Scripts/Managers/HUDCanvasManager.cs +++ b/Assets/Scripts/Managers/HUDCanvasManager.cs @@ -7,11 +7,13 @@ namespace Nightmare { public TMP_Text starText; public TMP_Text completedText; + public TMP_Text playerName; public GameObject timeTextParent; public GameObject nextButton; void Start() { + playerName.text = CurrentStateData.GetGlobalPlayerName(); UpdateHUD(); } diff --git a/Assets/Scripts/Managers/NewFile b/Assets/Scripts/Managers/NewFile deleted file mode 100644 index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..0000000000000000000000000000000000000000 diff --git a/Assets/Scripts/Managers/NewFile.meta b/Assets/Scripts/Managers/NewFile.meta deleted file mode 100644 index c9f977960ac53519652a1303e322dd9cc881b1f9..0000000000000000000000000000000000000000 --- a/Assets/Scripts/Managers/NewFile.meta +++ /dev/null @@ -1,7 +0,0 @@ -fileFormatVersion: 2 -guid: 69953b2b8be8a3a4abecbbdcd1af8be1 -DefaultImporter: - externalObjects: {} - userData: - assetBundleName: - assetBundleVariant: diff --git a/Assets/Scripts/Managers/NextSceneManager.cs b/Assets/Scripts/Managers/NextSceneManager.cs index ececd138ea6cc337307f545b7855b40e70d63c42..e5fd64e8abeab22cc214b41e4348181419d82931 100644 --- a/Assets/Scripts/Managers/NextSceneManager.cs +++ b/Assets/Scripts/Managers/NextSceneManager.cs @@ -40,12 +40,5 @@ namespace Nightmare saveFileCanvas.SetActive(true); nextButtonCanvas.SetActive(false); } - - public void NextWithScoreboard() - { - CurrentStateData.AddScoreEntry(CurrentStateData.GetCurrentPlayerName(), CurrentStateData.GetCurrentPlayTime()); - CurrentStateData.ChangeScene(scene); - SceneManager.LoadScene(scene); - } } } \ No newline at end of file diff --git a/Assets/Scripts/Managers/PlayTimeManager.cs b/Assets/Scripts/Managers/PlayTimeManager.cs new file mode 100644 index 0000000000000000000000000000000000000000..35eab3b208fa351156bd7b2f113bcc6f3e78230d --- /dev/null +++ b/Assets/Scripts/Managers/PlayTimeManager.cs @@ -0,0 +1,9 @@ +using UnityEngine; + +public class PlayTimeManager : MonoBehaviour +{ + private void Update() + { + CurrentStateData.AddPlayTime(Time.deltaTime); + } +} \ No newline at end of file diff --git a/Assets/Scripts/Managers/PlayTimeManager.cs.meta b/Assets/Scripts/Managers/PlayTimeManager.cs.meta new file mode 100644 index 0000000000000000000000000000000000000000..02e390a85a32b7377f5c2e91da7c29c54a77b0eb --- /dev/null +++ b/Assets/Scripts/Managers/PlayTimeManager.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: c12072774c03cc847a7e2b2a3916116c +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/Scripts/Managers/SaveManager.cs b/Assets/Scripts/Managers/SaveManager.cs index 2d0f7650f05a43f72109505306f29f2840ba22d2..db410b10fc811119333eac83dd12c2058bd65ca1 100644 --- a/Assets/Scripts/Managers/SaveManager.cs +++ b/Assets/Scripts/Managers/SaveManager.cs @@ -1,87 +1,41 @@ -using TMPro; +using System.Collections; +using System.Collections.Generic; +using UnityEngine.SceneManagement; using UnityEngine; -using UnityEngine.UI; +using TMPro; namespace Nightmare { public class SaveManager : MonoBehaviour { - private static GameObject _saveTitle; - private static GameObject _saveFilesPanel; - private static GameObject _saveNamePanel; - private static int _slotIndex; - - public GameObject inputSaveTitle; - public GameObject inputSaveFilesPanel; - public GameObject inputSaveNamePanel; - - public void Awake() - { - _saveTitle = inputSaveTitle; - _saveFilesPanel = inputSaveFilesPanel; - _saveNamePanel = inputSaveNamePanel; + public TMP_Text[] playerNameTexts; + public TMP_Text[] playTimeTexts; - _saveTitle.SetActive(false); - _saveFilesPanel.SetActive(false); - _saveNamePanel.SetActive(false); - } - - public static void OpenSlotFilesPanel() + // Start is called before the first frame update + void Start() { - _saveTitle.SetActive(true); - _saveFilesPanel.SetActive(true); - _saveNamePanel.SetActive(false); - - /*var saveEntries = CurrentStateData.GetSaveEntries(); - var buttons = _saveFilesPanel.GetComponentsInChildren<Button>(); - var texts = _saveFilesPanel.GetComponentsInChildren<TMP_Text>(); + var saveEntries = CurrentStateData.GetSaveEntries(); - for (var i = 0; i < 3; i++) + for (int i = 0; i < saveEntries.Length; i++) { - var i1 = i; - buttons[i].interactable = true; - buttons[i].onClick.AddListener(() => OpenSaveNamePanel(i1)); - if (saveEntries[i].playTime > 0) { - texts[2 * i].text = saveEntries[i].saveName; - texts[2 * i + 1].text = saveEntries[i].saveDateTime.ToString(); + playerNameTexts[i].text = saveEntries[i].saveName; + playTimeTexts[i].text = saveEntries[i].saveDateTime.ToString() + " WIB"; } else { - texts[2 * i].text = "(Empty Slot)"; - texts[2 * i + 1].text = ""; + playerNameTexts[i].text = "Slot " + (i+1).ToString(); + playTimeTexts[i].text = "Empty"; } - }*/ - } - - private static void OpenSaveNamePanel(int index) - { - _saveTitle.SetActive(false); - _saveFilesPanel.SetActive(false); - _saveNamePanel.SetActive(true); - - _slotIndex = index; - InputManager.SetText($"Save Slot {index + 1}"); - } - - public static int GetCurrentSlotIndex() - { - return _slotIndex; - } - - public static void OnSave() - { - _saveTitle.SetActive(false); - _saveFilesPanel.SetActive(false); - _saveNamePanel.SetActive(false); + } } - public static void OnBack() + public void Save(int index) { - _saveTitle.SetActive(true); - _saveFilesPanel.SetActive(true); - _saveNamePanel.SetActive(false); + QuestManager.ClearObjectives(); + CurrentStateData.SaveGameData(CurrentStateData.GetGlobalPlayerName(), index); + SceneManager.LoadScene(CurrentStateData.GetCurrentScene()); } } -} \ No newline at end of file +} diff --git a/UpgradeLog2.htm b/UpgradeLog2.htm new file mode 100644 index 0000000000000000000000000000000000000000..eec7b743a756e520b08393d2cd894772b19a1228 --- /dev/null +++ b/UpgradeLog2.htm @@ -0,0 +1,274 @@ +<!DOCTYPE html> +<!-- saved from url=(0014)about:internet --> + <html xmlns:msxsl="urn:schemas-microsoft-com:xslt"><head><meta content="en-us" http-equiv="Content-Language" /><meta content="text/html; charset=utf-16" http-equiv="Content-Type" /><title _locID="ConversionReport0"> + Migration Report + </title><style> + /* Body style, for the entire document */ + body + { + background: #F3F3F4; + color: #1E1E1F; + font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; + padding: 0; + margin: 0; + } + + /* Header1 style, used for the main title */ + h1 + { + padding: 10px 0px 10px 10px; + font-size: 21pt; + background-color: #E2E2E2; + border-bottom: 1px #C1C1C2 solid; + color: #201F20; + margin: 0; + font-weight: normal; + } + + /* Header2 style, used for "Overview" and other sections */ + h2 + { + font-size: 18pt; + font-weight: normal; + padding: 15px 0 5px 0; + margin: 0; + } + + /* Header3 style, used for sub-sections, such as project name */ + h3 + { + font-weight: normal; + font-size: 15pt; + margin: 0; + padding: 15px 0 5px 0; + background-color: transparent; + } + + /* Color all hyperlinks one color */ + a + { + color: #1382CE; + } + + /* Table styles */ + table + { + border-spacing: 0 0; + border-collapse: collapse; + font-size: 10pt; + } + + table th + { + background: #E7E7E8; + text-align: left; + text-decoration: none; + font-weight: normal; + padding: 3px 6px 3px 6px; + } + + table td + { + vertical-align: top; + padding: 3px 6px 5px 5px; + margin: 0px; + border: 1px solid #E7E7E8; + background: #F7F7F8; + } + + /* Local link is a style for hyperlinks that link to file:/// content, there are lots so color them as 'normal' text until the user mouse overs */ + .localLink + { + color: #1E1E1F; + background: #EEEEED; + text-decoration: none; + } + + .localLink:hover + { + color: #1382CE; + background: #FFFF99; + text-decoration: none; + } + + /* Center text, used in the over views cells that contain message level counts */ + .textCentered + { + text-align: center; + } + + /* The message cells in message tables should take up all avaliable space */ + .messageCell + { + width: 100%; + } + + /* Padding around the content after the h1 */ + #content + { + padding: 0px 12px 12px 12px; + } + + /* The overview table expands to width, with a max width of 97% */ + #overview table + { + width: auto; + max-width: 75%; + } + + /* The messages tables are always 97% width */ + #messages table + { + width: 97%; + } + + /* All Icons */ + .IconSuccessEncoded, .IconInfoEncoded, .IconWarningEncoded, .IconErrorEncoded + { + min-width:18px; + min-height:18px; + background-repeat:no-repeat; + background-position:center; + } + + /* Success icon encoded */ + .IconSuccessEncoded + { + /* Note: Do not delete the comment below. It is used to verify the correctness of the encoded image resource below before the product is released */ + /* [---XsltValidateInternal-Base64EncodedImage:IconSuccess#Begin#background-image: url(data:image/png;base64,#Separator#);#End#] */ + background-image: url(); + } + + /* Information icon encoded */ + .IconInfoEncoded + { + /* Note: Do not delete the comment below. It is used to verify the correctness of the encoded image resource below before the product is released */ + /* [---XsltValidateInternal-Base64EncodedImage:IconInformation#Begin#background-image: url(data:image/png;base64,#Separator#);#End#] */ + background-image: url(); + } + + /* Warning icon encoded */ + .IconWarningEncoded + { + /* Note: Do not delete the comment below. It is used to verify the correctness of the encoded image resource below before the product is released */ + /* [---XsltValidateInternal-Base64EncodedImage:IconWarning#Begin#background-image: url(data:image/png;base64,#Separator#);#End#] */ + background-image: url(); + } + + /* Error icon encoded */ + .IconErrorEncoded + { + /* Note: Do not delete the comment below. It is used to verify the correctness of the encoded image resource below before the product is released */ + /* [---XsltValidateInternal-Base64EncodedImage:IconError#Begin#background-image: url(data:image/png;base64,#Separator#);#End#] */ + background-image: url(); + } + </style><script type="text/javascript" language="javascript"> + + // Startup + // Hook up the the loaded event for the document/window, to linkify the document content + var startupFunction = function() { linkifyElement("messages"); }; + + if(window.attachEvent) + { + window.attachEvent('onload', startupFunction); + } + else if (window.addEventListener) + { + window.addEventListener('load', startupFunction, false); + } + else + { + document.addEventListener('load', startupFunction, false); + } + + // Toggles the visibility of table rows with the specified name + function toggleTableRowsByName(name) + { + var allRows = document.getElementsByTagName('tr'); + for (i=0; i < allRows.length; i++) + { + var currentName = allRows[i].getAttribute('name'); + if(!!currentName && currentName.indexOf(name) == 0) + { + var isVisible = allRows[i].style.display == ''; + isVisible ? allRows[i].style.display = 'none' : allRows[i].style.display = ''; + } + } + } + + function scrollToFirstVisibleRow(name) + { + var allRows = document.getElementsByTagName('tr'); + for (i=0; i < allRows.length; i++) + { + var currentName = allRows[i].getAttribute('name'); + var isVisible = allRows[i].style.display == ''; + if(!!currentName && currentName.indexOf(name) == 0 && isVisible) + { + allRows[i].scrollIntoView(true); + return true; + } + } + + return false; + } + + // Linkifies the specified text content, replaces candidate links with html links + function linkify(text) + { + if(!text || 0 === text.length) + { + return text; + } + + // Find http, https and ftp links and replace them with hyper links + var urlLink = /(http|https|ftp)\:\/\/[a-zA-Z0-9\-\.]+(:[a-zA-Z0-9]*)?\/?([a-zA-Z0-9\-\._\?\,\/\\\+&%\$#\=~;\{\}])*/gi; + + return text.replace(urlLink, '<a href="$&">$&</a>') ; + } + + // Linkifies the specified element by ID + function linkifyElement(id) + { + var element = document.getElementById(id); + if(!!element) + { + element.innerHTML = linkify(element.innerHTML); + } + } + + function ToggleMessageVisibility(projectName) + { + if(!projectName || 0 === projectName.length) + { + return; + } + + toggleTableRowsByName("MessageRowClass" + projectName); + toggleTableRowsByName('MessageRowHeaderShow' + projectName); + toggleTableRowsByName('MessageRowHeaderHide' + projectName); + } + + function ScrollToFirstVisibleMessage(projectName) + { + if(!projectName || 0 === projectName.length) + { + return; + } + + // First try the 'Show messages' row + if(!scrollToFirstVisibleRow('MessageRowHeaderShow' + projectName)) + { + // Failed to find a visible row for 'Show messages', try an actual message row + scrollToFirstVisibleRow('MessageRowClass' + projectName); + } + } + </script></head><body><h1 _locID="ConversionReport"> + Migration Report - </h1><div id="content"><h2 _locID="OverviewTitle">Overview</h2><div id="overview"><table><tr><th></th><th _locID="ProjectTableHeader">Project</th><th _locID="PathTableHeader">Path</th><th _locID="ErrorsTableHeader">Errors</th><th _locID="WarningsTableHeader">Warnings</th><th _locID="MessagesTableHeader">Messages</th></tr><tr><td class="IconErrorEncoded" /><td><strong><a href="#Assembly-CSharp">Assembly-CSharp</a></strong></td><td>Assembly-CSharp.csproj</td><td class="textCentered"><a href="#Assembly-CSharpError">1</a></td><td class="textCentered"><a>0</a></td><td class="textCentered"><a href="#">0</a></td></tr><tr><td class="IconErrorEncoded" /><td><strong><a href="#Assembly-CSharp-Editor">Assembly-CSharp-Editor</a></strong></td><td>Assembly-CSharp-Editor.csproj</td><td class="textCentered"><a href="#Assembly-CSharp-EditorError">1</a></td><td class="textCentered"><a>0</a></td><td class="textCentered"><a href="#">0</a></td></tr><tr><td class="IconSuccessEncoded" /><td><strong><a href="#Solution"><span _locID="OverviewSolutionSpan">Solution</span></a></strong></td><td>if3210-2024-unity-son.sln</td><td class="textCentered"><a>0</a></td><td class="textCentered"><a>0</a></td><td class="textCentered"><a href="#" onclick="ScrollToFirstVisibleMessage('Solution'); return false;">1</a></td></tr></table></div><h2 _locID="SolutionAndProjectsTitle">Solution and projects</h2><div id="messages"><a name="Assembly-CSharp" /><h3>Assembly-CSharp</h3><table><tr id="Assembly-CSharpHeaderRow"><th></th><th class="messageCell" _locID="MessageTableHeader">Message</th></tr><tr name="ErrorRowClassAssembly-CSharp"><td class="IconErrorEncoded"><a name="Assembly-CSharpError" /></td><td class="messageCell"><strong>Assembly-CSharp.csproj: + </strong><span>The application which this project type is based on was not found. Please try this link for further information: http://go.microsoft.com/fwlink/?LinkID=299083&projecttype=E097FAD1-6243-4DAD-9C02-E9B9EFC3FFC1</span></td></tr></table><a name="Assembly-CSharp-Editor" /><h3>Assembly-CSharp-Editor</h3><table><tr id="Assembly-CSharp-EditorHeaderRow"><th></th><th class="messageCell" _locID="MessageTableHeader">Message</th></tr><tr name="ErrorRowClassAssembly-CSharp-Editor"><td class="IconErrorEncoded"><a name="Assembly-CSharp-EditorError" /></td><td class="messageCell"><strong>Assembly-CSharp-Editor.csproj: + </strong><span>The application which this project type is based on was not found. Please try this link for further information: http://go.microsoft.com/fwlink/?LinkID=299083&projecttype=E097FAD1-6243-4DAD-9C02-E9B9EFC3FFC1</span></td></tr></table><a name="Solution" /><h3 _locID="ProjectDisplayNameHeader">Solution</h3><table><tr id="SolutionHeaderRow"><th></th><th class="messageCell" _locID="MessageTableHeader">Message</th></tr><tr name="MessageRowHeaderShowSolution"><td class="IconInfoEncoded" /><td class="messageCell"><a _locID="ShowAdditionalMessages" href="#" name="SolutionMessage" onclick="ToggleMessageVisibility('Solution'); return false;"> + Show 1 additional messages + </a></td></tr><tr name="MessageRowClassSolution" style="display: none"><td class="IconInfoEncoded"><a name="SolutionMessage" /></td><td class="messageCell"><strong>if3210-2024-unity-son.sln: + </strong><span>The solution file does not require migration.</span></td></tr><tr style="display: none" name="MessageRowHeaderHideSolution"><td class="IconInfoEncoded" /><td class="messageCell"><a _locID="HideAdditionalMessages" href="#" name="SolutionMessage" onclick="ToggleMessageVisibility('Solution'); return false;"> + Hide 1 additional messages + </a></td></tr></table></div></div></body></html> \ No newline at end of file