File size: 4,249 Bytes
671c006
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
class CustomSidebar extends HTMLElement {
    connectedCallback() {
        this.attachShadow({ mode: 'open' });
        this.shadowRoot.innerHTML = `
            <style>
                .sidebar {
                    width: 250px;
                    height: 100%;
                    background-color: var(--sidebar-bg, #1E293B);
                    color: var(--sidebar-text, #F8FAFC);
                    border-right: 1px solid var(--sidebar-border, #334155);
                    overflow-y: auto;
                }
                
                .sidebar-header {
                    padding: 12px 16px;
                    font-weight: 600;
                    border-bottom: 1px solid var(--sidebar-border, #334155);
                    display: flex;
                    align-items: center;
                    justify-content: space-between;
                }
                
                .sidebar-item {
                    padding: 8px 16px 8px 32px;
                    cursor: pointer;
                    display: flex;
                    align-items: center;
                    gap: 8px;
                    user-select: none;
                }
                
                .sidebar-item:hover {
                    background-color: var(--sidebar-hover, #334155);
                }
                
                .sidebar-item.active {
                    background-color: var(--sidebar-active, #3B82F6);
                }
                
                .sidebar-group {
                    margin: 8px 0;
                }
                
                .sidebar-group-title {
                    padding: 8px 16px;
                    font-size: 0.75rem;
                    text-transform: uppercase;
                    letter-spacing: 0.05em;
                    color: var(--sidebar-group-text, #94A3B8);
                }
                
                .folder-icon {
                    color: #F59E0B;
                }
                
                .file-icon {
                    color: #60A5FA;
                }
            </style>
            <div class="sidebar">
                <div class="sidebar-header">
                    <span>Project</span>
                    <i data-feather="chevron-down" class="w-4 h-4"></i>
                </div>
                
                <div class="sidebar-group">
                    <div class="sidebar-group-title">MyApplication</div>
                    <div class="sidebar-item active">
                        <i data-feather="file" class="file-icon"></i>
                        <span>MainActivity.kt</span>
                    </div>
                    <div class="sidebar-item">
                        <i data-feather="file" class="file-icon"></i>
                        <span>AndroidManifest.xml</span>
                    </div>
                </div>
                
                <div class="sidebar-group">
                    <div class="sidebar-group-title">res</div>
                    <div class="sidebar-item">
                        <i data-feather="folder" class="folder-icon"></i>
                        <span>layout</span>
                    </div>
                    <div class="sidebar-item">
                        <i data-feather="folder" class="folder-icon"></i>
                        <span>values</span>
                    </div>
                    <div class="sidebar-item">
                        <i data-feather="folder" class="folder-icon"></i>
                        <span>drawable</span>
                    </div>
                </div>
                
                <div class="sidebar-group">
                    <div class="sidebar-group-title">Gradle Scripts</div>
                    <div class="sidebar-item">
                        <i data-feather="file" class="file-icon"></i>
                        <span>build.gradle (Module)</span>
                    </div>
                    <div class="sidebar-item">
                        <i data-feather="file" class="file-icon"></i>
                        <span>build.gradle (Project)</span>
                    </div>
                </div>
            </div>
        `;
    }
}
customElements.define('custom-sidebar', CustomSidebar);