vg-coder-cli 2.0.22 → 2.0.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.vg/tree-state.json +9 -0
- package/package.json +3 -1
- package/scripts/build.js +49 -6
- package/src/server/api-server.js +46 -0
- package/src/server/views/css/structure.css +4 -1
- package/src/server/views/dashboard.css +24 -1
- package/src/server/views/dashboard.html +2 -0
- package/src/server/views/js/api.js +24 -0
- package/src/server/views/js/features/resize.js +57 -0
- package/src/server/views/js/features/structure.js +109 -16
- package/src/server/views/js/main.js +5 -0
- package/src/server/views/vg-coder/background.js +48201 -2
- package/src/server/views/vg-coder/controller.js +496 -1
- package/src/server/views/vg-coder/manifest.json +13 -5
- package/src/server/views/vg-coder/{options.css → sidepanel.css} +34 -32
- package/src/server/views/vg-coder/{options.html → sidepanel.html} +2 -2
- package/src/server/views/vg-coder/sidepanel.js +347 -0
- package/vetgo-auto/README.md +3 -0
- package/vetgo-auto/chrome/CSP_IMPROVEMENTS.md +147 -0
- package/vetgo-auto/chrome/MANIFEST_V3_MIGRATION.md +123 -0
- package/vetgo-auto/chrome/assets/icon128.png +0 -0
- package/vetgo-auto/chrome/assets/icon16.png +0 -0
- package/vetgo-auto/chrome/assets/icon48.png +0 -0
- package/vetgo-auto/chrome/environments/environment.ts +13 -0
- package/vetgo-auto/chrome/manifest.json +66 -0
- package/vetgo-auto/chrome/rules.json +23 -0
- package/vetgo-auto/chrome/src/background.ts +200 -0
- package/vetgo-auto/chrome/src/controller.ts +98 -0
- package/vetgo-auto/chrome/src/controllers/common.firebase.ts +31 -0
- package/vetgo-auto/chrome/src/controllers/firebase-crud.ts +147 -0
- package/vetgo-auto/chrome/src/controllers/load-common-fuc.controller.ts +24 -0
- package/vetgo-auto/chrome/src/controllers/load-script.controller.ts +23 -0
- package/vetgo-auto/chrome/src/script-injector.ts +305 -0
- package/vetgo-auto/chrome/src/sidepanel.css +166 -0
- package/vetgo-auto/chrome/src/sidepanel.html +48 -0
- package/vetgo-auto/chrome/src/sidepanel.ts +127 -0
- package/vetgo-auto/chrome/src/utils/db-utils.ts +2 -0
- package/vetgo-auto/chrome/src/utils/environment-storage.service.ts +85 -0
- package/vetgo-auto/chrome/webpack.config.js +53 -0
- package/vetgo-auto/chrome/webpack.config.prod.js +54 -0
- package/vetgo-auto/package.json +30 -0
- package/vetgo-auto/tsconfig.json +27 -0
- package/vg-coder-cli-2.0.23.tgz +0 -0
- package/src/server/views/vg-coder/background.js.LICENSE.txt +0 -118
- package/src/server/views/vg-coder/options.js +0 -1
- package/vg-coder-cli-2.0.21.tgz +0 -0
- package/vg-coder-cli-2.0.22.tgz +0 -0
- package/vg-coder.zip +0 -0
|
@@ -9,51 +9,51 @@ body {
|
|
|
9
9
|
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
|
10
10
|
min-height: 100vh;
|
|
11
11
|
display: flex;
|
|
12
|
-
align-items:
|
|
12
|
+
align-items: flex-start;
|
|
13
13
|
justify-content: center;
|
|
14
|
-
padding:
|
|
14
|
+
padding: 0;
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
.container {
|
|
18
18
|
background: white;
|
|
19
|
-
border-radius:
|
|
20
|
-
box-shadow:
|
|
21
|
-
padding:
|
|
22
|
-
max-width: 500px;
|
|
19
|
+
border-radius: 0;
|
|
20
|
+
box-shadow: none;
|
|
21
|
+
padding: 24px;
|
|
23
22
|
width: 100%;
|
|
23
|
+
min-height: 100vh;
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
h1 {
|
|
27
27
|
color: #333;
|
|
28
|
-
font-size:
|
|
29
|
-
margin-bottom:
|
|
28
|
+
font-size: 24px;
|
|
29
|
+
margin-bottom: 8px;
|
|
30
30
|
font-weight: 600;
|
|
31
31
|
}
|
|
32
32
|
|
|
33
33
|
.subtitle {
|
|
34
34
|
color: #666;
|
|
35
|
-
font-size:
|
|
36
|
-
margin-bottom:
|
|
35
|
+
font-size: 13px;
|
|
36
|
+
margin-bottom: 24px;
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
.form-group {
|
|
40
|
-
margin-bottom:
|
|
40
|
+
margin-bottom: 20px;
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
label {
|
|
44
44
|
display: block;
|
|
45
45
|
color: #444;
|
|
46
|
-
font-size:
|
|
46
|
+
font-size: 13px;
|
|
47
47
|
font-weight: 500;
|
|
48
|
-
margin-bottom:
|
|
48
|
+
margin-bottom: 6px;
|
|
49
49
|
}
|
|
50
50
|
|
|
51
51
|
input[type="text"] {
|
|
52
52
|
width: 100%;
|
|
53
|
-
padding: 12px
|
|
53
|
+
padding: 10px 12px;
|
|
54
54
|
border: 2px solid #e0e0e0;
|
|
55
|
-
border-radius:
|
|
56
|
-
font-size:
|
|
55
|
+
border-radius: 6px;
|
|
56
|
+
font-size: 14px;
|
|
57
57
|
transition: all 0.3s ease;
|
|
58
58
|
outline: none;
|
|
59
59
|
}
|
|
@@ -65,23 +65,23 @@ input[type="text"]:focus {
|
|
|
65
65
|
|
|
66
66
|
.hint {
|
|
67
67
|
color: #888;
|
|
68
|
-
font-size:
|
|
69
|
-
margin-top:
|
|
68
|
+
font-size: 11px;
|
|
69
|
+
margin-top: 4px;
|
|
70
70
|
font-style: italic;
|
|
71
71
|
}
|
|
72
72
|
|
|
73
73
|
.button-group {
|
|
74
74
|
display: flex;
|
|
75
|
-
gap:
|
|
76
|
-
margin-top:
|
|
75
|
+
gap: 10px;
|
|
76
|
+
margin-top: 24px;
|
|
77
77
|
}
|
|
78
78
|
|
|
79
79
|
button {
|
|
80
80
|
flex: 1;
|
|
81
|
-
padding:
|
|
81
|
+
padding: 10px 20px;
|
|
82
82
|
border: none;
|
|
83
|
-
border-radius:
|
|
84
|
-
font-size:
|
|
83
|
+
border-radius: 6px;
|
|
84
|
+
font-size: 14px;
|
|
85
85
|
font-weight: 600;
|
|
86
86
|
cursor: pointer;
|
|
87
87
|
transition: all 0.3s ease;
|
|
@@ -94,8 +94,8 @@ button {
|
|
|
94
94
|
}
|
|
95
95
|
|
|
96
96
|
.btn-primary:hover {
|
|
97
|
-
transform: translateY(-
|
|
98
|
-
box-shadow: 0
|
|
97
|
+
transform: translateY(-1px);
|
|
98
|
+
box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
|
|
99
99
|
}
|
|
100
100
|
|
|
101
101
|
.btn-primary:active {
|
|
@@ -112,10 +112,10 @@ button {
|
|
|
112
112
|
}
|
|
113
113
|
|
|
114
114
|
.message {
|
|
115
|
-
padding:
|
|
116
|
-
border-radius:
|
|
117
|
-
margin-bottom:
|
|
118
|
-
font-size:
|
|
115
|
+
padding: 10px 14px;
|
|
116
|
+
border-radius: 6px;
|
|
117
|
+
margin-bottom: 16px;
|
|
118
|
+
font-size: 13px;
|
|
119
119
|
display: none;
|
|
120
120
|
animation: slideIn 0.3s ease;
|
|
121
121
|
}
|
|
@@ -147,18 +147,20 @@ button {
|
|
|
147
147
|
|
|
148
148
|
.current-value {
|
|
149
149
|
background: #f8f9fa;
|
|
150
|
-
padding:
|
|
151
|
-
border-radius:
|
|
152
|
-
margin-bottom:
|
|
150
|
+
padding: 10px 14px;
|
|
151
|
+
border-radius: 6px;
|
|
152
|
+
margin-bottom: 16px;
|
|
153
153
|
border-left: 4px solid #667eea;
|
|
154
154
|
}
|
|
155
155
|
|
|
156
156
|
.current-value strong {
|
|
157
157
|
color: #667eea;
|
|
158
158
|
font-weight: 600;
|
|
159
|
+
font-size: 13px;
|
|
159
160
|
}
|
|
160
161
|
|
|
161
162
|
.current-value span {
|
|
162
163
|
color: #333;
|
|
163
164
|
font-family: 'Courier New', monospace;
|
|
165
|
+
font-size: 13px;
|
|
164
166
|
}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
<meta charset="UTF-8">
|
|
6
6
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
7
7
|
<title>VetGo Pro - Cấu hình</title>
|
|
8
|
-
<link rel="stylesheet" href="
|
|
8
|
+
<link rel="stylesheet" href="sidepanel.css">
|
|
9
9
|
</head>
|
|
10
10
|
|
|
11
11
|
<body>
|
|
@@ -42,7 +42,7 @@
|
|
|
42
42
|
</form>
|
|
43
43
|
</div>
|
|
44
44
|
|
|
45
|
-
<script src="
|
|
45
|
+
<script src="sidepanel.js"></script>
|
|
46
46
|
</body>
|
|
47
47
|
|
|
48
48
|
</html>
|
|
@@ -0,0 +1,347 @@
|
|
|
1
|
+
/******/ (() => { // webpackBootstrap
|
|
2
|
+
/******/ "use strict";
|
|
3
|
+
/******/ var __webpack_modules__ = ({
|
|
4
|
+
|
|
5
|
+
/***/ "./chrome/environments/environment.ts":
|
|
6
|
+
/*!********************************************!*\
|
|
7
|
+
!*** ./chrome/environments/environment.ts ***!
|
|
8
|
+
\********************************************/
|
|
9
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
10
|
+
|
|
11
|
+
__webpack_require__.r(__webpack_exports__);
|
|
12
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
13
|
+
/* harmony export */ environment: () => (/* binding */ environment)
|
|
14
|
+
/* harmony export */ });
|
|
15
|
+
const environment = {
|
|
16
|
+
production: false,
|
|
17
|
+
environmentName: 'VGCODER',
|
|
18
|
+
firebaseConfig: {
|
|
19
|
+
apiKey: "AIzaSyDrpNMso-DXeN7c4vwbpV0idpxnV2vtXhQ",
|
|
20
|
+
authDomain: "vetgo-chrome.firebaseapp.com",
|
|
21
|
+
databaseURL: "https://vetgo-chrome-default-rtdb.asia-southeast1.firebasedatabase.app",
|
|
22
|
+
projectId: "vetgo-chrome",
|
|
23
|
+
storageBucket: "vetgo-chrome.appspot.com",
|
|
24
|
+
messagingSenderId: "211178224097",
|
|
25
|
+
appId: "1:211178224097:web:f73bf5a81c2f4c32fc7aa0"
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
/***/ }),
|
|
31
|
+
|
|
32
|
+
/***/ "./chrome/src/utils/environment-storage.service.ts":
|
|
33
|
+
/*!*********************************************************!*\
|
|
34
|
+
!*** ./chrome/src/utils/environment-storage.service.ts ***!
|
|
35
|
+
\*********************************************************/
|
|
36
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
37
|
+
|
|
38
|
+
__webpack_require__.r(__webpack_exports__);
|
|
39
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
40
|
+
/* harmony export */ EnvironmentStorageService: () => (/* binding */ EnvironmentStorageService)
|
|
41
|
+
/* harmony export */ });
|
|
42
|
+
/* harmony import */ var _environments_environment__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../environments/environment */ "./chrome/environments/environment.ts");
|
|
43
|
+
var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
44
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
45
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
46
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
47
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
48
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
49
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
const STORAGE_KEY = 'environmentName';
|
|
54
|
+
const FIREBASE_CONFIG_KEY = 'firebaseConfig';
|
|
55
|
+
const DEFAULT_ENVIRONMENT = _environments_environment__WEBPACK_IMPORTED_MODULE_0__.environment.environmentName;
|
|
56
|
+
class EnvironmentStorageService {
|
|
57
|
+
/**
|
|
58
|
+
* Lấy environment name từ chrome.storage
|
|
59
|
+
*/
|
|
60
|
+
static getEnvironmentName() {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
+
return new Promise((resolve) => {
|
|
63
|
+
chrome.storage.sync.get([STORAGE_KEY], (result) => {
|
|
64
|
+
const envName = result[STORAGE_KEY] || DEFAULT_ENVIRONMENT;
|
|
65
|
+
resolve(envName);
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Lưu environment name vào chrome.storage
|
|
72
|
+
*/
|
|
73
|
+
static setEnvironmentName(name) {
|
|
74
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
75
|
+
return new Promise((resolve, reject) => {
|
|
76
|
+
if (!name || name.trim() === '') {
|
|
77
|
+
reject(new Error('Environment name cannot be empty'));
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
chrome.storage.sync.set({ [STORAGE_KEY]: name.trim() }, () => {
|
|
81
|
+
if (chrome.runtime.lastError) {
|
|
82
|
+
reject(chrome.runtime.lastError);
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
resolve();
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Lấy cấu hình Firebase. Ưu tiên storage, fallback về environment mặc định
|
|
93
|
+
*/
|
|
94
|
+
static getFirebaseConfig() {
|
|
95
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
96
|
+
return new Promise((resolve) => {
|
|
97
|
+
chrome.storage.sync.get([FIREBASE_CONFIG_KEY], (result) => {
|
|
98
|
+
const customConfig = result[FIREBASE_CONFIG_KEY];
|
|
99
|
+
if (customConfig && Object.keys(customConfig).length > 0) {
|
|
100
|
+
resolve(customConfig);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
resolve(_environments_environment__WEBPACK_IMPORTED_MODULE_0__.environment.firebaseConfig);
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Lưu cấu hình Firebase tùy chỉnh
|
|
111
|
+
*/
|
|
112
|
+
static setFirebaseConfig(config) {
|
|
113
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
114
|
+
return new Promise((resolve, reject) => {
|
|
115
|
+
chrome.storage.sync.set({ [FIREBASE_CONFIG_KEY]: config }, () => {
|
|
116
|
+
if (chrome.runtime.lastError) {
|
|
117
|
+
reject(chrome.runtime.lastError);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
resolve();
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Reset về giá trị mặc định
|
|
128
|
+
*/
|
|
129
|
+
static resetToDefault() {
|
|
130
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
131
|
+
try {
|
|
132
|
+
yield this.setEnvironmentName(DEFAULT_ENVIRONMENT);
|
|
133
|
+
// Xóa config firebase custom để dùng mặc định
|
|
134
|
+
yield new Promise((resolve) => {
|
|
135
|
+
chrome.storage.sync.remove(FIREBASE_CONFIG_KEY, () => resolve());
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
catch (e) {
|
|
139
|
+
throw e;
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
|
|
146
|
+
/***/ })
|
|
147
|
+
|
|
148
|
+
/******/ });
|
|
149
|
+
/************************************************************************/
|
|
150
|
+
/******/ // The module cache
|
|
151
|
+
/******/ var __webpack_module_cache__ = {};
|
|
152
|
+
/******/
|
|
153
|
+
/******/ // The require function
|
|
154
|
+
/******/ function __webpack_require__(moduleId) {
|
|
155
|
+
/******/ // Check if module is in cache
|
|
156
|
+
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
157
|
+
/******/ if (cachedModule !== undefined) {
|
|
158
|
+
/******/ return cachedModule.exports;
|
|
159
|
+
/******/ }
|
|
160
|
+
/******/ // Create a new module (and put it into the cache)
|
|
161
|
+
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
162
|
+
/******/ // no module.id needed
|
|
163
|
+
/******/ // no module.loaded needed
|
|
164
|
+
/******/ exports: {}
|
|
165
|
+
/******/ };
|
|
166
|
+
/******/
|
|
167
|
+
/******/ // Execute the module function
|
|
168
|
+
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
169
|
+
/******/
|
|
170
|
+
/******/ // Return the exports of the module
|
|
171
|
+
/******/ return module.exports;
|
|
172
|
+
/******/ }
|
|
173
|
+
/******/
|
|
174
|
+
/************************************************************************/
|
|
175
|
+
/******/ /* webpack/runtime/define property getters */
|
|
176
|
+
/******/ (() => {
|
|
177
|
+
/******/ // define getter functions for harmony exports
|
|
178
|
+
/******/ __webpack_require__.d = (exports, definition) => {
|
|
179
|
+
/******/ for(var key in definition) {
|
|
180
|
+
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
181
|
+
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
182
|
+
/******/ }
|
|
183
|
+
/******/ }
|
|
184
|
+
/******/ };
|
|
185
|
+
/******/ })();
|
|
186
|
+
/******/
|
|
187
|
+
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
|
188
|
+
/******/ (() => {
|
|
189
|
+
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
190
|
+
/******/ })();
|
|
191
|
+
/******/
|
|
192
|
+
/******/ /* webpack/runtime/make namespace object */
|
|
193
|
+
/******/ (() => {
|
|
194
|
+
/******/ // define __esModule on exports
|
|
195
|
+
/******/ __webpack_require__.r = (exports) => {
|
|
196
|
+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
197
|
+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
198
|
+
/******/ }
|
|
199
|
+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
200
|
+
/******/ };
|
|
201
|
+
/******/ })();
|
|
202
|
+
/******/
|
|
203
|
+
/************************************************************************/
|
|
204
|
+
var __webpack_exports__ = {};
|
|
205
|
+
// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk.
|
|
206
|
+
(() => {
|
|
207
|
+
/*!*********************************!*\
|
|
208
|
+
!*** ./chrome/src/sidepanel.ts ***!
|
|
209
|
+
\*********************************/
|
|
210
|
+
__webpack_require__.r(__webpack_exports__);
|
|
211
|
+
/* harmony import */ var _utils_environment_storage_service__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utils/environment-storage.service */ "./chrome/src/utils/environment-storage.service.ts");
|
|
212
|
+
/* harmony import */ var _environments_environment__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../environments/environment */ "./chrome/environments/environment.ts");
|
|
213
|
+
var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
214
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
215
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
216
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
217
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
218
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
219
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
220
|
+
});
|
|
221
|
+
};
|
|
222
|
+
|
|
223
|
+
|
|
224
|
+
// DOM Elements
|
|
225
|
+
const form = document.getElementById('configForm');
|
|
226
|
+
const environmentInput = document.getElementById('environmentName');
|
|
227
|
+
const firebaseConfigInput = document.getElementById('firebaseConfig');
|
|
228
|
+
const resetBtn = document.getElementById('resetBtn');
|
|
229
|
+
const messageDiv = document.getElementById('message');
|
|
230
|
+
const currentEnvSpan = document.getElementById('currentEnv');
|
|
231
|
+
/**
|
|
232
|
+
* Hiển thị thông báo cho người dùng
|
|
233
|
+
*/
|
|
234
|
+
function showMessage(text, type) {
|
|
235
|
+
messageDiv.textContent = text;
|
|
236
|
+
messageDiv.className = `message ${type}`;
|
|
237
|
+
// Tự động ẩn thông báo sau 3 giây
|
|
238
|
+
setTimeout(() => {
|
|
239
|
+
messageDiv.className = 'message';
|
|
240
|
+
}, 3000);
|
|
241
|
+
}
|
|
242
|
+
/**
|
|
243
|
+
* Load và hiển thị giá trị hiện tại
|
|
244
|
+
*/
|
|
245
|
+
function loadCurrentConfig() {
|
|
246
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
247
|
+
try {
|
|
248
|
+
// Load Env Name
|
|
249
|
+
const envName = yield _utils_environment_storage_service__WEBPACK_IMPORTED_MODULE_0__.EnvironmentStorageService.getEnvironmentName();
|
|
250
|
+
currentEnvSpan.textContent = envName;
|
|
251
|
+
environmentInput.value = envName;
|
|
252
|
+
// Load Firebase Config
|
|
253
|
+
const fbConfig = yield _utils_environment_storage_service__WEBPACK_IMPORTED_MODULE_0__.EnvironmentStorageService.getFirebaseConfig();
|
|
254
|
+
// Kiểm tra xem có phải config mặc định không
|
|
255
|
+
const isDefault = JSON.stringify(fbConfig) === JSON.stringify(_environments_environment__WEBPACK_IMPORTED_MODULE_1__.environment.firebaseConfig);
|
|
256
|
+
if (!isDefault) {
|
|
257
|
+
firebaseConfigInput.value = JSON.stringify(fbConfig, null, 2);
|
|
258
|
+
}
|
|
259
|
+
else {
|
|
260
|
+
firebaseConfigInput.value = ''; // Để trống nếu đang dùng default
|
|
261
|
+
firebaseConfigInput.placeholder = `Đang sử dụng mặc định:\n${JSON.stringify(_environments_environment__WEBPACK_IMPORTED_MODULE_1__.environment.firebaseConfig, null, 2)}`;
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
catch (error) {
|
|
265
|
+
console.error('Error loading config:', error);
|
|
266
|
+
currentEnvSpan.textContent = 'Lỗi khi tải cấu hình';
|
|
267
|
+
showMessage('Không thể tải cấu hình hiện tại', 'error');
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
/**
|
|
272
|
+
* Xử lý sự kiện submit form
|
|
273
|
+
*/
|
|
274
|
+
function handleSubmit(event) {
|
|
275
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
276
|
+
event.preventDefault();
|
|
277
|
+
const newEnvName = environmentInput.value.trim();
|
|
278
|
+
const firebaseConfigStr = firebaseConfigInput.value.trim();
|
|
279
|
+
if (!newEnvName) {
|
|
280
|
+
showMessage('Vui lòng nhập tên môi trường', 'error');
|
|
281
|
+
return;
|
|
282
|
+
}
|
|
283
|
+
try {
|
|
284
|
+
// 1. Lưu Environment Name
|
|
285
|
+
yield _utils_environment_storage_service__WEBPACK_IMPORTED_MODULE_0__.EnvironmentStorageService.setEnvironmentName(newEnvName);
|
|
286
|
+
currentEnvSpan.textContent = newEnvName;
|
|
287
|
+
// 2. Lưu Firebase Config
|
|
288
|
+
if (firebaseConfigStr) {
|
|
289
|
+
try {
|
|
290
|
+
const configObj = JSON.parse(firebaseConfigStr);
|
|
291
|
+
// Validate sơ bộ
|
|
292
|
+
if (!configObj.apiKey || !configObj.databaseURL) {
|
|
293
|
+
throw new Error("Config thiếu apiKey hoặc databaseURL");
|
|
294
|
+
}
|
|
295
|
+
yield _utils_environment_storage_service__WEBPACK_IMPORTED_MODULE_0__.EnvironmentStorageService.setFirebaseConfig(configObj);
|
|
296
|
+
}
|
|
297
|
+
catch (e) {
|
|
298
|
+
showMessage('❌ JSON Firebase Config không hợp lệ: ' + e.message, 'error');
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
else {
|
|
303
|
+
// Nếu để trống, xóa custom config để dùng default
|
|
304
|
+
yield new Promise((resolve) => {
|
|
305
|
+
chrome.storage.sync.remove('firebaseConfig', () => resolve());
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
showMessage('✅ Lưu cấu hình thành công!', 'success');
|
|
309
|
+
// Reload lại hiển thị để update placeholder/value
|
|
310
|
+
loadCurrentConfig();
|
|
311
|
+
}
|
|
312
|
+
catch (error) {
|
|
313
|
+
console.error('Error saving settings:', error);
|
|
314
|
+
showMessage('❌ Lỗi khi lưu cấu hình: ' + error.message, 'error');
|
|
315
|
+
}
|
|
316
|
+
});
|
|
317
|
+
}
|
|
318
|
+
/**
|
|
319
|
+
* Xử lý sự kiện reset về mặc định
|
|
320
|
+
*/
|
|
321
|
+
function handleReset() {
|
|
322
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
323
|
+
if (!confirm('Bạn có chắc muốn đặt lại tất cả về mặc định?')) {
|
|
324
|
+
return;
|
|
325
|
+
}
|
|
326
|
+
try {
|
|
327
|
+
yield _utils_environment_storage_service__WEBPACK_IMPORTED_MODULE_0__.EnvironmentStorageService.resetToDefault();
|
|
328
|
+
yield loadCurrentConfig(); // Reload UI
|
|
329
|
+
showMessage('✅ Đã đặt lại về cấu hình mặc định!', 'success');
|
|
330
|
+
}
|
|
331
|
+
catch (error) {
|
|
332
|
+
console.error('Error resetting environment:', error);
|
|
333
|
+
showMessage('❌ Lỗi khi đặt lại cấu hình', 'error');
|
|
334
|
+
}
|
|
335
|
+
});
|
|
336
|
+
}
|
|
337
|
+
// Event Listeners
|
|
338
|
+
form.addEventListener('submit', handleSubmit);
|
|
339
|
+
resetBtn.addEventListener('click', handleReset);
|
|
340
|
+
// Load giá trị hiện tại khi trang được mở
|
|
341
|
+
loadCurrentConfig();
|
|
342
|
+
|
|
343
|
+
})();
|
|
344
|
+
|
|
345
|
+
/******/ })()
|
|
346
|
+
;
|
|
347
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"sidepanel.js","mappings":"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","sources":["webpack://vg-coder/./chrome/environments/environment.ts","webpack://vg-coder/./chrome/src/utils/environment-storage.service.ts","webpack://vg-coder/webpack/bootstrap","webpack://vg-coder/webpack/runtime/define property getters","webpack://vg-coder/webpack/runtime/hasOwnProperty shorthand","webpack://vg-coder/webpack/runtime/make namespace object","webpack://vg-coder/./chrome/src/sidepanel.ts"],"sourcesContent":["export const environment = {\n  production: false,\n  environmentName: 'VGCODER',\n  firebaseConfig: {\n    apiKey: \"AIzaSyDrpNMso-DXeN7c4vwbpV0idpxnV2vtXhQ\",\n    authDomain: \"vetgo-chrome.firebaseapp.com\",\n    databaseURL: \"https://vetgo-chrome-default-rtdb.asia-southeast1.firebasedatabase.app\",\n    projectId: \"vetgo-chrome\",\n    storageBucket: \"vetgo-chrome.appspot.com\",\n    messagingSenderId: \"211178224097\",\n    appId: \"1:211178224097:web:f73bf5a81c2f4c32fc7aa0\"\n  }\n};\n","import { environment } from \"../../environments/environment\";\n\nconst STORAGE_KEY = 'environmentName';\nconst FIREBASE_CONFIG_KEY = 'firebaseConfig';\nconst DEFAULT_ENVIRONMENT = environment.environmentName;\n\nexport class EnvironmentStorageService {\n    /**\n     * Lấy environment name từ chrome.storage\n     */\n    static async getEnvironmentName(): Promise<string> {\n        return new Promise((resolve) => {\n            chrome.storage.sync.get([STORAGE_KEY], (result) => {\n                const envName = result[STORAGE_KEY] || DEFAULT_ENVIRONMENT;\n                resolve(envName);\n            });\n        });\n    }\n\n    /**\n     * Lưu environment name vào chrome.storage\n     */\n    static async setEnvironmentName(name: string): Promise<void> {\n        return new Promise((resolve, reject) => {\n            if (!name || name.trim() === '') {\n                reject(new Error('Environment name cannot be empty'));\n                return;\n            }\n\n            chrome.storage.sync.set({ [STORAGE_KEY]: name.trim() }, () => {\n                if (chrome.runtime.lastError) {\n                    reject(chrome.runtime.lastError);\n                } else {\n                    resolve();\n                }\n            });\n        });\n    }\n\n    /**\n     * Lấy cấu hình Firebase. Ưu tiên storage, fallback về environment mặc định\n     */\n    static async getFirebaseConfig(): Promise<any> {\n        return new Promise((resolve) => {\n            chrome.storage.sync.get([FIREBASE_CONFIG_KEY], (result) => {\n                const customConfig = result[FIREBASE_CONFIG_KEY];\n                if (customConfig && Object.keys(customConfig).length > 0) {\n                    resolve(customConfig);\n                } else {\n                    resolve(environment.firebaseConfig);\n                }\n            });\n        });\n    }\n\n    /**\n     * Lưu cấu hình Firebase tùy chỉnh\n     */\n    static async setFirebaseConfig(config: any): Promise<void> {\n        return new Promise((resolve, reject) => {\n            chrome.storage.sync.set({ [FIREBASE_CONFIG_KEY]: config }, () => {\n                if (chrome.runtime.lastError) {\n                    reject(chrome.runtime.lastError);\n                } else {\n                    resolve();\n                }\n            });\n        });\n    }\n\n    /**\n     * Reset về giá trị mặc định\n     */\n    static async resetToDefault(): Promise<void> {\n        try {\n            await this.setEnvironmentName(DEFAULT_ENVIRONMENT);\n            // Xóa config firebase custom để dùng mặc định\n            await new Promise<void>((resolve) => {\n                chrome.storage.sync.remove(FIREBASE_CONFIG_KEY, () => resolve());\n            });\n        } catch (e) {\n            throw e;\n        }\n    }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import { EnvironmentStorageService } from './utils/environment-storage.service';\nimport { environment } from '../environments/environment';\n\n// DOM Elements\nconst form = document.getElementById('configForm') as HTMLFormElement;\nconst environmentInput = document.getElementById('environmentName') as HTMLInputElement;\nconst firebaseConfigInput = document.getElementById('firebaseConfig') as HTMLTextAreaElement;\nconst resetBtn = document.getElementById('resetBtn') as HTMLButtonElement;\nconst messageDiv = document.getElementById('message') as HTMLDivElement;\nconst currentEnvSpan = document.getElementById('currentEnv') as HTMLSpanElement;\n\n/**\n * Hiển thị thông báo cho người dùng\n */\nfunction showMessage(text: string, type: 'success' | 'error') {\n    messageDiv.textContent = text;\n    messageDiv.className = `message ${type}`;\n\n    // Tự động ẩn thông báo sau 3 giây\n    setTimeout(() => {\n        messageDiv.className = 'message';\n    }, 3000);\n}\n\n/**\n * Load và hiển thị giá trị hiện tại\n */\nasync function loadCurrentConfig() {\n    try {\n        // Load Env Name\n        const envName = await EnvironmentStorageService.getEnvironmentName();\n        currentEnvSpan.textContent = envName;\n        environmentInput.value = envName;\n\n        // Load Firebase Config\n        const fbConfig = await EnvironmentStorageService.getFirebaseConfig();\n        \n        // Kiểm tra xem có phải config mặc định không\n        const isDefault = JSON.stringify(fbConfig) === JSON.stringify(environment.firebaseConfig);\n        \n        if (!isDefault) {\n            firebaseConfigInput.value = JSON.stringify(fbConfig, null, 2);\n        } else {\n            firebaseConfigInput.value = ''; // Để trống nếu đang dùng default\n            firebaseConfigInput.placeholder = `Đang sử dụng mặc định:\\n${JSON.stringify(environment.firebaseConfig, null, 2)}`;\n        }\n\n    } catch (error) {\n        console.error('Error loading config:', error);\n        currentEnvSpan.textContent = 'Lỗi khi tải cấu hình';\n        showMessage('Không thể tải cấu hình hiện tại', 'error');\n    }\n}\n\n/**\n * Xử lý sự kiện submit form\n */\nasync function handleSubmit(event: Event) {\n    event.preventDefault();\n\n    const newEnvName = environmentInput.value.trim();\n    const firebaseConfigStr = firebaseConfigInput.value.trim();\n\n    if (!newEnvName) {\n        showMessage('Vui lòng nhập tên môi trường', 'error');\n        return;\n    }\n\n    try {\n        // 1. Lưu Environment Name\n        await EnvironmentStorageService.setEnvironmentName(newEnvName);\n        currentEnvSpan.textContent = newEnvName;\n\n        // 2. Lưu Firebase Config\n        if (firebaseConfigStr) {\n            try {\n                const configObj = JSON.parse(firebaseConfigStr);\n                // Validate sơ bộ\n                if (!configObj.apiKey || !configObj.databaseURL) {\n                    throw new Error(\"Config thiếu apiKey hoặc databaseURL\");\n                }\n                await EnvironmentStorageService.setFirebaseConfig(configObj);\n            } catch (e) {\n                showMessage('❌ JSON Firebase Config không hợp lệ: ' + (e as Error).message, 'error');\n                return;\n            }\n        } else {\n            // Nếu để trống, xóa custom config để dùng default\n             await new Promise<void>((resolve) => {\n                chrome.storage.sync.remove('firebaseConfig', () => resolve());\n            });\n        }\n\n        showMessage('✅ Lưu cấu hình thành công!', 'success');\n        // Reload lại hiển thị để update placeholder/value\n        loadCurrentConfig();\n        \n    } catch (error) {\n        console.error('Error saving settings:', error);\n        showMessage('❌ Lỗi khi lưu cấu hình: ' + (error as Error).message, 'error');\n    }\n}\n\n/**\n * Xử lý sự kiện reset về mặc định\n */\nasync function handleReset() {\n    if (!confirm('Bạn có chắc muốn đặt lại tất cả về mặc định?')) {\n        return;\n    }\n\n    try {\n        await EnvironmentStorageService.resetToDefault();\n        await loadCurrentConfig(); // Reload UI\n        showMessage('✅ Đã đặt lại về cấu hình mặc định!', 'success');\n    } catch (error) {\n        console.error('Error resetting environment:', error);\n        showMessage('❌ Lỗi khi đặt lại cấu hình', 'error');\n    }\n}\n\n// Event Listeners\nform.addEventListener('submit', handleSubmit);\nresetBtn.addEventListener('click', handleReset);\n\n// Load giá trị hiện tại khi trang được mở\nloadCurrentConfig();\n"],"names":[],"ignoreList":[],"sourceRoot":""}
|