oceanhelm 0.0.1 → 0.0.3

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/dist/style.css CHANGED
@@ -1 +1 @@
1
- .left[data-v-5c9320f4]{margin-left:20px}.black[data-v-5c9320f4]{color:#000!important}.left{margin-left:20px}.vessel-card{background:white;border-radius:10px;box-shadow:0 8px 16px #0069c026;transition:all .3s ease;margin-bottom:20px;overflow:hidden;border-left:4px solid var(--accent-color)}.vessel-card:hover{transform:translateY(-5px);box-shadow:0 12px 20px #0069c033}.vessel-icon{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;background-color:#e3f2fd;border-radius:10px;color:var(--accent-color);font-size:24px;margin-right:15px}.black{color:#000!important}.action-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:20px;color:var(--accent-color);font-size:16px;margin-right:15px;margin-top:20px;margin-bottom:10px}.delete{background-color:var(--danger)}.edit{background-color:var(--success)}.vessel-status{display:inline-block;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600}.status-active{background-color:#e8f5e9;color:#2e7d32}.status-maintenance{background-color:#fff8e1;color:#f57f17}.status-inactive{background-color:#f5f5f5;color:#757575}.page-header{margin-bottom:30px;border-bottom:1px solid #e0e0e0;padding-bottom:15px}.progress-container{margin-bottom:20px}.progress-bar{background-color:#e9ecef;border-radius:4px;height:10px;margin-top:8px}.progress-fill{background-color:#00a8e8;height:100%;border-radius:4px;transition:width .3s ease}.checklist{list-style-type:none;padding:0}.checklist-item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #eee;cursor:pointer}.checkbox{margin-right:15px;width:20px;height:20px;border:2px solid #00a8e8;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkbox.checked{background-color:#00a8e8;color:#fff}.task-text{flex-grow:1}.task-text.completed{text-decoration:line-through;color:#6c757d}.status{margin-top:20px;font-weight:700;text-align:center}.reset-button{background-color:#005792;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:20px;font-weight:700}.btn-outline-custom{color:#005792;border:2px solid #005792;background-color:transparent;padding:8px 16px;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .3s,color .3s}.btn-outline-custom:hover{background-color:#005792;color:#fff}.reset-button:hover{background-color:#003d5b}header{background-color:var(--maitprimary);color:#fff;padding:1rem;text-align:center;border-radius:5px 5px 0 0}nav{background-color:var(--maitsecondary);padding:10px;display:flex;justify-content:center}nav button{background-color:var(--maitsecondary);color:#fff;border:none;padding:10px 20px;margin:0 5px;cursor:pointer;font-weight:700;border-radius:3px;transition:background-color .3s}nav button:hover,nav button.active{background-color:var(--maitprimary)}.content{background-color:#fff;padding:20px;border-radius:0 0 5px 5px;box-shadow:0 2px 10px #0000001a}h2{color:var(--dark);margin-bottom:20px;border-bottom:2px solid var(--light);padding-bottom:10px}.form-section{display:none;animation:fadeIn .5s}.form-section.active{display:block}.form-row{margin-bottom:15px}.form-group{margin-bottom:20px}label{display:block;margin-bottom:5px;font-weight:700;color:var(--dark)}input,select,textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:16px}.input-group{display:flex;gap:10px}.input-group>div{flex:1}textarea{height:120px;resize:vertical}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .3s}.btn-primary{background-color:var(--maitprimary);color:#fff}.btn-primary:hover{background-color:var(--dark)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{background-color:#219653}.action-buttons{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.status-badge{display:inline-block;padding:5px 10px;border-radius:15px;font-size:14px;font-weight:700;color:#fff}.status-pending{background-color:var(--warning)}.status-progress{background-color:var(--accent)}.status-completed{background-color:var(--success)}.attachment-area{border:2px dashed #ddd;padding:20px;text-align:center;border-radius:5px;margin-bottom:20px}.file-input{display:none}.file-label{display:inline-block;padding:10px 20px;background-color:var(--accent);color:#fff;border-radius:4px;cursor:pointer;transition:background-color .3s}.file-label:hover{background-color:var(--maitsecondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-section h3{margin-top:30px;margin-bottom:15px;color:var(--maitsecondary)}.checkbox-group{display:flex;flex-wrap:wrap;gap:15px;margin-top:10px}.checkbox-item{display:flex;align-items:center;gap:5px}.checkbox-item input{width:auto}.status-badge{padding:.3em .6em;border-radius:4px;color:#fff;font-weight:700;font-size:.85rem}.status-action{padding:.3em .6em;border-radius:4px;color:#fff;font-weight:700;font-size:.85rem;background-color:var(--maitprimary)}.status-badge.overdue{background-color:red}.task-table-wrapper{font-family:Inter,sans-serif;padding:1rem}.table-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.filters{display:flex;gap:.5rem;flex-wrap:wrap}.filters button,.filters input{padding:.5rem 1rem;border-radius:6px;border:1px solid #ccc;background-color:#f5f5f5;font-weight:500;cursor:pointer}.filters button.active{background-color:#002f6c;color:#fff}.filters input{border:1px solid #bbb}.filter-badge{background-color:#eee;color:#333}.table-controls>div:last-child button{padding:.5rem 1rem;border:1px solid var(--maitprimary);border-radius:6px;background-color:#fff;color:var(--maitprimary);font-weight:600;cursor:pointer;transition:background .2s}.table-controls>div:last-child button:last-child{background-color:var(--maitprimary);color:#fff}.task-table{width:100%;border-collapse:collapse;box-shadow:0 0 0 1px #ccc}.task-table thead{background-color:var(--maitprimary);color:#fff}.task-table th,.task-table td{padding:.75rem;text-align:left;border-bottom:1px solid #eee;white-space:pre-line}.task-table tbody tr:hover{background-color:#f9f9f9}.status-badge{padding:.3em .6em;border-radius:6px;font-weight:700;font-size:.85rem;color:#fff;display:inline-block;text-align:center;min-width:90px}.status-badge.complete{background-color:#4dffd0}.status-badge.soon{background-color:orange}.status-badge.completed{background-color:#4caf50}.delete-btn{background:none;border:none;color:#dc3545;cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:1;margin-left:8px;flex-shrink:0;transform:scale(1.1)}.checklist-item:hover .delete-btn{opacity:1}.delete-btn:hover{background-color:#dc3545;color:#fff;transform:scale(1.1)}.delete-btn:active{transform:scale(.95)}.print-only-container{text-align:center}.initial-print-btn{background:linear-gradient(135deg,#0066cc,#004499);color:#fff;border:none;padding:20px 40px;font-size:1.3em;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px #0066cc4d;display:flex;align-items:center;gap:15px;margin:0 auto}.initial-print-btn:hover{background:linear-gradient(135deg,#004499,#003366);transform:translateY(-3px);box-shadow:0 8px 25px #06c6}.initial-print-btn:active{transform:translateY(0)}.company-branding{margin-bottom:30px}.company-logo{font-size:3em;font-weight:700;color:#06c;margin-bottom:10px}.company-tagline{font-size:1.1em;color:#666}.report-container{display:none;max-width:900px;margin:0 auto;background:white;padding:30px;border-radius:10px;box-shadow:0 4px 15px #0000001a}.header{text-align:center;border-bottom:3px solid #0066cc;padding-bottom:20px;margin-bottom:30px}.report-logo{font-size:2.5em;font-weight:700;color:#06c;margin-bottom:10px}.report-title{font-size:1.8em;color:#333;margin:10px 0}.report-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.info-box{background:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #0066cc}.info-box ul li{margin-left:15px}.info-label{font-weight:700;color:#06c;margin-bottom:5px}.section{margin-bottom:30px}.section-title{font-size:1.3em;font-weight:700;color:#06c;border-bottom:2px solid #e9ecef;padding-bottom:10px;margin-bottom:15px}.task-item{background:#f8f9fa;margin:15px 0;padding:20px;border-radius:8px;border-left:4px solid #28a745;box-shadow:0 2px 5px #0000001a}.task-item.pending{border-left-color:#ffc107}.task-item.overdue{border-left-color:#dc3545}.task-item.in-progress{border-left-color:#17a2b8}.task-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;flex-wrap:wrap;gap:10px}.task-title{font-size:1.2em;font-weight:700;color:#333}.task-component{font-size:.9em;color:#666;margin-top:5px}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.8em;font-weight:700;text-transform:uppercase}.status-completed{background:#d4edda;color:#155724}.status-pending{background:#fff3cd;color:#856404}.status-overdue{background:#f8d7da;color:#721c24}.status-in-progress{background:#d1ecf1;color:#0c5460}.task-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin:15px 0}.detail-item{display:flex;flex-direction:column}.detail-label{font-weight:700;font-size:.85em;color:#06c;margin-bottom:3px}.detail-value{font-size:.95em;color:#333}.checklist-progress{margin-top:15px}.progress-bar{width:100%;height:20px;background:#e9ecef;border-radius:10px;overflow:hidden;margin:10px 0}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .3s ease}.checklist-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:10px}.checklist-item{display:flex;align-items:center;padding:8px;background:white;border-radius:5px;font-size:.9em}.checklist-icon{margin-right:8px;font-size:1.1em}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin:20px 0}.summary-card{background:white;padding:20px;border-radius:8px;text-align:center;border:2px solid #e9ecef}.summary-number{font-size:2em;font-weight:700;color:#06c}.summary-label{font-size:.9em;color:#666;margin-top:5px}.signature-section{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:40px}.signature-box{padding-top:10px;text-align:center}.maintenance-type{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75em;font-weight:700;text-transform:uppercase;margin-left:10px}.type-corrective{background:#fff3cd;color:#856404}.type-preventive{background:#d4edda;color:#155724}.type-predictive{background:#d1ecf1;color:#0c5460}@media print{body{background:white;padding:0;display:block}.print-only-container{display:none!important}.report-container{display:block!important;box-shadow:none;padding:0;margin:0;max-width:none}}.header{background:linear-gradient(135deg,var(--dashprimary-color),var(--dashsecondary-color));color:#fff;padding:2rem 0;margin-bottom:2rem;border-radius:12px;box-shadow:0 10px 30px #3499404d}.header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}.header p{text-align:center;opacity:.9;font-size:1.1rem}.controls{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:250px;position:relative}.search-box input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease}.search-box input:focus{outline:none;border-color:var(--dashsecondary-color);box-shadow:0 0 0 3px #3499401a}.filter-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:white;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:var(--dashsecondary-color);box-shadow:0 0 0 3px #3499401a}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #3499404d}.btn-secondary{background:var(--secondary);color:var(--dark)}.btn-secondary:hover{background:#e6a200;transform:translateY(-1px);box-shadow:0 4px 12px #f4b4004d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 4px 20px #0000000d;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:var(--gray);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.stat-card .value{font-size:2rem;font-weight:700;color:var(--dashsecondary-color)}.logs-container{background:white;border-radius:12px;box-shadow:0 4px 20px #0000000d;overflow:hidden}.logs-header{background:var(--light);padding:1.5rem;border-bottom:1px solid #e0e0e0}.logs-header h2{color:var(--dark);font-size:1.3rem;font-weight:600}.logs-table{width:100%;border-collapse:collapse}.logs-table th,.logs-table td{padding:1rem;text-align:left;border-bottom:1px solid #f0f0f0}.logs-table th{background:var(--light);font-weight:600;color:var(--dark);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.logs-table tr:hover{background:#f8f9fa}.activity-badge{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-login{background:var(--success);color:#fff}.badge-logout{background:var(--gray);color:#fff}.badge-create{background:var(--dashprimary-color);color:#fff}.badge-update{background:var(--warning);color:#fff}.badge-delete{background:var(--danger);color:#fff}.badge-danger{color:var(--danger)}.badge-view{background:var(--maitsecondary);color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:1.5rem;background:var(--light)}.pagination button{padding:8px 12px;border:1px solid #e0e0e0;background:white;border-radius:6px;cursor:pointer;transition:all .3s ease}.pagination button:hover,.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.no-logs{text-align:center;padding:3rem;color:var(--gray)}.no-logs h3{font-size:1.5rem;margin-bottom:1rem}.loading{text-align:center;padding:3rem;color:var(--gray)}.spinner{border:3px solid #f3f3f3;border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.controls{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.stats-grid{grid-template-columns:1fr}.logs-table{font-size:.9rem}.logs-table th,.logs-table td{padding:.5rem}}h1,h2{color:#005792}.crew-section{margin-bottom:30px}.crew-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-bottom:30px}.crew-card{background-color:#f8f9fa;border-radius:6px;padding:15px;box-shadow:0 1px 5px #00000014;border-left:4px solid #00a8e8;position:relative}.crew-card.unavailable{border-left-color:#dc3545;opacity:.8}.crew-name{font-weight:700;font-size:1.1em;margin-bottom:5px;color:#005792}.crew-role{color:#6c757d;font-size:.9em;margin-bottom:10px}.crew-certifications,.crew-availability{font-size:.85em;margin:5px 0}.certification-tag{display:inline-block;background-color:#e6f7ff;color:#005792;border-radius:4px;padding:2px 8px;margin-right:5px;margin-bottom:5px;font-size:.85em}.status-badge{position:absolute;top:15px;right:15px;font-size:.75em;padding:3px 8px;border-radius:12px;font-weight:700}.status-available{background-color:#d4edda;color:#155724}.status-unavailable{background-color:#f8d7da;color:#721c24}.status-onduty{background-color:#cce5ff;color:#004085}.action-buttons{display:flex;justify-content:space-between;margin-top:15px}.btn{padding:6px 12px;border-radius:4px;border:none;cursor:pointer;font-size:.9em;transition:background-color .2s}.btn-primary{background-color:#005792;color:#fff}.btn-primary:hover{background-color:#004675}.btn-secondary{background-color:#e9ecef;color:#495057}.btn-secondary:hover{background-color:#dde2e6}.search-filter{display:flex;margin-bottom:20px;gap:10px}.search-filter input,.search-filter select{padding:8px 12px;border:1px solid #ced4da;border-radius:4px}.search-filter input{flex-grow:1}.search-filter select{width:30%}.add-crew-form{background-color:#f8f9fa;padding:20px;border-radius:6px;margin-top:30px}.form-row{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.form-group{flex:1;min-width:200px}.form-group label{display:block;margin-bottom:5px;font-weight:700;color:#495057}.text-danger{color:red;font-weight:bolder}.text-warning{color:orange;font-weight:bolder}.text-success{color:green;font-weight:bolder}.icon{font-size:20px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px;border:1px solid #ced4da;border-radius:4px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.no-results{text-align:center;padding:20px;color:#6c757d}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.vcard{border-radius:6px;padding:5px}#content.active{margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width))}
1
+ .v-left{margin-left:20px}.vessel-card{background:white;border-radius:10px;box-shadow:0 8px 16px #0069c026;transition:all .3s ease;margin-bottom:20px;overflow:hidden;border-left:4px solid var(--accent-color)}.vessel-card:hover{transform:translateY(-5px);box-shadow:0 12px 20px #0069c033}.vessel-icon{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;background-color:#e3f2fd;border-radius:10px;color:var(--accent-color);font-size:24px;margin-right:15px}.black{color:#000!important}.action-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:20px;color:var(--accent-color);font-size:16px;margin-right:15px;margin-top:20px;margin-bottom:10px}.delete{background-color:var(--danger)}.edit{background-color:var(--success)}.vessel-status{display:inline-block;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600}.status-active{background-color:#e8f5e9;color:#2e7d32}.status-maintenance{background-color:#fff8e1;color:#f57f17}.status-inactive{background-color:#f5f5f5;color:#757575}.page-header{margin-bottom:30px;border-bottom:1px solid #e0e0e0;padding-bottom:15px}.progress-container{margin-bottom:20px}.progress-bar{background-color:#e9ecef;border-radius:4px;height:10px;margin-top:8px}.progress-fill{background-color:#00a8e8;height:100%;border-radius:4px;transition:width .3s ease}.checklist{list-style-type:none;padding:0}.checklist-item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #eee;cursor:pointer}.checkbox{margin-right:15px;width:20px;height:20px;border:2px solid #00a8e8;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkbox.checked{background-color:#00a8e8;color:#fff}.task-text{flex-grow:1}.task-text.completed{text-decoration:line-through;color:#6c757d}.status{margin-top:20px;font-weight:700;text-align:center}.reset-button{background-color:#005792;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:20px;font-weight:700}.btn-outline-custom{color:#005792;border:2px solid #005792;background-color:transparent;padding:8px 16px;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .3s,color .3s}.btn-outline-custom:hover{background-color:#005792;color:#fff}.reset-button:hover{background-color:#003d5b}header{background-color:var(--maitprimary);color:#fff;padding:1rem;text-align:center;border-radius:5px 5px 0 0}.content{background-color:#fff;padding:20px;border-radius:0 0 5px 5px;box-shadow:0 2px 10px #0000001a}h2{color:var(--dark);margin-bottom:20px;border-bottom:2px solid var(--light);padding-bottom:10px}.form-section{display:none;animation:fadeIn .5s}.form-section.active{display:block}.form-row{margin-bottom:15px}.form-group{margin-bottom:20px}label{display:block;margin-bottom:5px;font-weight:700;color:var(--dark)}input,select,textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:16px}.input-group{display:flex;gap:10px}.input-group>div{flex:1}textarea{height:120px;resize:vertical}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .3s}.btn-primary{background-color:var(--maitprimary);color:#fff}.btn-primary:hover{background-color:var(--dark)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{background-color:#219653}.action-buttons{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.status-badge{display:inline-block;padding:5px 10px;border-radius:15px;font-size:14px;font-weight:700;color:#fff}.status-pending{background-color:var(--warning)}.status-progress{background-color:var(--accent)}.status-completed{background-color:var(--success)}.attachment-area{border:2px dashed #ddd;padding:20px;text-align:center;border-radius:5px;margin-bottom:20px}.file-input{display:none}.file-label{display:inline-block;padding:10px 20px;background-color:var(--accent);color:#fff;border-radius:4px;cursor:pointer;transition:background-color .3s}.file-label:hover{background-color:var(--maitsecondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-section h3{margin-top:30px;margin-bottom:15px;color:var(--maitsecondary)}.checkbox-group{display:flex;flex-wrap:wrap;gap:15px;margin-top:10px}.checkbox-item{display:flex;align-items:center;gap:5px}.checkbox-item input{width:auto}.status-badge{padding:.3em .6em;border-radius:4px;color:#fff;font-weight:700;font-size:.85rem}.status-action{padding:.3em .6em;border-radius:4px;color:#fff;font-weight:700;font-size:.85rem;background-color:var(--maitprimary)}.status-badge.overdue{background-color:red}.task-table-wrapper{font-family:Inter,sans-serif;padding:1rem}.table-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.filters{display:flex;gap:.5rem;flex-wrap:wrap}.filters button,.filters input{padding:.5rem 1rem;border-radius:6px;border:1px solid #ccc;background-color:#f5f5f5;font-weight:500;cursor:pointer}.filters button.active{background-color:#002f6c;color:#fff}.filters input{border:1px solid #bbb}.filter-badge{background-color:#eee;color:#333}.table-controls>div:last-child button{padding:.5rem 1rem;border:1px solid var(--maitprimary);border-radius:6px;background-color:#fff;color:var(--maitprimary);font-weight:600;cursor:pointer;transition:background .2s}.table-controls>div:last-child button:last-child{background-color:var(--maitprimary);color:#fff}.task-table{width:100%;border-collapse:collapse;box-shadow:0 0 0 1px #ccc}.task-table thead{background-color:var(--maitprimary);color:#fff}.task-table th,.task-table td{padding:.75rem;text-align:left;border-bottom:1px solid #eee;white-space:pre-line}.task-table tbody tr:hover{background-color:#f9f9f9}.status-badge{padding:.3em .6em;border-radius:6px;font-weight:700;font-size:.85rem;color:#fff;display:inline-block;text-align:center;min-width:90px}.status-badge.complete{background-color:#4dffd0}.status-badge.soon{background-color:orange}.status-badge.completed{background-color:#4caf50}.delete-btn{background:none;border:none;color:#dc3545;cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:1;margin-left:8px;flex-shrink:0;transform:scale(1.1)}.checklist-item:hover .delete-btn{opacity:1}.delete-btn:hover{background-color:#dc3545;color:#fff;transform:scale(1.1)}.delete-btn:active{transform:scale(.95)}.print-only-container{text-align:center}.initial-print-btn{background:linear-gradient(135deg,#0066cc,#004499);color:#fff;border:none;padding:20px 40px;font-size:1.3em;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px #0066cc4d;display:flex;align-items:center;gap:15px;margin:0 auto}.initial-print-btn:hover{background:linear-gradient(135deg,#004499,#003366);transform:translateY(-3px);box-shadow:0 8px 25px #06c6}.initial-print-btn:active{transform:translateY(0)}.company-branding{margin-bottom:30px}.company-logo{font-size:3em;font-weight:700;color:#06c;margin-bottom:10px}.company-tagline{font-size:1.1em;color:#666}.report-container{display:none;max-width:900px;margin:0 auto;background:white;padding:30px;border-radius:10px;box-shadow:0 4px 15px #0000001a}.header{text-align:center;border-bottom:3px solid #0066cc;padding-bottom:20px;margin-bottom:30px}.report-logo{font-size:2.5em;font-weight:700;color:#06c;margin-bottom:10px}.report-title{font-size:1.8em;color:#333;margin:10px 0}.report-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.info-box{background:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #0066cc}.info-box ul li{margin-left:15px}.info-label{font-weight:700;color:#06c;margin-bottom:5px}.section{margin-bottom:30px}.section-title{font-size:1.3em;font-weight:700;color:#06c;border-bottom:2px solid #e9ecef;padding-bottom:10px;margin-bottom:15px}.task-item{background:#f8f9fa;margin:15px 0;padding:20px;border-radius:8px;border-left:4px solid #28a745;box-shadow:0 2px 5px #0000001a}.task-item.pending{border-left-color:#ffc107}.task-item.overdue{border-left-color:#dc3545}.task-item.in-progress{border-left-color:#17a2b8}.task-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;flex-wrap:wrap;gap:10px}.task-title{font-size:1.2em;font-weight:700;color:#333}.task-component{font-size:.9em;color:#666;margin-top:5px}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.8em;font-weight:700;text-transform:uppercase}.status-completed{background:#d4edda;color:#155724}.status-pending{background:#fff3cd;color:#856404}.status-overdue{background:#f8d7da;color:#721c24}.status-in-progress{background:#d1ecf1;color:#0c5460}.task-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin:15px 0}.detail-item{display:flex;flex-direction:column}.detail-label{font-weight:700;font-size:.85em;color:#06c;margin-bottom:3px}.detail-value{font-size:.95em;color:#333}.checklist-progress{margin-top:15px}.progress-bar{width:100%;height:20px;background:#e9ecef;border-radius:10px;overflow:hidden;margin:10px 0}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .3s ease}.checklist-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:10px}.checklist-item{display:flex;align-items:center;padding:8px;background:white;border-radius:5px;font-size:.9em}.checklist-icon{margin-right:8px;font-size:1.1em}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin:20px 0}.summary-card{background:white;padding:20px;border-radius:8px;text-align:center;border:2px solid #e9ecef}.summary-number{font-size:2em;font-weight:700;color:#06c}.summary-label{font-size:.9em;color:#666;margin-top:5px}.signature-section{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:40px}.signature-box{padding-top:10px;text-align:center}.maintenance-type{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75em;font-weight:700;text-transform:uppercase;margin-left:10px}.type-corrective{background:#fff3cd;color:#856404}.type-preventive{background:#d4edda;color:#155724}.type-predictive{background:#d1ecf1;color:#0c5460}@media print{body{background:white;padding:0;display:block}.print-only-container{display:none!important}.report-container{display:block!important;box-shadow:none;padding:0;margin:0;max-width:none}}.a-header{background:linear-gradient(135deg,var(--dashprimary-color),var(--dashsecondary-color));color:#fff;padding:2rem 0;margin-bottom:2rem;border-radius:12px;box-shadow:0 10px 30px #3499404d}.a-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}.a-header p{text-align:center;opacity:.9;font-size:1.1rem}.a-controls{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.a-search-box{flex:1;min-width:250px;position:relative}.a-search-box input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease}.a-search-box input:focus{outline:none;border-color:var(--dashsecondary-color);box-shadow:0 0 0 3px #3499401a}.filter-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:white;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:var(--dashsecondary-color);box-shadow:0 0 0 3px #3499401a}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #3499404d}.btn-secondary{background:var(--secondary);color:var(--dark)}.btn-secondary:hover{background:#e6a200;transform:translateY(-1px);box-shadow:0 4px 12px #f4b4004d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 4px 20px #0000000d;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:var(--gray);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.stat-card .value{font-size:2rem;font-weight:700;color:var(--dashsecondary-color)}.logs-container{background:white;border-radius:12px;box-shadow:0 4px 20px #0000000d;overflow:hidden}.logs-header{background:var(--light);padding:1.5rem;border-bottom:1px solid #e0e0e0}.logs-header h2{color:var(--dark);font-size:1.3rem;font-weight:600}.logs-table{width:100%;border-collapse:collapse}.logs-table th,.logs-table td{padding:1rem;text-align:left;border-bottom:1px solid #f0f0f0}.logs-table th{background:var(--light);font-weight:600;color:var(--dark);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.logs-table tr:hover{background:#f8f9fa}.activity-badge{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-login{background:var(--success);color:#fff}.badge-logout{background:var(--gray);color:#fff}.badge-create{background:var(--dashprimary-color);color:#fff}.badge-update{background:var(--warning);color:#fff}.badge-delete{background:var(--danger);color:#fff}.badge-danger{color:var(--danger)}.badge-view{background:var(--maitsecondary);color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:1.5rem;background:var(--light)}.pagination button{padding:8px 12px;border:1px solid #e0e0e0;background:white;border-radius:6px;cursor:pointer;transition:all .3s ease}.pagination button:hover,.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.no-logs{text-align:center;padding:3rem;color:var(--gray)}.no-logs h3{font-size:1.5rem;margin-bottom:1rem}.loading{text-align:center;padding:3rem;color:var(--gray)}.spinner{border:3px solid #f3f3f3;border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.a-controls{flex-direction:column;align-items:stretch}.a-search-box{min-width:100%}.stats-grid{grid-template-columns:1fr}.logs-table{font-size:.9rem}.logs-table th,.logs-table td{padding:.5rem}}.add-crew-form h2{color:#005792}.crew-section{margin-bottom:30px}.crew-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-bottom:30px}.crew-card{background-color:#f8f9fa;border-radius:6px;padding:15px;box-shadow:0 1px 5px #00000014;border-left:4px solid #00a8e8;position:relative}.crew-card.unavailable{border-left-color:#dc3545;opacity:.8}.crew-name{font-weight:700;font-size:1.1em;margin-bottom:5px;color:#005792}.crew-role{color:#6c757d;font-size:.9em;margin-bottom:10px}.crew-certifications,.crew-availability{font-size:.85em;margin:5px 0}.certification-tag{display:inline-block;background-color:#e6f7ff;color:#005792;border-radius:4px;padding:2px 8px;margin-right:5px;margin-bottom:5px;font-size:.85em}.status-badge{position:absolute;top:15px;right:15px;font-size:.75em;padding:3px 8px;border-radius:12px;font-weight:700}.status-available{background-color:#d4edda;color:#155724}.status-unavailable{background-color:#f8d7da;color:#721c24}.status-onduty{background-color:#cce5ff;color:#004085}.action-buttons{display:flex;justify-content:space-between;margin-top:15px}.btn{padding:6px 12px;border-radius:4px;border:none;cursor:pointer;font-size:.9em;transition:background-color .2s}.btn-primary{background-color:#005792;color:#fff}.btn-primary:hover{background-color:#004675}.btn-secondary{background-color:#e9ecef;color:#495057}.btn-secondary:hover{background-color:#dde2e6}.search-filter{display:flex;margin-bottom:20px;gap:10px}.search-filter input,.search-filter select{padding:8px 12px;border:1px solid #ced4da;border-radius:4px}.search-filter input{flex-grow:1}.search-filter select{width:30%}.add-crew-form{background-color:#f8f9fa;padding:20px;border-radius:6px;margin-top:30px}.form-row{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.form-group{flex:1;min-width:200px}.form-group label{display:block;margin-bottom:5px;font-weight:700;color:#495057}.text-danger{color:red;font-weight:bolder}.text-warning{color:orange;font-weight:bolder}.text-success{color:green;font-weight:bolder}.icon{font-size:20px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px;border:1px solid #ced4da;border-radius:4px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.no-results{text-align:center;padding:20px;color:#6c757d}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.vcard{border-radius:6px;padding:5px}#content.active{margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width))}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "oceanhelm",
3
- "version": "0.0.1",
3
+ "version": "0.0.3",
4
4
  "description": "Oceanhelm's highly customizable library",
5
5
  "private": false,
6
6
  "type": "module",
@@ -1,14 +1,8 @@
1
1
  <template>
2
2
  <div class="activity-logs">
3
- <!-- Header -->
4
- <div class="header">
5
- <h1>Activity Logs</h1>
6
- <p>Monitor and track all system activities in real-time</p>
7
- </div>
8
-
9
3
  <!-- Controls -->
10
- <div class="controls">
11
- <div class="search-box">
4
+ <div class="a-controls">
5
+ <div class="a-search-box">
12
6
  <input
13
7
  type="text"
14
8
  placeholder="Search activities, users, or actions..."
@@ -162,7 +156,7 @@
162
156
  </script>
163
157
 
164
158
  <style>
165
- .header {
159
+ .a-header {
166
160
  background: linear-gradient(135deg, var(--dashprimary-color), var(--dashsecondary-color));
167
161
  color: white;
168
162
  padding: 2rem 0;
@@ -171,20 +165,20 @@
171
165
  box-shadow: 0 10px 30px rgba(52, 153, 64, 0.3);
172
166
  }
173
167
 
174
- .header h1 {
168
+ .a-header h1 {
175
169
  font-size: 2.5rem;
176
170
  font-weight: 700;
177
171
  margin-bottom: 0.5rem;
178
172
  text-align: center;
179
173
  }
180
174
 
181
- .header p {
175
+ .a-header p {
182
176
  text-align: center;
183
177
  opacity: 0.9;
184
178
  font-size: 1.1rem;
185
179
  }
186
180
 
187
- .controls {
181
+ .a-controls {
188
182
  display: flex;
189
183
  gap: 1rem;
190
184
  margin-bottom: 2rem;
@@ -192,13 +186,13 @@
192
186
  align-items: center;
193
187
  }
194
188
 
195
- .search-box {
189
+ .a-search-box {
196
190
  flex: 1;
197
191
  min-width: 250px;
198
192
  position: relative;
199
193
  }
200
194
 
201
- .search-box input {
195
+ .a-search-box input {
202
196
  width: 100%;
203
197
  padding: 12px 16px;
204
198
  border: 2px solid #e0e0e0;
@@ -207,7 +201,7 @@
207
201
  transition: all 0.3s ease;
208
202
  }
209
203
 
210
- .search-box input:focus {
204
+ .a-search-box input:focus {
211
205
  outline: none;
212
206
  border-color: var(--dashsecondary-color);
213
207
  box-shadow: 0 0 0 3px rgba(52, 153, 64, 0.1);
@@ -458,12 +452,12 @@
458
452
  }
459
453
 
460
454
  @media (max-width: 768px) {
461
- .controls {
455
+ .a-controls {
462
456
  flex-direction: column;
463
457
  align-items: stretch;
464
458
  }
465
459
 
466
- .search-box {
460
+ .a-search-box {
467
461
  min-width: 100%;
468
462
  }
469
463
 
@@ -226,14 +226,3 @@
226
226
  }
227
227
  </script>
228
228
 
229
- <style scoped>
230
- .left {
231
- margin-left: 20px;
232
- }
233
-
234
- .black {
235
- color: black !important;
236
- }
237
-
238
- /* Add any other necessary styles */
239
- </style>
@@ -521,8 +521,7 @@ export default {
521
521
  </script>
522
522
 
523
523
  <style>
524
- h1,
525
- h2 {
524
+ .add-crew-form h2 {
526
525
  color: #005792;
527
526
  }
528
527
 
@@ -10,7 +10,7 @@
10
10
 
11
11
  <div class="inventory-container">
12
12
  <!-- Header -->
13
- <div class="header">
13
+ <div class="i-header">
14
14
  <div>
15
15
  <h1><i class="fas fa-ship"></i>{{ title || 'OceanHelm Inventory Management' }}</h1>
16
16
  <div class="header-stats">
@@ -769,7 +769,7 @@
769
769
  padding: 20px;
770
770
  }
771
771
 
772
- .header {
772
+ .i-header {
773
773
  background: linear-gradient(135deg, var(--dashprimary-color), #0f172a);
774
774
  color: white;
775
775
  padding: 20px;
@@ -780,7 +780,7 @@
780
780
  align-items: center;
781
781
  }
782
782
 
783
- .header h1 {
783
+ .i-header h1 {
784
784
  font-size: 28px;
785
785
  font-weight: 600;
786
786
  display: flex;
@@ -1141,11 +1141,6 @@
1141
1141
  opacity: 0.6;
1142
1142
  }
1143
1143
 
1144
- /* Vessel Cards */
1145
- .left {
1146
- margin-left: 20px;
1147
- }
1148
-
1149
1144
  .vessel-card {
1150
1145
  background: white;
1151
1146
  border-radius: 10px;
@@ -1175,7 +1170,7 @@
1175
1170
  }
1176
1171
 
1177
1172
  /* Header Actions */
1178
- .header {
1173
+ .i-header {
1179
1174
  display: flex;
1180
1175
  justify-content: space-between;
1181
1176
  align-items: flex-start;
@@ -1330,7 +1325,7 @@
1330
1325
  padding: 15px;
1331
1326
  }
1332
1327
 
1333
- .header {
1328
+ .i-header {
1334
1329
  flex-direction: column;
1335
1330
  align-items: stretch;
1336
1331
  }
@@ -1070,29 +1070,8 @@ header {
1070
1070
  border-radius: 5px 5px 0 0;
1071
1071
  }
1072
1072
 
1073
- nav {
1074
- background-color: var(--maitsecondary);
1075
- padding: 10px;
1076
- display: flex;
1077
- justify-content: center;
1078
- }
1079
-
1080
- nav button {
1081
- background-color: var(--maitsecondary);
1082
- color: white;
1083
- border: none;
1084
- padding: 10px 20px;
1085
- margin: 0 5px;
1086
- cursor: pointer;
1087
- font-weight: bold;
1088
- border-radius: 3px;
1089
- transition: background-color 0.3s;
1090
- }
1091
-
1092
- nav button:hover,
1093
- nav button.active {
1094
- background-color: var(--maitprimary);
1095
- }
1073
+ /*
1074
+ */
1096
1075
 
1097
1076
  .content {
1098
1077
  background-color: white;
@@ -65,7 +65,7 @@
65
65
  <div class="col-lg-6" v-for="vessel in vessels" :key="vessel.registrationNumber || vessel.id">
66
66
  <div class="vessel-card" @click="handleVesselClick(vessel)">
67
67
  <div class="card-body d-flex align-items-center">
68
- <div class="vessel-icon left">
68
+ <div class="vessel-icon v-left">
69
69
  <i class="fas fa-ship"></i>
70
70
  </div>
71
71
  <div class="flex-grow-1">
@@ -85,7 +85,7 @@
85
85
  </div>
86
86
  </div>
87
87
  </div>
88
- <div class="action-icon left delete">
88
+ <div class="action-icon v-left delete">
89
89
  <i class="bi bi-trash" @click.stop="handleDeleteVessel(vessel)"></i>
90
90
  </div>
91
91
  <button class="btn btn-primary" @click.stop="handleToggleStatus(vessel)">
@@ -265,7 +265,7 @@ export default {
265
265
  </script>
266
266
 
267
267
  <style>
268
- .left {
268
+ .v-left {
269
269
  margin-left: 20px;
270
270
  }
271
271
 
package/src/index.js CHANGED
@@ -21,11 +21,11 @@ export * from './types'
21
21
  export default {
22
22
  install(app, options = {}) {
23
23
  app.component('ConfigurableSidebar', ConfigurableSidebar)
24
- app.component('VesselList', VesselList)
24
+ app.component('VesselLists', VesselList)
25
25
  app.component('DashHead', DashHead)
26
26
  app.component('ActivityLogs', ActivityLogs)
27
27
  app.component('CrewManagement', CrewManagement)
28
- app.component('DashHead', OceanHelmMaintenance)
28
+ app.component('OceanHelmMaintenance', OceanHelmMaintenance)
29
29
 
30
30
  // Provide global configuration
31
31
  app.provide('sidebarConfig', options)