Files
pig-farm-controller/frontend/dist/assets/index.42c8d2d4.css
huang cc7ea94e41 1. 实现前端删除饲喂计划
2. 修复后端delete接口bug
2025-09-10 16:25:52 +08:00

2 lines
14 KiB
CSS

*{margin:0;padding:0;box-sizing:border-box}#app{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f5f7fa;min-height:100vh}.login-container[data-v-bb5c78dc]{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 15px 35px #0003;padding:40px;width:100%;max-width:400px;text-align:center;animation:fadeIn-bb5c78dc .5s ease-out;margin:100px auto}@keyframes fadeIn-bb5c78dc{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.logo[data-v-bb5c78dc]{width:80px;height:80px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px;font-weight:700}h1[data-v-bb5c78dc]{color:#333;margin-bottom:10px;font-size:28px}.subtitle[data-v-bb5c78dc]{color:#666;margin-bottom:30px;font-size:14px}.form-group[data-v-bb5c78dc]{margin-bottom:20px;text-align:left}label[data-v-bb5c78dc]{display:block;margin-bottom:8px;color:#555;font-weight:500}input[data-v-bb5c78dc]{width:100%;padding:15px;border:2px solid #e1e1e1;border-radius:10px;font-size:16px;transition:all .3s ease;outline:none}input[data-v-bb5c78dc]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}button[data-v-bb5c78dc]{width:100%;padding:15px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}button[data-v-bb5c78dc]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}button[data-v-bb5c78dc]:disabled{opacity:.7;cursor:not-allowed}.error-message[data-v-bb5c78dc]{color:#dc3545;margin-top:15px;padding:10px;background-color:#f8d7da;border-radius:5px}.success-message[data-v-bb5c78dc]{color:#28a745;margin-top:15px;padding:10px;background-color:#d4edda;border-radius:5px}.header[data-v-904f2d71]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:20px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.header h1[data-v-904f2d71]{font-size:24px;display:flex;align-items:center;gap:10px}.user-info[data-v-904f2d71]{display:flex;align-items:center;gap:15px}.logout-btn[data-v-904f2d71]{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 15px;border-radius:5px;cursor:pointer;transition:all .3s ease}.logout-btn[data-v-904f2d71]:hover{background:rgba(255,255,255,.3)}.nav[data-v-904f2d71]{background:white;padding:15px 20px;box-shadow:0 2px 5px #0000000d}.nav ul[data-v-904f2d71]{display:flex;list-style:none;gap:20px}.nav a[data-v-904f2d71]{text-decoration:none;color:#666;padding:8px 15px;border-radius:5px;transition:all .3s ease}.nav a[data-v-904f2d71]:hover,.nav a.active[data-v-904f2d71]{background:#667eea;color:#fff}.container[data-v-904f2d71]{max-width:1200px;margin:30px auto;padding:0 20px}.dashboard-grid[data-v-904f2d71]{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:30px}.card[data-v-904f2d71]{background:white;border-radius:15px;box-shadow:0 5px 15px #00000014;padding:25px;transition:transform .3s ease,box-shadow .3s ease}.card[data-v-904f2d71]:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.card h3[data-v-904f2d71]{color:#333;margin-bottom:15px;display:flex;align-items:center;gap:10px}.card p[data-v-904f2d71]{color:#666;line-height:1.6}.device-control[data-v-904f2d71]{background:white;border-radius:15px;box-shadow:0 5px 15px #00000014;padding:25px;margin-bottom:30px}.control-grid[data-v-904f2d71]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:20px}.control-item[data-v-904f2d71]{background:#f8f9fa;border-radius:10px;padding:20px;text-align:center}.control-item h4[data-v-904f2d71]{margin-bottom:15px;color:#333}.control-buttons[data-v-904f2d71]{display:flex;gap:10px;justify-content:center}.control-btn[data-v-904f2d71]{padding:8px 15px;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:all .3s ease}.on-btn[data-v-904f2d71]{background:#28a745;color:#fff}.off-btn[data-v-904f2d71]{background:#dc3545;color:#fff}.control-btn[data-v-904f2d71]:hover{opacity:.9;transform:translateY(-2px)}@media (max-width: 768px){.dashboard-grid[data-v-904f2d71]{grid-template-columns:1fr}.header[data-v-904f2d71]{flex-direction:column;gap:15px}}.device-management[data-v-a2f9bd42]{height:100vh;display:flex;flex-direction:column;background-color:#f5f7fa}.nav[data-v-a2f9bd42]{background-color:#343a40;padding:0;margin-bottom:20px}.nav ul[data-v-a2f9bd42]{list-style-type:none;margin:0;padding:0;display:flex}.nav li[data-v-a2f9bd42]{margin:0}.nav a[data-v-a2f9bd42]{display:block;padding:15px 20px;color:#fff;text-decoration:none;transition:background-color .3s}.nav a[data-v-a2f9bd42]:hover{background-color:#495057}.nav a.active[data-v-a2f9bd42]{background-color:#007bff}.header[data-v-a2f9bd42]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.header h1[data-v-a2f9bd42]{margin:0;font-size:1.5rem;display:flex;align-items:center;gap:10px}.user-info[data-v-a2f9bd42]{display:flex;align-items:center;gap:1rem}.logout-btn[data-v-a2f9bd42]{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .3s ease}.logout-btn[data-v-a2f9bd42]:hover{background:rgba(255,255,255,.3)}.main-content[data-v-a2f9bd42]{flex:1;padding:1.5rem;overflow-y:auto}.toolbar[data-v-a2f9bd42]{margin-bottom:1.5rem;display:flex;justify-content:flex-end}.btn[data-v-a2f9bd42]{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary[data-v-a2f9bd42]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;box-shadow:0 4px 15px #0003}.btn-primary[data-v-a2f9bd42]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.btn-secondary[data-v-a2f9bd42]{background:#f5f5f5;color:#333;border:1px solid #ddd}.btn-secondary[data-v-a2f9bd42]:hover{background:#e0e0e0}.device-tree[data-v-a2f9bd42]{background:white;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:1.5rem;overflow:hidden}.tree-node[data-v-a2f9bd42]{margin-bottom:.75rem;border-radius:8px;transition:all .3s ease;box-shadow:0 1px 3px #0000001a}.tree-node[data-v-a2f9bd42]:hover{box-shadow:0 2px 8px #00000026}.tree-node.relay-node[data-v-a2f9bd42]{background:#fff3e0;border-left:4px solid #ff9800}.tree-node.controller-node[data-v-a2f9bd42]{background:#e3f2fd;border-left:4px solid #2196f3;margin-left:1.5rem}.tree-node.device-node[data-v-a2f9bd42]{background:#e8f5e9;border-left:4px solid #4caf50;margin-left:3rem}.node-header[data-v-a2f9bd42]{display:flex;justify-content:space-between;align-items:center;padding:1rem;cursor:pointer}.node-header[data-v-a2f9bd42]:hover{background-color:#00000005}.node-info[data-v-a2f9bd42]{display:flex;align-items:center;gap:.75rem}.toggle-icon[data-v-a2f9bd42]{width:20px;text-align:center;font-size:.8rem;color:#666}.node-title[data-v-a2f9bd42]{font-weight:600;color:#333;font-size:1.1rem}.node-address[data-v-a2f9bd42]{font-size:.9rem;color:#666;background:rgba(0,0,0,.05);padding:.2rem .5rem;border-radius:4px}.node-type[data-v-a2f9bd42]{font-size:.8rem;padding:.3rem .6rem;border-radius:12px;font-weight:500;text-transform:uppercase}.node-status[data-v-a2f9bd42]{font-size:.8rem;padding:.3rem .6rem;border-radius:12px;font-weight:500}.status-active[data-v-a2f9bd42]{background:#4caf50;color:#fff}.status-inactive[data-v-a2f9bd42]{background:#9e9e9e;color:#fff}.relay-type[data-v-a2f9bd42]{background:#ff9800;color:#fff}.controller-type[data-v-a2f9bd42]{background:#2196f3;color:#fff}.device-type[data-v-a2f9bd42]{background:#4caf50;color:#fff}.node-actions[data-v-a2f9bd42]{display:flex;gap:.5rem}.action-btn[data-v-a2f9bd42]{padding:.4rem .8rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.edit-btn[data-v-a2f9bd42]{background:#1976d2;color:#fff}.edit-btn[data-v-a2f9bd42]:hover{background:#1565c0;transform:translateY(-1px)}.delete-btn[data-v-a2f9bd42]{background:#d32f2f;color:#fff}.delete-btn[data-v-a2f9bd42]:hover{background:#c62828;transform:translateY(-1px)}.children-container[data-v-a2f9bd42]{padding:.5rem 0 .5rem 1rem;border-left:2px dashed rgba(0,0,0,.1);margin-left:1rem}.modal[data-v-a2f9bd42]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn-a2f9bd42 .3s ease}@keyframes fadeIn-a2f9bd42{0%{opacity:0}to{opacity:1}}.modal-content[data-v-a2f9bd42]{background:white;border-radius:10px;width:90%;max-width:500px;box-shadow:0 10px 30px #0000004d;animation:slideIn-a2f9bd42 .3s ease}@keyframes slideIn-a2f9bd42{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-a2f9bd42]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.modal-header h3[data-v-a2f9bd42]{margin:0;color:#333;font-size:1.3rem}.close-btn[data-v-a2f9bd42]{background:none;border:none;font-size:1.8rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:#999;transition:color .2s ease}.close-btn[data-v-a2f9bd42]:hover{color:#333}.modal-body[data-v-a2f9bd42]{padding:1.5rem}.form-group[data-v-a2f9bd42]{margin-bottom:1.5rem}.form-group label[data-v-a2f9bd42]{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input[data-v-a2f9bd42],.form-group select[data-v-a2f9bd42]{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.form-group input[data-v-a2f9bd42]:focus,.form-group select[data-v-a2f9bd42]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-footer[data-v-a2f9bd42]{padding:1.5rem;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:.75rem}.no-devices[data-v-a2f9bd42]{text-align:center;color:#7f8c8d;padding:3rem;font-style:italic;font-size:1.1rem}@media (max-width: 768px){.main-content[data-v-a2f9bd42],.header[data-v-a2f9bd42]{padding:1rem}.node-header[data-v-a2f9bd42]{flex-direction:column;align-items:flex-start;gap:.75rem}.node-actions[data-v-a2f9bd42]{align-self:flex-end}.tree-node.controller-node[data-v-a2f9bd42],.tree-node.device-node[data-v-a2f9bd42]{margin-left:1rem}}.feed-plan-management[data-v-181c8146]{padding:20px}.header[data-v-181c8146]{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #eee}.header h1[data-v-181c8146]{margin:0;color:#333}.user-info[data-v-181c8146]{display:flex;align-items:center;gap:15px}.logout-btn[data-v-181c8146]{padding:8px 16px;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.logout-btn[data-v-181c8146]:hover{background-color:#c82333}.nav[data-v-181c8146]{background-color:#343a40;padding:0;margin-bottom:20px}.nav ul[data-v-181c8146]{list-style-type:none;margin:0;padding:0;display:flex}.nav li[data-v-181c8146]{margin:0}.nav a[data-v-181c8146]{display:block;padding:15px 20px;color:#fff;text-decoration:none;transition:background-color .3s}.nav a[data-v-181c8146]:hover{background-color:#495057}.nav a.active[data-v-181c8146]{background-color:#007bff}.toolbar[data-v-181c8146]{margin-bottom:20px}.btn[data-v-181c8146]{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.btn-primary[data-v-181c8146]{background-color:#007bff;color:#fff}.btn-primary[data-v-181c8146]:hover{background-color:#0069d9}.plan-list[data-v-181c8146]{min-height:400px}.loading[data-v-181c8146],.no-plans[data-v-181c8146]{text-align:center;padding:50px;color:#666;font-size:16px}.plans-container[data-v-181c8146]{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.plan-card[data-v-181c8146]{border:1px solid #ddd;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;background-color:#fff;transition:box-shadow .3s,transform .3s}.plan-card[data-v-181c8146]:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.plan-header[data-v-181c8146]{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.plan-header h3[data-v-181c8146]{margin:0;color:#333;font-size:18px}.plan-status[data-v-181c8146]{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700}.plan-status.enabled[data-v-181c8146]{background-color:#d4edda;color:#155724}.plan-status.disabled[data-v-181c8146]{background-color:#f8d7da;color:#721c24}.plan-details[data-v-181c8146]{margin-bottom:20px}.plan-description[data-v-181c8146]{margin:0 0 15px;color:#666;line-height:1.5}.plan-meta[data-v-181c8146]{display:flex;flex-wrap:wrap;gap:10px}.plan-type[data-v-181c8146],.plan-cron[data-v-181c8146]{padding:4px 8px;background-color:#e9ecef;border-radius:4px;font-size:12px;color:#495057}.plan-actions[data-v-181c8146]{display:flex;gap:10px;justify-content:flex-end}.action-btn[data-v-181c8146]{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:background-color .3s}.detail-btn[data-v-181c8146]{background-color:#17a2b8;color:#fff}.detail-btn[data-v-181c8146]:hover{background-color:#138496}.edit-btn[data-v-181c8146]{background-color:#ffc107;color:#212529}.edit-btn[data-v-181c8146]:hover{background-color:#e0a800}.delete-btn[data-v-181c8146]{background-color:#dc3545;color:#fff}.delete-btn[data-v-181c8146]:hover{background-color:#c82333}@media (max-width: 768px){.plans-container[data-v-181c8146]{grid-template-columns:1fr}.header[data-v-181c8146]{flex-direction:column;gap:15px;align-items:flex-start}.nav ul[data-v-181c8146]{flex-direction:column}}