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/oceanhelm.es.js +6 -10
- package/dist/oceanhelm.es.js.map +1 -1
- package/dist/oceanhelm.umd.js +1 -1
- package/dist/oceanhelm.umd.js.map +1 -1
- package/dist/style.css +1 -1
- package/package.json +1 -1
- package/src/components/ActivityLogs.vue +11 -17
- package/src/components/ConfigurableSidebar.vue +0 -11
- package/src/components/CrewManagement.vue +1 -2
- package/src/components/InventoryManagement.vue +5 -10
- package/src/components/OceanHelmMaintenance.vue +2 -23
- package/src/components/VesselList.vue +3 -3
- package/src/index.js +2 -2
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,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
|
|
|
@@ -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
|
-
|
|
1074
|
-
|
|
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('
|
|
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('
|
|
28
|
+
app.component('OceanHelmMaintenance', OceanHelmMaintenance)
|
|
29
29
|
|
|
30
30
|
// Provide global configuration
|
|
31
31
|
app.provide('sidebarConfig', options)
|