Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Team-11] 새로운 이슈 만들기 기능 추가, DIContainer 에 대한 고찰 #243

Open
wants to merge 69 commits into
base: team-11
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
69 commits
Select commit Hold shift + click to select a range
aea9a63
[Jinsujin/issue-tracker#20] Feat: 새 이슈 생성 시 선택 옵션을 Option enum으로 분리
bibi6666667 Jun 27, 2022
ed0be9c
[Jinsujin/issue-tracker#20] Feat: 새 이슈 생성 시 저장소 선택 화면 구현
bibi6666667 Jun 27, 2022
3611e1a
[Jinsujin/issue-tracker#20] Fix: issue list api
Jinsujin Jun 27, 2022
3c6694a
[Jinsujin/issue-tracker#20] Feat: Repository 엔티티 추가 및 repository 요청 코…
bibi6666667 Jun 27, 2022
7753233
Merge branch 'feat#20' of https://github.com/Jinsujin/issue-tracker i…
Jinsujin Jun 27, 2022
60069e4
[Jinsujin/issue-tracker#20] Feat: OptionSelectViewController 생성을 Cont…
bibi6666667 Jun 27, 2022
fb53b06
[Jinsujin/issue-tracker#20] Refactor: Container에서 OptionSelectViewCon…
bibi6666667 Jun 28, 2022
a17829e
[Jinsujin/issue-tracker#20] Feat: 새 이슈 생성 시 API 요청하여 Repository 불러오기 …
bibi6666667 Jun 28, 2022
d14a0d7
[Jinsujin/issue-tracker#20] Feat: 이슈 만들기 버튼과 API 연결
Jinsujin Jun 28, 2022
09d8f7e
[Jinsujin/issue-tracker#20] Feat: 새 이슈 생성 기능 구현
bibi6666667 Jun 29, 2022
b425f41
[Jinsujin/issue-tracker#20] chore: 불필요한 코드 및 주석 제거
bibi6666667 Jun 29, 2022
547ac43
[Jinsujin/issue-tracker#24] Ref: 옵션 선택하는 화면에서 API 를 호출하도록 수정
Jinsujin Jun 29, 2022
d494374
[Jinsujin/issue-tracker#24] Ref: 선택한 아이템을 이전화면으로 넘길때 리스트에서 option 을 찾…
Jinsujin Jun 29, 2022
43aefc6
[Jinsujin/issue-tracker#24] Feat: 로그인 후, 첫 화면을 repo list 로 변경
Jinsujin Jun 29, 2022
e24536b
[Jinsujin/issue-tracker#24] Feat: 이슈 목록을 불러올때, issue tab 에서 생성한 이슈만 가…
Jinsujin Jun 29, 2022
c200084
Ref: Container 가 token 을 주입받도록 수정
Jinsujin Jun 30, 2022
a30d281
Ref: Container 에서 ViewController 인스턴스 생성시, token 을 주입하도록 함
Jinsujin Jun 30, 2022
4ec1a9f
Feat: 레포지토리 리스트 화면에서의 Model 생성과 연결
Jinsujin Jun 30, 2022
48e7ceb
Ref: navigation 의 largetitle 설정
Jinsujin Jun 30, 2022
94700a7
[Jinsujin/issue-tracker] Feat: NewIssueModel 계층 추가
bibi6666667 Jun 30, 2022
f4b1f07
[Jinsujin/issue-tracker] chore: 불필요한 코드 및 주석 삭제
bibi6666667 Jun 30, 2022
3200b4f
[Jinsujin/issue-tracker] OptionSelectModel 계층 추가
bibi6666667 Jun 30, 2022
bc006c4
[Jinsujin/issue-tracker] Feat: 새 이슈 생성 시 Label 붙이는 기능 추가
bibi6666667 Jun 30, 2022
5e8b77a
Feat: 선택한 옵션이 무엇인지에 따라서 다른데이터를 불러오도록 수정
Jinsujin Jun 30, 2022
d2675b2
Feat: assignees 를 불러오는 API작업중
Jinsujin Jun 30, 2022
b398019
[Jinsujin/issue-tracker] Feat: 새 이슈 생성 시 해당 저장소에 대한 Assignee 조회 구현
bibi6666667 Jul 1, 2022
b86ec49
[Jinsujin/issue-tracker] Feat: 제목, 내용, label, milestone, assignee를 포함…
bibi6666667 Jul 1, 2022
1ddb879
[Jinsujin/issue-tracker] 불필요한 코드, 주석 삭제 및 파일 분리
bibi6666667 Jul 1, 2022
d5c4855
Ref: GithubUserDefaults 의 static 제거
Jinsujin Jul 8, 2022
709b78b
Ref: Repos 바인딩을 Container 에 하도록 변경
Jinsujin Jul 8, 2022
cf39c51
Doc: readme.md 업뎃
Jinsujin Jul 8, 2022
94f6cb2
[Jinsujin/issue-tracker] #28 Container의 의존성을 관리하는 ContainerEnvironmen…
bibi6666667 Jul 19, 2022
2cf9ed0
[Jinsujin/issue-tracker #28] ReposModel의 의존성인 IssueService.requestRep…
bibi6666667 Jul 19, 2022
c5bca22
Revert "[Jinsujin/issue-tracker #28] ReposModel의 의존성인 IssueService.re…
bibi6666667 Jul 20, 2022
f1dc0ce
[Jinsujin/issue-tracker #28] ReposModel의 의존성인 IssueService.requestRep…
bibi6666667 Jul 19, 2022
d791820
[Jinsujin/issue-tracker] #28 IssueModel이 service 전체를 받지 않고, service에서…
bibi6666667 Jul 21, 2022
aaf1c2f
[Jinsujin/issue-tracker] #28 Feat: NewIssueModel에 service 전체 대신, 필요한 …
bibi6666667 Jul 21, 2022
7e9b7ba
[Jinsujin/issue-tracker] #28 Feat: OptionSelect에서 사용하는 service의 메서드들을…
bibi6666667 Jul 21, 2022
3dce5a4
[Jinsujin/issue-tracker] #28 Refactor: LoginVC와 LoginModel 분리 및 OAuth…
bibi6666667 Jul 22, 2022
2aa67de
[Jinsujin/issue-tracker] #28 Refactor: IssueVC 생성 시 필요한 작업을 viewDidLo…
bibi6666667 Jul 25, 2022
da4fa97
[Jinsujin/issue-tracker] #28 Refactor: OptionSelectVC 생성 시 필요한 설정 부분을…
bibi6666667 Jul 25, 2022
4d2672b
Merge branch 'develop' into bibi/refactor
bibi6666667 Jul 25, 2022
a54d231
Merge pull request #29 from Jinsujin/bibi/refactor
bibi6666667 Aug 9, 2022
7eb9168
Feat : AppDelegate를 위한 코디네이터인 AppCoordinator 생성 및 실행 시점 rootVC 판단 로직 분리
bibi6666667 Aug 9, 2022
50e1cb4
Feat: Container에 register, resolve 패턴 적용해 Login/Repos 화면 전환
bibi6666667 Aug 11, 2022
c43f970
Feat: ReposVC에 코디네이터와 컨테이너 적용
bibi6666667 Aug 16, 2022
7bf8c02
Feat: ReposViewController를 보여줄 때 ReposCoordinator를 사용하도록 변경
bibi6666667 Aug 19, 2022
1065a7b
Feat: IssueViewController 화면 흐름을 관리하는 IssueCoordinator 추가 #28
bibi6666667 Aug 31, 2022
93724ce
Feat: NewIssueViewController를 관리하는 NewIssueCoordinator 추가 및 새 이슈 생성에 …
bibi6666667 Aug 31, 2022
300373e
Feat: 모든 뷰컨에 coordinator 프로퍼티 추가 및 NewIssue 생성 시 뒤로가기 동작 구현 #28
bibi6666667 Aug 31, 2022
7170c83
Feat: OptionSelectViewController를 관리하는 OptionSelectCoordinator 추가 #28
bibi6666667 Aug 31, 2022
9f80da2
Feat : coordinator생성 시 register한 뒤, childCoordinators 관리할 때 활용 #28
bibi6666667 Sep 2, 2022
e3a03eb
Feat : 이슈생성, 옵션선택 후 coordinator에서 이전 화면으로 되돌아가며 reload호출 (동작하지 않음) #28
bibi6666667 Sep 2, 2022
c94cb85
Feat : OptionSelectVC를 coordinator로 연결 - 옵션마다 다른 화면 생성 #28
bibi6666667 Sep 2, 2022
6f7ac28
Merge branch 'bibi/refactor' of https://github.com/Jinsujin/issue-tra…
bibi6666667 Sep 2, 2022
7e2c599
Feat : 이슈 생성 요청과 이슈목록 요청 사이에 딜레이 추가, 받아온 이슈에 새로 생성한 이슈가 없다면 재요청 #28
bibi6666667 Sep 5, 2022
cf7c960
Chore : 미사용 메서드와 주석 삭제 #28
bibi6666667 Sep 5, 2022
00867fb
Chore : 불필요한 주석 및 코드 삭제 #28
bibi6666667 Sep 6, 2022
5865265
refactor: ViewController deinit이 호출되지 않는 문제 디버깅 #28
bibi6666667 Sep 15, 2022
75a66ca
refactor: 변수명을 적절하게 수정 #28
bibi6666667 Sep 15, 2022
264ed97
refactor: 불필요한 self 키워드 삭제 #28
bibi6666667 Sep 15, 2022
d37d8c9
refactor: 이슈 생성 요청 이후 새 이슈가 생성되었는지 확인한 다음 이슈 목록으로 되돌아가도록 변경 (뷰 미완성) #28
bibi6666667 Sep 15, 2022
55b3b87
refactor : 새 이슈 생성 -> 이슈 조회 흐름 수정. #28
bibi6666667 Sep 16, 2022
0d2db84
debug : 로그인 직후 앱으로 돌아왔을 때 저장소 목록이 나오지 않는 현상 디버깅(해결) #28
bibi6666667 Sep 21, 2022
6e2fcec
refactor : Container에서 뷰컨트롤러와 관련 코디네이터를 묶어 관리하고 삭제 작업도 처리하도록 변경 #28
bibi6666667 Sep 22, 2022
448b9dd
refactor : 뷰컨트롤러와 관련 코디네이터 이름을 담은 ViewControllerCoordinator 열거형을 사용해 …
bibi6666667 Sep 22, 2022
f44007b
chore : 불필요한 주석 및 print문 삭제 #28
bibi6666667 Sep 22, 2022
c5d1b0b
debug : IssueService 초기화를 위해 토큰 기본값을 넘기는 대신 옵셔널로 타입 수정 #28
bibi6666667 Sep 26, 2022
13517eb
Merge pull request #31 from Jinsujin/bibi/refactor
bibi6666667 Sep 30, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
94 changes: 87 additions & 7 deletions IssueTracker/IssueTracker.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,19 @@
objects = {

/* Begin PBXBuildFile section */
000B92C2286D67F8009EB2D8 /* NewIssueModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 000B92C1286D67F8009EB2D8 /* NewIssueModel.swift */; };
000B92C4286D6816009EB2D8 /* Option.swift in Sources */ = {isa = PBXBuildFile; fileRef = 000B92C3286D6816009EB2D8 /* Option.swift */; };
000B92C7286D6F9D009EB2D8 /* OptionSelectModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 000B92C6286D6F9D009EB2D8 /* OptionSelectModel.swift */; };
004800F6286E8C0700A58B2A /* Assignee.swift in Sources */ = {isa = PBXBuildFile; fileRef = 004800F5286E8C0700A58B2A /* Assignee.swift */; };
004800F8286E907300A58B2A /* Optionable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 004800F7286E907300A58B2A /* Optionable.swift */; };
0053D7552859B162006614EC /* Config.plist in Resources */ = {isa = PBXBuildFile; fileRef = 0053D7542859B162006614EC /* Config.plist */; };
0053D7572859B4CA006614EC /* PrivateStorage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0053D7562859B4CA006614EC /* PrivateStorage.swift */; };
00567EE8286194DB00F3E8EC /* IssueService.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00567EE7286194DB00F3E8EC /* IssueService.swift */; };
00567EEC2861B49F00F3E8EC /* IssueModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00567EEB2861B49F00F3E8EC /* IssueModel.swift */; };
005E48D62862AE91004BD5F6 /* Container.swift in Sources */ = {isa = PBXBuildFile; fileRef = 005E48D52862AE91004BD5F6 /* Container.swift */; };
005E48D828630635004BD5F6 /* NewIssueViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 005E48D728630635004BD5F6 /* NewIssueViewController.swift */; };
005E48DA28636064004BD5F6 /* Devider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 005E48D928636064004BD5F6 /* Devider.swift */; };
00AF8F282869A7060009674C /* Repository.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00AF8F272869A7060009674C /* Repository.swift */; };
00BCB406285B01AA005E87BC /* Issue.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00BCB405285B01AA005E87BC /* Issue.swift */; };
00BCB408285B0262005E87BC /* Label.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00BCB407285B0262005E87BC /* Label.swift */; };
00BCB40A285B027B005E87BC /* Milestone.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00BCB409285B027B005E87BC /* Milestone.swift */; };
Expand All @@ -24,6 +30,8 @@
981BD43F285B12F300DDDE64 /* Margins.swift in Sources */ = {isa = PBXBuildFile; fileRef = 981BD43E285B12F200DDDE64 /* Margins.swift */; };
983E66C6285B208800C9B975 /* GithubUserDefaults.swift in Sources */ = {isa = PBXBuildFile; fileRef = 983E66C5285B208800C9B975 /* GithubUserDefaults.swift */; };
983E66C8285B212A00C9B975 /* GitHubService.swift in Sources */ = {isa = PBXBuildFile; fileRef = 983E66C7285B212A00C9B975 /* GitHubService.swift */; };
9844C193286C803F00D0CFC9 /* ReposViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9844C192286C803F00D0CFC9 /* ReposViewController.swift */; };
9844C195286D434B00D0CFC9 /* ReposModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9844C194286D434B00D0CFC9 /* ReposModel.swift */; };
985CAB47285C1A26005E709D /* UIStackView+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = 985CAB46285C1A26005E709D /* UIStackView+Extension.swift */; };
985CAB49285C1A61005E709D /* UIColor+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = 985CAB48285C1A61005E709D /* UIColor+Extension.swift */; };
985CAB4C28603AE9005E709D /* NetworkHeader.swift in Sources */ = {isa = PBXBuildFile; fileRef = 985CAB4B28603AE9005E709D /* NetworkHeader.swift */; };
Expand Down Expand Up @@ -61,13 +69,19 @@
/* End PBXContainerItemProxy section */

/* Begin PBXFileReference section */
000B92C1286D67F8009EB2D8 /* NewIssueModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NewIssueModel.swift; sourceTree = "<group>"; };
000B92C3286D6816009EB2D8 /* Option.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Option.swift; sourceTree = "<group>"; };
000B92C6286D6F9D009EB2D8 /* OptionSelectModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OptionSelectModel.swift; sourceTree = "<group>"; };
004800F5286E8C0700A58B2A /* Assignee.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Assignee.swift; sourceTree = "<group>"; };
004800F7286E907300A58B2A /* Optionable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Optionable.swift; sourceTree = "<group>"; };
0053D7542859B162006614EC /* Config.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Config.plist; sourceTree = "<group>"; };
0053D7562859B4CA006614EC /* PrivateStorage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PrivateStorage.swift; sourceTree = "<group>"; };
00567EE7286194DB00F3E8EC /* IssueService.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = IssueService.swift; sourceTree = "<group>"; };
00567EEB2861B49F00F3E8EC /* IssueModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = IssueModel.swift; sourceTree = "<group>"; };
005E48D52862AE91004BD5F6 /* Container.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Container.swift; sourceTree = "<group>"; };
005E48D728630635004BD5F6 /* NewIssueViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NewIssueViewController.swift; sourceTree = "<group>"; };
005E48D928636064004BD5F6 /* Devider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Devider.swift; sourceTree = "<group>"; };
00AF8F272869A7060009674C /* Repository.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Repository.swift; sourceTree = "<group>"; };
00BCB405285B01AA005E87BC /* Issue.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Issue.swift; sourceTree = "<group>"; };
00BCB407285B0262005E87BC /* Label.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Label.swift; sourceTree = "<group>"; };
00BCB409285B027B005E87BC /* Milestone.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Milestone.swift; sourceTree = "<group>"; };
Expand All @@ -78,6 +92,8 @@
981BD43E285B12F200DDDE64 /* Margins.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Margins.swift; sourceTree = "<group>"; };
983E66C5285B208800C9B975 /* GithubUserDefaults.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GithubUserDefaults.swift; sourceTree = "<group>"; };
983E66C7285B212A00C9B975 /* GitHubService.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GitHubService.swift; sourceTree = "<group>"; };
9844C192286C803F00D0CFC9 /* ReposViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ReposViewController.swift; sourceTree = "<group>"; };
9844C194286D434B00D0CFC9 /* ReposModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ReposModel.swift; sourceTree = "<group>"; };
985CAB46285C1A26005E709D /* UIStackView+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIStackView+Extension.swift"; sourceTree = "<group>"; };
985CAB48285C1A61005E709D /* UIColor+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIColor+Extension.swift"; sourceTree = "<group>"; };
985CAB4B28603AE9005E709D /* NetworkHeader.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NetworkHeader.swift; sourceTree = "<group>"; };
Expand Down Expand Up @@ -126,6 +142,41 @@
/* End PBXFrameworksBuildPhase section */

/* Begin PBXGroup section */
000B92BF286D67C6009EB2D8 /* NewIssue */ = {
isa = PBXGroup;
children = (
000B92C0286D67E9009EB2D8 /* Model */,
005E48D728630635004BD5F6 /* NewIssueViewController.swift */,
000B92C3286D6816009EB2D8 /* Option.swift */,
);
path = NewIssue;
sourceTree = "<group>";
};
000B92C0286D67E9009EB2D8 /* Model */ = {
isa = PBXGroup;
children = (
000B92C1286D67F8009EB2D8 /* NewIssueModel.swift */,
);
path = Model;
sourceTree = "<group>";
};
000B92C5286D6F85009EB2D8 /* OptionSelect */ = {
isa = PBXGroup;
children = (
988FA2E92864034C0058C333 /* OptionSelectViewController.swift */,
000B92C8286D6FA1009EB2D8 /* Model */,
);
path = OptionSelect;
sourceTree = "<group>";
};
000B92C8286D6FA1009EB2D8 /* Model */ = {
isa = PBXGroup;
children = (
000B92C6286D6F9D009EB2D8 /* OptionSelectModel.swift */,
);
path = Model;
sourceTree = "<group>";
};
00567EE92861B42A00F3E8EC /* Service */ = {
isa = PBXGroup;
children = (
Expand All @@ -145,9 +196,7 @@
981BD438285B123A00DDDE64 /* Issue */ = {
isa = PBXGroup;
children = (
988FA2E92864034C0058C333 /* OptionSelectViewController.swift */,
98130E1A285AC8A5001B6DA1 /* IssueViewController.swift */,
005E48D728630635004BD5F6 /* NewIssueViewController.swift */,
00567EEA2861B43600F3E8EC /* Model */,
00567EE92861B42A00F3E8EC /* Service */,
981BD439285B124E00DDDE64 /* View */,
Expand Down Expand Up @@ -178,14 +227,34 @@
983E66CA285B2AD300C9B975 /* Entity */ = {
isa = PBXGroup;
children = (
00AF8F272869A7060009674C /* Repository.swift */,
00BCB405285B01AA005E87BC /* Issue.swift */,
00BCB407285B0262005E87BC /* Label.swift */,
00BCB409285B027B005E87BC /* Milestone.swift */,
00BCB40B285B076B005E87BC /* State.swift */,
00BCB409285B027B005E87BC /* Milestone.swift */,
004800F7286E907300A58B2A /* Optionable.swift */,
00BCB407285B0262005E87BC /* Label.swift */,
004800F5286E8C0700A58B2A /* Assignee.swift */,
);
path = Entity;
sourceTree = "<group>";
};
9844C191286C802000D0CFC9 /* Repos */ = {
isa = PBXGroup;
children = (
9844C196286D436900D0CFC9 /* Model */,
9844C192286C803F00D0CFC9 /* ReposViewController.swift */,
);
path = Repos;
sourceTree = "<group>";
};
9844C196286D436900D0CFC9 /* Model */ = {
isa = PBXGroup;
children = (
9844C194286D434B00D0CFC9 /* ReposModel.swift */,
);
path = Model;
sourceTree = "<group>";
};
985CAB45285C19D0005E709D /* Extension */ = {
isa = PBXGroup;
children = (
Expand Down Expand Up @@ -239,12 +308,15 @@
988510D428572B8700CC2DA9 /* IssueTracker */ = {
isa = PBXGroup;
children = (
985CAB5128606898005E709D /* Login */,
985CAB4A28603AD3005E709D /* GitHub */,
983E66C4285B204600C9B975 /* Storage */,
985CAB45285C19D0005E709D /* Extension */,
985CAB4A28603AD3005E709D /* GitHub */,
985CAB5128606898005E709D /* Login */,
9844C191286C802000D0CFC9 /* Repos */,
983E66CA285B2AD300C9B975 /* Entity */,
983E66C4285B204600C9B975 /* Storage */,
000B92BF286D67C6009EB2D8 /* NewIssue */,
981BD438285B123A00DDDE64 /* Issue */,
000B92C5286D6F85009EB2D8 /* OptionSelect */,
988510D528572B8700CC2DA9 /* AppDelegate.swift */,
988510DE28572B8900CC2DA9 /* Assets.xcassets */,
988510E028572B8900CC2DA9 /* LaunchScreen.storyboard */,
Expand Down Expand Up @@ -413,6 +485,7 @@
files = (
00BCB40A285B027B005E87BC /* Milestone.swift in Sources */,
005E48D828630635004BD5F6 /* NewIssueViewController.swift in Sources */,
004800F8286E907300A58B2A /* Optionable.swift in Sources */,
985CAB4C28603AE9005E709D /* NetworkHeader.swift in Sources */,
985CAB47285C1A26005E709D /* UIStackView+Extension.swift in Sources */,
981BD43F285B12F300DDDE64 /* Margins.swift in Sources */,
Expand All @@ -425,18 +498,25 @@
988510DA28572B8700CC2DA9 /* LoginViewController.swift in Sources */,
00567EE8286194DB00F3E8EC /* IssueService.swift in Sources */,
981BD43D285B12AC00DDDE64 /* IssueListCell.swift in Sources */,
000B92C2286D67F8009EB2D8 /* NewIssueModel.swift in Sources */,
988510D628572B8700CC2DA9 /* AppDelegate.swift in Sources */,
985CAB49285C1A61005E709D /* UIColor+Extension.swift in Sources */,
005E48DA28636064004BD5F6 /* Devider.swift in Sources */,
985CAB4E28603AFF005E709D /* QueryParameter.swift in Sources */,
0053D7572859B4CA006614EC /* PrivateStorage.swift in Sources */,
00BCB408285B0262005E87BC /* Label.swift in Sources */,
9844C195286D434B00D0CFC9 /* ReposModel.swift in Sources */,
983E66C6285B208800C9B975 /* GithubUserDefaults.swift in Sources */,
004800F6286E8C0700A58B2A /* Assignee.swift in Sources */,
000B92C4286D6816009EB2D8 /* Option.swift in Sources */,
005E48D62862AE91004BD5F6 /* Container.swift in Sources */,
00567EEC2861B49F00F3E8EC /* IssueModel.swift in Sources */,
00BCB40C285B076B005E87BC /* State.swift in Sources */,
9844C193286C803F00D0CFC9 /* ReposViewController.swift in Sources */,
000B92C7286D6F9D009EB2D8 /* OptionSelectModel.swift in Sources */,
988FA2EA2864034C0058C333 /* OptionSelectViewController.swift in Sources */,
00BCB406285B01AA005E87BC /* Issue.swift in Sources */,
00AF8F282869A7060009674C /* Repository.swift in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
Expand Down
14 changes: 5 additions & 9 deletions IssueTracker/IssueTracker/AppDelegate.swift
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,8 @@ import UIKit
@main
class AppDelegate: UIResponder, UIApplicationDelegate {

private let container = Container()

var window: UIWindow?
let container = Container(environment: .live)

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// TODO: - 토큰 유효기간 판단
Expand All @@ -29,13 +28,10 @@ class AppDelegate: UIResponder, UIApplicationDelegate {
}

func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool {
OAuthService().fetchToken(from: url) { [weak self] accessToken in
guard let token = accessToken else {
// TODO: 로그인 실패 얼럿띄우기
return
}
GithubUserDefaults.setToken(token)
self?.window?.rootViewController = self?.container.buildRootViewController()
// AppDelegate입장에서는 : 콜백으로 들어와서 토큰이 있으면 repoVC, 없으면 loginVC를 rootVC로 설정하면 된다. 나머지 내용은 알 필요가 없다.
// TODO: 분리하기!
container.checkRootViewController(url: url) { viewController in
self.window?.rootViewController = viewController
}
return true
}
Expand Down
104 changes: 77 additions & 27 deletions IssueTracker/IssueTracker/Container.swift
Original file line number Diff line number Diff line change
@@ -1,38 +1,88 @@
//
// Container.swift
// IssueTracker
//
// Created by Bibi on 2022/06/22.
//

import UIKit

struct Container {
enum Screen {
case login
case issue(token: String)
case newIssue
}
class Container {

func buildRootViewController() -> UIViewController {
if let accessToken = GithubUserDefaults.getToken() {
return buildViewController(.issue(token: accessToken))
} else {
return buildViewController(.login)
}
let environment: ContainerEnvironment

init(environment: ContainerEnvironment) {
self.environment = environment
}

func buildViewController(_ screen: Screen) -> UIViewController {
let service = environment.issueService
switch screen {
case .login:
return LoginViewController(service: OAuthService())
case .issue(let token):
let service = IssueService()
let model = IssueModel(service: service, token: token)
let viewController = IssueViewController(model: model)
return UINavigationController(rootViewController: vc)
case .newIssue:
return NewIssueViewController()
return LoginViewController(service: environment.oAuthService)
case .issue(let selectedRepo):
let model = IssueModel(service: service, repo: selectedRepo)
let viewController = IssueViewController(model: model, repo: selectedRepo) // Issue -> Issues
return viewController
case .repos:
// Repost에 필요한 service조각만 Model에 넣어주기(클로저 방식 사용)
// ReposModelEnvironment로 IssueService의 requestRepos()를 넣어줘야 한다
let model = ReposModel(environment: .init(requestRepos: { [weak self] completion in
self?.environment.issueService.requestRepos(completion: { result in
completion(result)
})
}))
let viewController = ReposViewController(model: model)
model.fetchViewData()
// vc는 모델을 가지는데, 모델은 vc의 테이블뷰를 참조해야 하므로 순환참조를 방지하기 위해 weak vc로 선언
model.updated = { [weak viewController] repos in
DispatchQueue.main.async {
viewController?.reloadTableView()
}
}
viewController.title = "Repos"
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ViewController에 대한 뷰를 꾸미는 작업 내부에서 처리하는게 더 좋아보입니다.
외부에서 ViewController 를 꾸밀때는, 더 의미가 명확한 작업을 하셨으면 좋겠습니다.

return UINavigationController(rootViewController: viewController)
case .newIssue(let repo):
let model = NewIssueModel(service: service)
return NewIssueViewController(repo: repo, model: model)
case .optionSelect(let option, let repo):
let model = OptionSelectModel(service: service)
return OptionSelectViewController(model: model, option: option, repo: repo)
}
}

func checkRootViewController(url: URL, completion: @escaping (UIViewController) -> Void) {
environment.oAuthService.fetchToken(from: url) { [weak self] accessToken in
guard let token = accessToken,
let self = self else {
// TODO: 로그인 실패 얼럿띄우기
return // 옵셔널 처리 시 리턴값이 애매해질 때 한가지 방법은, 리턴값 대신 completion(리턴값) -> Void 를 사용하는 것
}
self.environment.githubUserDefaults.setToken(token)
completion(self.buildRootViewController())
}
}

func buildRootViewController() -> UIViewController {
self.environment.githubUserDefaults.getToken() != nil
? self.buildViewController(.repos)
: self.buildViewController(.login)
}
}

extension Container {
enum Screen {
case login
case repos
case issue(selectedRepo: Repository)
case newIssue(repo: Repository)
case optionSelect(option: Option, repo: Repository)
}
}

// Container에 필요한 Environment : 필요한 의존성을 가진 객체
struct ContainerEnvironment {
var githubUserDefaults: GithubUserDefaults
var oAuthService: OAuthService
var issueService: IssueService

static let live: ContainerEnvironment = {
let githubUserDefaults = GithubUserDefaults()
let token = githubUserDefaults.getToken()

return ContainerEnvironment(githubUserDefaults: githubUserDefaults, oAuthService: OAuthService(), issueService: IssueService(token: token ?? ""))
}()
}
16 changes: 16 additions & 0 deletions IssueTracker/IssueTracker/Entity/Assignee.swift
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
//
// Assignee.swift
// IssueTracker
//
// Created by Bibi on 2022/07/01.
//

import Foundation

struct Assignee: Codable, Optionable {
var subTitle: String {
self.login
}

let login: String
}
5 changes: 0 additions & 5 deletions IssueTracker/IssueTracker/Entity/Issue.swift
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,6 @@ struct Issue: Codable {
let repository: Repository
}

struct Repository: Codable {
let name: String
let owner: Owner
}

struct Owner: Codable {
let login: String
}
6 changes: 5 additions & 1 deletion IssueTracker/IssueTracker/Entity/Label.swift
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,11 @@
import Foundation

// MARK: - Label
struct Label: Codable {
struct Label: Codable, Optionable {
var subTitle: String {
self.name
}

let id: Int
let url: String
let name, color: String
Expand Down
Loading