-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.html
More file actions
184 lines (156 loc) · 7.75 KB
/
index.html
File metadata and controls
184 lines (156 loc) · 7.75 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Dependency Tree Diff</title>
<script src="https://cdn.jsdelivr.net/npm/counterapi/dist/counter.browser.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/html2canvas@1.4.1/dist/html2canvas.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/dom-to-image-more@3.4.0/dist/dom-to-image-more.min.js"></script>
<!-- Prism -->
<link href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism-tomorrow.min.css" rel="stylesheet" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-core.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/plugins/autoloader/prism-autoloader.min.js"></script>
<!-- App CSS -->
<link rel="stylesheet" href="./css/styles.css" />
</head>
<body>
<main class="container">
<header class="header">
<!-- 방문자 카운터 (오른쪽 상단) -->
<div class="view-counter" aria-label="페이지 방문자 수">
<span class="counter-label">Total</span>
<span id="total-count" class="counter-value">-</span>
</div>
<br>
<h1>Dependency Tree Diff</h1>
<p>Android 의존성 그래프 변경사항을 쉽게 비교해보세요</p>
</header>
<section class="card upload">
<!-- 동적 경고 배너 (초기엔 숨김) -->
<div id="notice" class="notice hidden" aria-live="polite">
⚠️ 파일이 너무 크면 비교 결과가 일부만 표시되거나 느려질 수 있습니다.
</div>
<div id="error" class="error"></div>
<div class="grid">
<div class="field">
<label for="file-old">기존 의존성 파일 (.txt)</label>
<div class="drop" id="drop-old" role="button" aria-label="기존 파일 선택">
<input class="file-input" id="file-old" type="file" accept=".txt" />
<div class="hint">클릭 또는 드래그하여 업로드</div>
<div class="name" id="name-old" aria-live="polite"></div>
</div>
</div>
<div class="field">
<label for="file-new">변경된 의존성 파일 (.txt)</label>
<div class="drop" id="drop-new" role="button" aria-label="변경된 파일 선택">
<input class="file-input" id="file-new" type="file" accept=".txt" />
<div class="hint">클릭 또는 드래그하여 업로드</div>
<div class="name" id="name-new" aria-live="polite"></div>
</div>
</div>
</div>
<div class="actions">
<button class="btn" id="btn-compare" disabled>
<span id="btn-label">비교하기</span>
<span id="spinner" class="spinner" style="display:none"></span>
</button>
<button class="btn btn-secondary" id="btn-reset" type="button">초기화</button>
</div>
</section>
<section class="card result" id="result-card" style="display:none">
<div class="result-header">
<h2 class="result-title">비교 결과</h2>
<div class="result-actions">
<button class="btn btn-secondary" id="btn-copy" type="button">결과 복사</button>
<button class="btn btn-secondary" id="btn-screenshot" type="button">
<span id="btn-screenshot-text">스크린샷 저장</span>
<span id="spinner-screenshot" class="spinner" style="display:none"></span>
</button>
<button class="btn btn-secondary" id="btn-md-download" type="button">
<span id="btn-md-text">마크다운으로 저장</span>
<span id="spinner-md" class="spinner" style="display:none"></span>
</button>
</div>
</div>
<!-- 탭 메뉴 -->
<div class="diff-tabs">
<button class="tab-btn active" data-tab="enhanced">전체 출력</button>
<button class="tab-btn" data-tab="only-diff">변경된 부분만 출력</button>
<button class="tab-btn" data-tab="flattened">요약</button>
</div>
<!-- 탭 컨텐츠 -->
<div class="tab-content active" id="tab-enhanced">
<div class="tab-description">
<p>일반적인 파일 diff처럼 모든 내용을 보여줍니다.</p>
</div>
<div class="code-wrap" id="capture-area-enhanced">
<pre><code class="language-diff" id="code-diff-enhanced"></code></pre>
</div>
</div>
<div class="tab-content" id="tab-only-diff">
<div class="tab-description">
<p>추가되거나 삭제된 의존성만 표시합니다.</p>
</div>
<div class="code-wrap" id="capture-area-only-diff">
<pre><code class="language-diff" id="code-diff-only-diff"></code></pre>
</div>
</div>
<div class="tab-content" id="tab-flattened">
<div class="tab-description">
<p>추가/삭제/변경된 의존성을 카테고리별로 정리합니다.</p>
<p> - 전체 모듈 기준으로 새로 포함된 의존성만 표시됩니다.</p>
</div>
<div class="code-wrap" id="capture-area-flattened">
<pre><code class="language-diff" id="code-diff-flattened"></code></pre>
</div>
</div>
</section>
<section class="guide-section" id="guide-deptree" style="display:block">
<button class="guide-toggle" type="button" aria-expanded="false">
📘 의존성 트리 출력 방법
</button>
<div class="guide-content" style="display:none">
<ol class="guide-steps">
<li class="guide-step">
<div class="guide-step-title">1. 변경 전 의존성 출력</div>
<div class="guide-note">현재 <strong>develop</strong> 브랜치 또는 변경 전 브랜치에서 실행하세요.</div>
<div class="guide-block">
<div class="guide-label">명령어</div>
<pre
class="guide-code"><code>./gradlew app:dependencies --configuration {BuildVariant명}RuntimeClassPath > before.txt</code></pre>
</div>
<ul class="config-info">
<li><strong>RuntimeClassPath</strong>: 실제 앱 실행 시 필요한 의존성 (APK에 포함되는 라이브러리들)</li>
<li><strong>CompileClassPath</strong>: 컴파일 시에만 필요한 의존성 (API, annotation processor 등)</li>
<li>💡 실제 앱 의존성 확인 시 <code>RuntimeClassPath</code> 권장</li>
</ul>
</li>
<li class="guide-step">
<div class="guide-step-title">2. 변경 후 의존성 출력</div>
<div class="guide-note">브랜치 변경 후 <strong>파일명만 다르게</strong> 저장하세요.</div>
<div class="guide-block">
<div class="guide-label">명령어</div>
<pre
class="guide-code"><code>./gradlew app:dependencies --configuration {BuildVariant명}RuntimeClassPath > after.txt</code></pre>
</div>
</li>
<li class="guide-step">
<div class="guide-step-title">3. 비교하기</div>
<div class="guide-note"><code>before.txt</code>와 <code>after.txt</code>를 업로드해보세요.</div>
</li>
</ol>
</div>
</section>
</main>
<script defer src="./js/visitor-counter.js"></script>
<!-- Core (diff 로직) 먼저 로드 -->
<script defer src="./js/dependency-only-diff.js"></script>
<script defer src="./js/dependency-diff-flattened.js"></script>
<script defer src="./js/dependency-diff-tree-full-enhanced.js"></script>
<!-- UI -->
<script defer src="./js/app.js"></script>
<script defer src="./js/result-capture.js"></script>
<script defer src="./js/result-markdown.js"></script>
</body>
</html>