1
0
zxlie 6 сар өмнө
parent
commit
48ebce5fe4

+ 10 - 0
.cursorignore

@@ -0,0 +1,10 @@
+# 工程文件
+.idea
+.DS_Store
+.todolist
+node_modules/
+package-lock.json
+Users/
+output/apps/
+output-firefox/apps/
+output-edge/apps/

+ 0 - 1
apps/options/index.html

@@ -3,7 +3,6 @@
 <head>
     <title>FeHelper-插件市场</title>
     <meta charset="utf-8">
-    <link rel="stylesheet" href="index.css"/>
     <link rel="stylesheet" href="market.css"/>
     <script type="text/javascript" src="../static/vendor/evalCore.min.js"></script>
     <script type="text/javascript" src="../static/vendor/vue/vue.js"></script>

+ 107 - 43
apps/options/market.css

@@ -704,7 +704,7 @@
 }
 
 .settings-body {
-    padding: 20px;
+    padding: 0 20px;
     overflow-y: auto;
     flex: 1;
     scrollbar-width: thin;
@@ -951,6 +951,9 @@
 }
 
 .nav-item {
+    position: relative;
+    transition: all 0.3s ease;
+    overflow: hidden;
     display: flex;
     align-items: center;
     justify-content: center;
@@ -958,7 +961,6 @@
     text-decoration: none;
     padding: 8px 15px;
     border-radius: 6px;
-    transition: all 0.3s ease;
     font-size: 14px;
     box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
     min-width: 100px;
@@ -966,9 +968,9 @@
 }
 
 .nav-item:hover {
-    background-color: rgba(255, 255, 255, 0.25);
-    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
+    background-color: rgba(255, 255, 255, 0.1);
     transform: translateY(-2px);
+    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
     color: #fff;
     text-decoration: none;
 }
@@ -979,75 +981,106 @@
 }
 
 .nav-icon {
+    display: inline-block;
+    transition: all 0.3s ease;
     margin-right: 6px;
     font-size: 16px;
 }
 
-/* 设置按钮样式 */
-.settings-link {
-    position: relative;
-    overflow: hidden;
-    background-color: rgba(255, 255, 255, 0.15);
+.nav-item:hover .nav-icon {
+    transform: scale(1.2) rotate(10deg);
 }
 
-.settings-link .nav-icon {
-    transition: transform 0.5s ease;
+/* 波纹效果 */
+.nav-item::after {
+    content: '';
+    position: absolute;
+    top: 50%;
+    left: 50%;
+    width: 5px;
+    height: 5px;
+    background: rgba(255, 255, 255, 0.3);
+    opacity: 0;
+    border-radius: 100%;
+    transform: scale(1, 1) translate(-50%);
+    transform-origin: 50% 50%;
 }
 
-.settings-link:hover .nav-icon {
-    transform: rotate(180deg);
+.nav-item:hover::after {
+    animation: ripple 0.6s ease-out;
 }
 
-/* 打赏按钮样式 */
-.donate-link {
+/* 打赏鼓励按钮特殊效果 */
+.navbar-actions .donate-link {
     background: linear-gradient(135deg, #ff9a9e 0%, #fad0c4 99%, #fad0c4 100%);
     color: #333;
     position: relative;
     overflow: hidden;
 }
 
-.donate-link:hover {
-    background: linear-gradient(135deg, #ff9a9e 0%, #fecfef 99%, #fecfef 100%);
+.navbar-actions .donate-link:hover {
+    background: linear-gradient(45deg, #ff7675, #d63031);
+    transform: translateY(-3px);
+    box-shadow: 0 5px 15px rgba(255, 105, 97, 0.4);
+    color: #fff;
 }
 
-.donate-link .nav-icon {
+.navbar-actions .donate-link .nav-icon {
     color: #e74c3c;
-    animation: heartbeat 1.3s ease-in-out infinite;
+    font-size: 18px;
 }
 
-.donate-link:hover .nav-icon {
-    animation: heartbeat 0.6s ease-in-out infinite;
+.navbar-actions .donate-link:hover .nav-icon {
+    animation: heartbeat 1.2s infinite;
+    color: #fff;
 }
 
-/* 版本信息样式 */
-.version-info {
-    display: flex;
-    align-items: center;
-    background: rgba(255, 255, 255, 0.15);
-    padding: 8px 15px;
-    border-radius: 6px;
-    flex-wrap: wrap;
-    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
+/* 设置按钮特殊效果 */
+.navbar-actions .settings-link {
+    position: relative;
+    overflow: hidden;
+    background-color: rgba(255, 255, 255, 0.15);
 }
 
-/* 暗黑模式下导航栏样式 */
-.dark-mode .main-navbar {
-    background: linear-gradient(to right, #1a1a2e, #16213e);
+.navbar-actions .settings-link:hover {
+    background: linear-gradient(45deg, #74b9ff, #0984e3);
 }
 
-/* 暗模式下的设置按钮样式 */
-.dark-mode .settings-link {
-    background-color: rgba(255, 255, 255, 0.08);
-    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
+.navbar-actions .settings-link .nav-icon {
+    transition: transform 0.5s ease;
 }
 
-.dark-mode .settings-link:hover {
-    background-color: rgba(255, 255, 255, 0.15);
-    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
+.navbar-actions .settings-link:hover .nav-icon {
+    animation: rotate 2s linear infinite;
+}
+
+/* 动画关键帧 */
+@keyframes ripple {
+    0% {
+        transform: scale(0, 0);
+        opacity: 1;
+    }
+    20% {
+        transform: scale(25, 25);
+        opacity: 1;
+    }
+    100% {
+        opacity: 0;
+        transform: scale(40, 40);
+    }
 }
 
-.dark-mode .settings-link::after {
-    background: rgba(255, 255, 255, 0.5);
+@keyframes heartbeat {
+    0% { transform: scale(1); }
+    25% { transform: scale(1.3); }
+    50% { transform: scale(1); }
+    75% { transform: scale(1.3); }
+    100% { transform: scale(1); }
+}
+
+@keyframes rotate {
+    0% { transform: rotate(0deg); }
+    100% { transform: rotate(360deg); }
 }
 
 /* 响应式调整 */
@@ -1416,7 +1449,7 @@
 }
 
 .donate-image {
-    max-width: 200px;
+    max-width: 250px;
     border-radius: 10px;
     box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
     margin-bottom: 15px;
@@ -1527,3 +1560,34 @@
 .dark-mode .confirm-message {
     color: #ddd;
 }
+
+/* 暗黑模式下的导航栏按钮样式 */
+.dark-mode .navbar-actions .settings-link {
+    background-color: rgba(255, 255, 255, 0.08);
+    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
+}
+
+.dark-mode .navbar-actions .settings-link:hover {
+    background: linear-gradient(45deg, #3498db, #2980b9);
+    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
+}
+
+.dark-mode .navbar-actions .donate-link {
+    background: linear-gradient(135deg, #ff6b6b 0%, #f39c12 100%);
+    color: #fff;
+}
+
+.dark-mode .navbar-actions .donate-link:hover {
+    background: linear-gradient(45deg, #e74c3c, #c0392b);
+    color: #fff;
+}
+
+/* 暗黑模式下的波纹效果 */
+.dark-mode .navbar-actions .nav-item::after {
+    background: rgba(255, 255, 255, 0.4);
+}
+
+.dark-mode .navbar-actions .donate-link .nav-icon,
+.dark-mode .navbar-actions .settings-link .nav-icon {
+    color: #fff;
+}

+ 39 - 5
apps/options/market.js

@@ -8,12 +8,10 @@ const TOOL_CATEGORIES = [
     { key: 'encode', name: '编解码转换类', tools: ['en-decode', 'trans-radix', 'timestamp', 'trans-color'] },
     { key: 'image', name: '图像处理类', tools: ['qr-code', 'image-base64', 'screenshot', 'color-picker'] },
     { key: 'productivity', name: '效率工具类', tools: ['aiagent', 'sticky-notes', 'html2markdown', 'page-monkey'] },
-    { key: 'calculator', name: '计算工具类', tools: ['crontab', 'loan-rate', 'password'] }
+    { key: 'calculator', name: '计算工具类', tools: ['crontab', 'loan-rate', 'password'] },
+    { key: 'other', name: '其他工具', tools: [] }
 ];
 
-// 插件在Chrome商店中的ID
-const EXTENSION_ID = 'pkgccpejnmalmdinmhkkfafefagiiiad';
-
 // Vue实例
 new Vue({
     el: '#marketContainer',
@@ -116,7 +114,20 @@ new Vue({
                         acc.push(...category.tools);
                         return acc;
                     }, []);
-                    result.sort((a, b) => allTools.indexOf(a.key) - allTools.indexOf(b.key));
+                    
+                    result.sort((a, b) => {
+                        const indexA = allTools.indexOf(a.key);
+                        const indexB = allTools.indexOf(b.key);
+                        
+                        // 如果工具不在任何类别中,放到最后
+                        if (indexA === -1 && indexB === -1) {
+                            return a.key.localeCompare(b.key); // 字母顺序排序
+                        }
+                        if (indexA === -1) return 1;
+                        if (indexB === -1) return -1;
+                        
+                        return indexA - indexB;
+                    });
             }
 
             return result;
@@ -169,6 +180,9 @@ new Vue({
                 
                 // 初始化activeTools为所有工具
                 this.activeTools = { ...processedTools };
+                
+                // 更新"其他工具"类别
+                this.updateOtherCategory(Object.keys(processedTools));
 
                 // 默认选中第一个分类
                 if (TOOL_CATEGORIES.length > 0) {
@@ -180,6 +194,26 @@ new Vue({
                 this.loading = false;
             }
         },
+        
+        // 更新"其他工具"类别,将未分类的工具添加到此类别
+        updateOtherCategory(allToolKeys) {
+            // 获取所有已分类的工具
+            const categorizedTools = new Set();
+            TOOL_CATEGORIES.forEach(category => {
+                if (category.key !== 'other') {
+                    category.tools.forEach(tool => categorizedTools.add(tool));
+                }
+            });
+            
+            // 找出未分类的工具
+            const uncategorizedTools = allToolKeys.filter(key => !categorizedTools.has(key));
+            
+            // 更新"其他工具"类别
+            const otherCategory = TOOL_CATEGORIES.find(category => category.key === 'other');
+            if (otherCategory) {
+                otherCategory.tools = uncategorizedTools;
+            }
+        },
 
         // 检查版本更新
         async checkVersionUpdate() {