1ac3d7cd5b
Fix sort() mutating state in getter by copying array first
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:10:18 +08:00
63fa11c44e
Wrap localStorage JSON.parse in try-catch in cytoscapeMap
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:10:17 +08:00
2a2eeabac7
Fix XSS in uploadFailedSecond default case with escapeHtml
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:10:16 +08:00
b58659295b
Fix null from match() crash in formatMaxTwo
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:10:14 +08:00
c6d073e119
Fix getYTicksByIndex truncating integers by using toFixed
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:10:09 +08:00
4dbed9fe56
Fix .trim() on null in conformance cases getter and add fallback returns
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:10:08 +08:00
19a39bbbff
Clean up dead code, typos, and minor style issues
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:00:31 +08:00
932275e4d4
Remove abandoned confirm-password feature hidden with v-show=false
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:00:26 +08:00
69d31c6c8b
Remove dead refs and empty focus handlers from LoginPage
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:00:24 +08:00
2710910829
Remove dead imports and constants from mapCompareStore
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 14:00:19 +08:00
6141e70235
Fix missing bounds checks, unsafe JSON.parse, and cleanup issues
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:56:47 +08:00
48784010ad
Fix chart data issues: 24-hour format, Y-axis bounds, rounding modes
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:55:45 +08:00
881dccc1ab
Fix memory leaks from Tippy.js instances and unremoved event listeners
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:54:38 +08:00
9acd722929
Fix splice(-1,1) removing last user when logged-in user not found
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:52:08 +08:00
3db725e52c
Fix static destructuring from reactive source in MyAccount and ModalAccountInfo
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:51:23 +08:00
8f610f1244
Fix array destructuring bug in moveJustCreateUserToFirstRow
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:50:18 +08:00
ac4405068f
Fix HTML injection risks in FilesPage and UploadPage
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-09 13:48:23 +08:00
89fae2cda7
Update MainContainer module documentation to match current route-guard responsibilities
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:41:46 +08:00
6e3aaca3b1
Extract reusable auth guard decision logic and test router auth behavior against it
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:39:10 +08:00
28fd83242c
Use UTF-8 safe return-to encoding and decoding across router and login
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:35:40 +08:00
28464214bc
Remove refreshToken navigation side effects and let callers handle redirects
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:32:06 +08:00
1670054356
Clear all auth cookies when API token refresh fails before redirecting to login
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:29:04 +08:00
b53f58cb0c
Clear refresh token cookie during logout to enforce full session termination
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:25:53 +08:00
955e9ceda9
Move auth-entry checks to router guard and simplify MainContainer route logic
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:14:20 +08:00
f3d11ebbcb
Refactor MainContainer child routes to consistent relative-path nesting
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:10:52 +08:00
b3f4ace13f
Enforce requiresAuth routes in global router guard with login return-to redirects
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:07:56 +08:00
a8cd590a11
Require access token presence in MainContainer auth gate before route entry
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 19:01:03 +08:00
0948a82eb5
Align compare navbar state mapping with MAP and PERFORMANCE tabs
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 18:58:01 +08:00
7309c97502
Remove redundant self-assignment watcher in navbar state
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 14:14:11 +08:00
2721aed928
Handle invalid return-to payloads without misclassifying login as failed
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 13:52:47 +08:00
fc43ca67ca
Rename single-word Vue files to multi-word names and update references
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 13:26:12 +08:00
ae03b9cedd
Enable multi-word Vue component names with explicit naming
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 13:01:16 +08:00
d03041c2e3
Enable vue/no-side-effects-in-computed-properties and refactor computed state sync
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 12:45:39 +08:00
c88646eba3
Enable vue/return-in-computed-property and add explicit fallback returns
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 12:39:11 +08:00
1bf8355092
Enable vue/no-unused-vars and fix template loop variable
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 12:34:27 +08:00
2a2948fd24
Re-enable key Vue lint rules and fix resulting violations
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 12:30:17 +08:00
52a36e3a7c
Resolve remaining lint violations and stabilize ESLint config
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 12:24:45 +08:00
847904c49b
Apply repository-wide ESLint auto-fix formatting pass
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 12:11:57 +08:00
ef9cf2de8c
Migrate router type augmentation to Vue 3 runtime core
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 11:55:06 +08:00
d7caf08d1f
Fix design file metadata mapping in files store
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 10:47:49 +08:00
8acb1b50de
Persist relative return-to path for post-login redirect
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 10:44:53 +08:00
e275e79a63
Sanitize Cytoscape tooltip labels to prevent XSS
...
Co-Authored-By: Codex <codex@openai.com >
2026-03-08 10:41:48 +08:00
1d621bf304
Translate all Chinese comments and strings to English
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 20:03:19 +08:00
7d5918837b
Add try-catch to async IIFEs to prevent unhandled rejections
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 18:11:27 +08:00
ede7becb3a
Remove await on non-promise values
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 18:06:29 +08:00
1b5f97dc9a
Remove unnecessary persist:true from acctMgmt store
...
The store only holds transient data (user list refetched from API,
hover/menu UI states) that should not survive page reload.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 17:58:39 +08:00
07a2518e76
Remove unused $moment and $emitter from globalProperties
...
These were set for Options API (this.$moment, this.$emitter) but all
components now use <script setup> with direct imports.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 17:53:00 +08:00
5b3130ea9c
Compute refresh token expiry fresh on each sign-in
...
The expiry date was computed once at store init time and went stale
in long-running SPA sessions.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 17:49:14 +08:00
ba7c1c7cd0
Rename allUserAccoutList to allUserAccountList (fix typo)
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 17:43:12 +08:00
fe4738b04c
Add encodeURIComponent for username in API URL paths
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-03-07 16:58:30 +08:00