collabdocchat 2.4.8 → 2.5.0
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/README.md +103 -23
- package/dist/assets/index-BXsUUS0E.js +2163 -0
- package/dist/assets/index-D8ZqeoaM.css +8 -0
- package/dist/index.html +16 -0
- package/package.json +4 -3
- package/scripts/start-app.js +36 -5
- package/server/index.js +41 -0
- package/server/public/index.html +246 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-dark: #0f172a;--bg-card: #1e293b;--bg-hover: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border: #334155;--shadow: rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);color:var(--text-primary);min-height:100vh}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:var(--bg-card);border-radius:20px;padding:40px;width:100%;max-width:450px;box-shadow:0 20px 60px var(--shadow);animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.logo{font-size:32px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:10px}.tagline{color:var(--text-secondary);font-size:14px}.auth-switch{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.switch-text{color:var(--text-secondary);font-size:14px;margin:0}.link-btn{background:none;border:none;color:var(--primary);text-decoration:none;cursor:pointer;font-size:14px;font-weight:600;padding:0;margin-left:5px;transition:all .3s}.link-btn:hover{color:var(--primary-dark);text-decoration:underline}.register-note{text-align:center;padding:15px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:8px;margin-bottom:10px}.register-note p{color:var(--text-secondary);font-size:13px;margin:0}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form.hidden,.hidden{display:none}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{padding:12px 16px;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.btn-primary{padding:14px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #6366f166}.error-message{color:var(--danger);font-size:14px;min-height:20px}.dashboard{display:flex;height:100vh;width:100%;background:var(--bg-dark)}.sidebar{width:280px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px;height:100vh;overflow-y:auto;overflow-x:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.sidebar-header h2{font-size:20px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.badge-admin{background:var(--primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-user{background:var(--success);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.user-info{display:flex;align-items:center;gap:12px;padding:15px;background:var(--bg-dark);border-radius:12px;margin-bottom:30px}.avatar{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}.username{font-weight:600;font-size:15px}.user-role{font-size:13px;color:var(--text-secondary)}.nav-menu{flex:1;display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .3s;font-size:15px;text-align:left}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--primary);color:#fff}.nav-item .icon{font-size:20px}.btn-logout{padding:12px;background:var(--danger);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.btn-logout:hover{background:#dc2626}.main-content{flex:1;overflow-y:auto;padding:30px;width:100%;max-width:100%;height:100vh;max-height:100vh}.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.view-header h2{font-size:28px;font-weight:700}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.group-card{background:var(--bg-card);border-radius:15px;padding:25px;transition:all .3s;border:2px solid transparent}.group-card:hover{border-color:var(--primary);transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow)}.group-card h3{font-size:20px;margin-bottom:10px}.group-card p{color:var(--text-secondary);font-size:14px;margin-bottom:15px}.group-stats{display:flex;gap:15px;margin-bottom:15px;font-size:13px;color:var(--text-secondary)}.btn-select{width:100%;padding:10px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.btn-select:hover{background:var(--primary-dark)}.tasks-list{display:flex;flex-direction:column;gap:15px}.task-card{background:var(--bg-card);border-radius:15px;padding:20px;border-left:4px solid var(--primary)}.task-card.status-completed{border-left-color:var(--success);opacity:.7}.task-card.status-terminated{border-left-color:var(--danger);opacity:.7}.task-card h3{font-size:18px;margin-bottom:10px}.task-card p{color:var(--text-secondary);font-size:14px;margin-bottom:15px}.task-meta{display:flex;gap:15px;flex-wrap:wrap;font-size:13px;color:var(--text-secondary)}.status-badge{padding:4px 12px;border-radius:20px;background:var(--primary);color:#fff;font-weight:600}.task-actions{margin-top:15px;display:flex;gap:10px}.btn-sm{padding:8px 16px;font-size:13px;border-radius:8px;border:none;cursor:pointer;font-weight:600;transition:all .3s}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff;border:none;cursor:pointer;transition:all .3s}.btn-danger:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 5px 15px #ef444466}.btn-danger:active{transform:translateY(0);box-shadow:0 2px 8px #ef44444d}.documents-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.document-card{background:var(--bg-card);border-radius:15px;padding:20px;transition:all .3s}.document-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px var(--shadow)}.document-card h3{font-size:18px;margin-bottom:15px}.doc-meta{display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--text-secondary);margin-bottom:15px}.btn-edit{width:100%;padding:10px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.editor-container{background:var(--bg-card);border-radius:15px;padding:20px;height:calc(100vh - 200px);display:flex;flex-direction:column}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid var(--border)}.online-users{display:flex;gap:10px;flex-wrap:wrap}.user-badge{padding:6px 12px;background:var(--bg-dark);border-radius:20px;font-size:13px}.user-badge.typing{background:var(--primary);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}#editor{flex:1;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;padding:20px;color:var(--text-primary);font-family:Consolas,monospace;font-size:15px;line-height:1.6;resize:none}#editor:focus{outline:none;border-color:var(--primary)}.editor-footer{margin-top:15px;padding-top:15px;border-top:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.chat-container{background:var(--bg-card);border-radius:15px;height:calc(100vh - 200px);display:flex;flex-direction:column}.messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px}.message{display:flex;flex-direction:column;gap:5px;max-width:70%}.message.own{align-self:flex-end}.message-header{display:flex;gap:10px;font-size:12px;color:var(--text-secondary)}.message-content{background:var(--bg-dark);padding:12px 16px;border-radius:12px;word-wrap:break-word}.message.own .message-content{background:var(--primary)}.notification{align-self:center;background:var(--bg-hover);padding:8px 16px;border-radius:20px;font-size:13px;color:var(--text-secondary)}.chat-input{display:flex;gap:10px;padding:20px;border-top:1px solid var(--border)}.chat-input input{flex:1;padding:12px 16px;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px}.chat-input input:focus{outline:none;border-color:var(--primary)}.call-panel{background:var(--bg-card);border-radius:15px;padding:30px}.call-controls{display:flex;align-items:center;gap:15px;margin-bottom:30px}.call-controls label{font-weight:600}.call-controls input{width:80px;padding:10px;background:var(--bg-dark);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:16px}.btn-large{padding:14px 30px;font-size:18px}.call-result{min-height:200px}.called-members{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px;margin-top:20px}.member-card{background:var(--bg-dark);border-radius:12px;padding:20px;text-align:center;animation:bounceIn .5s ease}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.member-card .avatar{margin:0 auto 10px}.member-name{font-weight:600}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal.hidden{display:none}.modal-content{background:var(--bg-card);border-radius:15px;padding:30px;width:90%;max-width:500px}.modal-content h3{margin-bottom:20px;font-size:24px}.modal-content form{display:flex;flex-direction:column;gap:15px}.btn-secondary{padding:12px;background:var(--bg-hover);border:none;border-radius:8px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s}.btn-back{padding:10px 20px;background:var(--bg-hover);border:none;border-radius:8px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s}.btn-back:hover{background:var(--border)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}.doc-status{padding:8px 16px;background:var(--bg-card);border-radius:20px;font-size:14px}.doc-link{color:var(--primary);text-decoration:none;font-size:14px;margin-top:10px;display:inline-block}.doc-link:hover{text-decoration:underline}.audit-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-card);border-radius:12px;padding:20px;text-align:center;box-shadow:0 4px 20px var(--shadow)}.stat-card h3{font-size:14px;color:var(--text-secondary);margin-bottom:10px;font-weight:500}.stat-number{font-size:32px;font-weight:700;color:var(--primary)}.audit-table{background:var(--bg-card);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px var(--shadow)}.audit-header{display:grid;grid-template-columns:150px 120px 120px 1fr 2fr;gap:20px;padding:15px 20px;background:var(--bg-hover);font-weight:600;font-size:14px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.audit-row{display:grid;grid-template-columns:150px 120px 120px 1fr 2fr;gap:20px;padding:15px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .3s}.audit-row:hover{background:var(--bg-hover)}.audit-row:last-child{border-bottom:none}.audit-time{font-size:12px;color:var(--text-secondary)}.audit-user{display:flex;align-items:center;gap:8px}.audit-user .avatar{width:24px;height:24px;font-size:10px}.audit-user span{font-size:13px}.audit-action .action-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.action-badge.action-document_create{background:#10b98133;color:var(--success)}.action-badge.action-document_update{background:#3b82f633;color:#3b82f6}.action-badge.action-document_delete{background:#ef444433;color:var(--danger)}.action-badge.action-content_edit{background:#f59e0b33;color:var(--warning)}.action-badge.action-title_edit{background:#8b5cf633;color:var(--secondary)}.action-badge.action-document_permission_change{background:#6b728033;color:#6b7280}.audit-resource{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-description{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pagination{display:flex;align-items:center;justify-content:center;gap:15px;margin-top:20px}.pagination button{padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .3s}.pagination button:hover:not(:disabled){background:var(--bg-hover)}.pagination button:disabled{opacity:.5;cursor:not-allowed}#pageInfo{color:var(--text-secondary);font-size:14px}.form-select,.form-input{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px}.form-select option{background:var(--bg-card);color:var(--text-primary)}.error-state{text-align:center;padding:40px;color:var(--danger);background:#ef44441a;border-radius:8px;margin:20px 0}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border)}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.audit-detail{padding:20px;background:var(--bg-dark);border-radius:8px}.audit-detail p{margin-bottom:10px;line-height:1.6}@media (max-width: 768px){.audit-header,.audit-row{grid-template-columns:1fr;gap:10px}.audit-header>div,.audit-row>div{display:flex;justify-content:space-between;align-items:center}.audit-header>div:before,.audit-row>div:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:12px}.view-header{flex-direction:column;gap:15px}.view-header>div{flex-wrap:wrap;gap:10px}}.files-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;padding:20px}.file-card{background:var(--bg-card);border-radius:12px;padding:20px;display:flex;gap:15px;align-items:flex-start;transition:transform .2s,box-shadow .2s}.file-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.file-icon{font-size:40px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-info h4{margin:0 0 8px;color:var(--text-primary);font-size:16px;word-break:break-word}.file-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary);margin-bottom:8px}.file-description{color:var(--text-secondary);font-size:13px;margin:8px 0 0;line-height:1.4}.file-actions{display:flex;gap:8px;flex-shrink:0}.file-actions a{text-decoration:none}.btn-emoji{background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;padding:12px 16px;font-size:20px;cursor:pointer;transition:all .2s}.btn-emoji:hover{background:var(--bg-hover);border-color:var(--primary)}.btn-emoji:disabled{opacity:.5;cursor:not-allowed}emoji-picker{position:absolute;bottom:70px;left:20px;z-index:1000;border-radius:12px;box-shadow:0 4px 20px #0003}emoji-picker.hidden{display:none}.search-container{padding:20px}.search-box{display:flex;gap:10px;margin-bottom:20px}.search-box input{flex:1;padding:12px 16px;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px}.search-box input:focus{outline:none;border-color:var(--primary)}.search-filters{display:flex;gap:20px;margin-bottom:20px;padding:15px;background:var(--bg-card);border-radius:10px}.search-filters label{display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--text-primary);font-size:14px}.search-filters input[type=checkbox]{width:18px;height:18px;cursor:pointer}.search-results{display:flex;flex-direction:column;gap:15px}.search-result-item{background:var(--bg-card);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s}.search-result-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.result-type{font-size:12px;color:var(--text-secondary);background:var(--bg-dark);padding:4px 8px;border-radius:6px}.result-time{font-size:12px;color:var(--text-secondary)}.search-result-item h4{margin:0 0 8px;color:var(--text-primary);font-size:16px}.search-result-item p{margin:0 0 10px;color:var(--text-secondary);font-size:14px;line-height:1.5}.search-result-item mark{background:var(--primary);color:#fff;padding:2px 4px;border-radius:3px}.result-group,.result-status{display:inline-block;font-size:12px;color:var(--text-secondary);background:var(--bg-dark);padding:4px 8px;border-radius:6px;margin-right:8px}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.ql-container{font-size:15px;color:var(--text-primary);background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;min-height:400px}.ql-toolbar{background:var(--bg-card);border:2px solid var(--border);border-bottom:none;border-radius:10px 10px 0 0}.ql-toolbar .ql-stroke{stroke:var(--text-primary)}.ql-toolbar .ql-fill{fill:var(--text-primary)}.ql-toolbar button:hover,.ql-toolbar button.ql-active{color:var(--primary)}.ql-toolbar button:hover .ql-stroke,.ql-toolbar button.ql-active .ql-stroke{stroke:var(--primary)}.ql-toolbar button:hover .ql-fill,.ql-toolbar button.ql-active .ql-fill{fill:var(--primary)}#editor.readonly .ql-toolbar{display:none}#editor.readonly .ql-container{border-top:2px solid var(--border);border-radius:10px}.chat-input{position:relative}.chat-input .btn-emoji{flex-shrink:0}@media (max-width: 768px){.files-list{grid-template-columns:1fr}emoji-picker{left:10px;right:10px;width:auto}.search-filters{flex-direction:column;gap:10px}}/*!
|
|
2
|
+
* Quill Editor v1.3.7
|
|
3
|
+
* https://quilljs.com/
|
|
4
|
+
* Copyright (c) 2014, Jason Chen
|
|
5
|
+
* Copyright (c) 2013, salesforce.com
|
|
6
|
+
*/.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor ul,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"�?}.ql-editor ul[data-checked=true],.ql-editor ul[data-checked=false]{pointer-events:none}.ql-editor ul[data-checked=true]>li *,.ql-editor ul[data-checked=false]>li *{pointer-events:all}.ql-editor ul[data-checked=true]>li:before,.ql-editor ul[data-checked=false]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"�?}.ql-editor ul[data-checked=false]>li:before{content:"�?}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;counter-increment:list-0}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer: coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{white-space:pre-wrap;margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0px}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0px;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}
|
|
7
|
+
.knowledge-filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}}:is() .knowledge-filters input,:is() .knowledge-filters select{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);min-width:180px}:is() .knowledge-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}:is() .knowledge-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}:is() .kb-header{display:flex;justify-content:space-between;align-items:center;gap:8px}:is() .kb-header h3{font-size:17px;margin:0;flex:1;color:var(--text-primary)}:is() .kb-status{padding:6px 10px;border-radius:10px;font-size:12px;text-transform:uppercase;background:var(--bg-hover);color:var(--text-secondary)}:is() .kb-status.published{background:#10b98133;color:var(--success)}:is() .kb-status.draft{background:#f59e0b33;color:var(--warning)}:is() .kb-status.archived{background:#64748b33;color:#cbd5e1}:is() .kb-meta,:is() .kb-tags,:is() .kb-actions{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text-secondary)}:is() .kb-tags .tag{background:var(--bg-hover);padding:4px 8px;border-radius:8px;color:var(--text-primary);font-size:12px}:is() .kb-actions{margin-top:4px}:is() .export-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}:is() .export-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 6px 18px var(--shadow)}:is() .export-section h3{margin:0;font-size:16px;color:var(--text-primary)}:is() .export-section p{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.5}:is() .export-actions{display:flex;flex-wrap:wrap;gap:10px}:is() .settings-view{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.02) 100%);border:1px solid var(--border);border-radius:20px;padding:28px;animation:fadeInUp .6s ease}:is() .settings-tabs{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--border)}:is() .settings-tabs .tab-btn{padding:12px 24px;border:2px solid var(--border);border-radius:12px;background:var(--bg-dark);color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-weight:600;font-size:14px;position:relative;overflow:hidden}:is() .settings-tabs .tab-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}:is() .settings-tabs .tab-btn:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #6366f133}:is() .settings-tabs .tab-btn:hover:before{left:100%}:is() .settings-tabs .tab-btn.active{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-color:var(--primary);color:#fff;box-shadow:0 6px 20px #6366f166;transform:translateY(-2px)}:is() .settings-content{background:var(--bg-dark);border:1px solid var(--border);border-radius:16px;padding:24px;min-height:400px}:is() .tab-content{display:none;animation:fadeIn .4s ease}:is() .tab-content.active{display:block}:is() .setting-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border-bottom:1px solid var(--border);transition:all .3s ease;border-radius:8px}:is() .setting-item:hover{background:#6366f10d;transform:translate(5px)}:is() .setting-item:last-child{border-bottom:none}:is() .setting-item label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;font-size:15px}:is() .setting-item input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}:is() .setting-description{margin:8px 0 0 32px;color:var(--text-secondary);font-size:13px;line-height:1.6}:is() .ai-settings,:is() .notification-settings{display:flex;flex-direction:column;gap:16px}:is() .ai-settings h3,:is() .notification-settings h3{margin:0 0 20px;font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .help-center{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.02) 100%);border:1px solid var(--border);border-radius:20px;padding:28px;animation:fadeInUp .6s ease}:is() .help-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}:is() .help-section{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.03) 100%);border:1px solid var(--border);border-radius:16px;padding:24px;transition:all .3s ease;position:relative;overflow:hidden}:is() .help-section:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);transition:all .5s ease}:is() .help-section:hover{transform:translateY(-8px);box-shadow:0 12px 32px #6366f133;border-color:var(--primary)}:is() .help-section:hover:before{top:0;right:0}:is() .help-section h3{margin:0 0 16px;font-size:18px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px;position:relative;z-index:1}:is() .help-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--text-secondary);position:relative;z-index:1}:is() .help-section ul li{padding:8px 12px;border-radius:8px;transition:all .3s ease;cursor:pointer}:is() .help-section ul li:hover{background:#6366f11a;color:var(--text-primary);transform:translate(5px)}:is() .help-section a{color:var(--primary);text-decoration:none;font-weight:600;transition:all .3s ease}:is() .help-section a:hover{color:var(--secondary);text-decoration:underline}:is() .help-footer{margin-top:30px;padding:24px;background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.05) 100%);border-radius:16px;border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}:is() .help-footer p{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}:is() .help-footer button{padding:12px 28px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:15px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6366f14d}:is() .help-footer button:hover{transform:translateY(-3px);box-shadow:0 8px 24px #6366f180}:is() .task-detail-view{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.03) 100%);border:1px solid var(--border);border-radius:20px;padding:28px;box-shadow:0 16px 48px var(--shadow);color:var(--text-primary);animation:modalSlideIn .4s ease}:is() .task-detail-header{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--border)}:is() .task-detail-header h2{margin:0;font-size:26px;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .task-detail-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:24px;padding:20px;background:var(--bg-dark);border-radius:12px;border:1px solid var(--border)}:is() .task-detail-info .info-row{display:flex;gap:10px;font-size:14px;align-items:center}:is() .task-detail-info .info-label{color:var(--text-secondary);font-weight:600;min-width:80px}:is() .task-detail-info .info-value{color:var(--text-primary);font-weight:500}:is() .task-completion-stats{margin-bottom:24px}:is() .task-completion-stats h3{margin:0 0 16px;font-size:18px;font-weight:700;color:var(--text-primary)}:is() .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}:is() .stat-card{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;transition:all .3s ease;position:relative;overflow:hidden}:is() .stat-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);transition:all .5s ease}:is() .stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #6366f133;border-color:var(--primary)}:is() .stat-card:hover:before{top:0;right:0}:is() .stat-label{color:var(--text-secondary);font-size:13px;margin-bottom:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}:is() .stat-value{font-size:28px;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .progress-bar-container{margin-top:16px}:is() .progress-bar{width:100%;height:12px;background:var(--bg-hover);border-radius:10px;overflow:hidden;box-shadow:inset 0 2px 4px #0003}:is() .progress-fill{height:100%;background:linear-gradient(90deg,var(--primary) 0%,var(--secondary) 100%);border-radius:10px;transition:width .6s ease;box-shadow:0 0 10px #6366f180}:is() .poll-results-section{margin-bottom:24px}:is() .poll-results-section h3{margin:0 0 16px;font-size:18px;font-weight:700}:is() .poll-options-results{display:flex;flex-direction:column;gap:14px}:is() .poll-option-result{background:var(--bg-dark);border:1px solid var(--border);border-radius:12px;padding:16px;transition:all .3s ease}:is() .poll-option-result:hover{border-color:var(--primary);transform:translate(5px)}:is() .poll-option-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;font-size:15px}:is() .poll-option-text{color:var(--text-primary);font-weight:600}:is() .poll-option-count{color:var(--text-secondary);font-weight:700}:is() .task-members-list h3{margin:0 0 16px;font-size:18px;font-weight:700}:is() .members-table{border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 4px 12px var(--shadow)}:is() .members-table-header,:is() .members-table-row{display:grid;grid-template-columns:1fr 140px 180px;gap:16px;align-items:center;padding:14px 18px}:is() .members-table-header{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%);color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px}:is() .members-table-row{border-top:1px solid var(--border);background:var(--bg-card);transition:all .3s ease}:is() .members-table-row:hover{background:#6366f10d;transform:translate(5px)}:is() .member-info{display:flex;align-items:center;gap:12px}:is() .member-status{font-size:13px;font-weight:600}:is() .member-time{color:var(--text-secondary);font-size:13px}:is() .members-table-row.completed{background:linear-gradient(90deg,rgba(16,185,129,.1) 0%,transparent 100%);border-left:3px solid var(--success)}:is() .members-table-row.pending{background:linear-gradient(90deg,rgba(239,68,68,.08) 0%,transparent 100%);border-left:3px solid var(--danger)}:is() .backup-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px;animation:fadeInUp .6s ease}:is() .backup-stats .stat-card{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 8px 24px var(--shadow);transition:all .3s ease;position:relative;overflow:hidden}:is() .backup-stats .stat-card:before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);border-radius:50%;transform:translate(30%,-30%)}:is() .backup-stats .stat-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px #6366f133;border-color:var(--primary)}:is() .backup-stats .stat-card h3{margin:0 0 12px;font-size:13px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}:is() .backup-stats .stat-number{font-size:32px;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .backup-list{background:transparent;animation:fadeIn .8s ease}:is() .backups-table{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 8px 24px var(--shadow)}:is() .backup-header,:is() .backup-row{display:grid;grid-template-columns:200px 100px 120px 150px 1fr;gap:16px;align-items:center;padding:16px 20px}:is() .backup-header{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%);color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid var(--border)}:is() .backup-row{border-top:1px solid var(--border);font-size:14px;color:var(--text-primary);transition:all .3s ease}:is() .backup-row:hover{background:#6366f10d;transform:translate(5px)}:is() .backup-row:nth-child(2n){background:#ffffff05}:is() .backup-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}:is() .backup-type-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border);transition:all .3s ease}:is() .backup-type-badge:hover{transform:scale(1.05)}:is() .backup-type-badge.manual{background:linear-gradient(135deg,#6366f133,#6366f11a);border-color:#6366f180;color:#818cf8}:is() .backup-type-badge.scheduled{background:linear-gradient(135deg,#10b98133,#10b9811a);border-color:#10b98180;color:#34d399}:is() .backup-type-badge.auto{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);border-color:#f59e0b80;color:#fbbf24}@media (max-width: 900px){{@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes spin{to{transform:rotate(360deg)}}}:is() .backup-header{display:none}:is() .backup-row{grid-template-columns:1fr;gap:8px}:is() .backup-row>div{display:flex;justify-content:space-between;gap:10px}:is() .backup-row>div:nth-child(1):before{content:"备份时间";color:var(--text-secondary)}:is() .backup-row>div:nth-child(2):before{content:"类型";color:var(--text-secondary)}:is() .backup-row>div:nth-child(3):before{content:"大小";color:var(--text-secondary)}:is() .backup-row>div:nth-child(4):before{content:"状�?;color:var(--text-secondary)}
|
|
8
|
+
.backup-row>div:nth-child(5){justify-content:flex-end}}:is() .btn-primary,:is() .btn-secondary,:is() .btn-success,:is() .btn-danger,:is() .btn-warning{position:relative;overflow:hidden;transition:all .3s ease}:is() .btn-primary:before,:is() .btn-secondary:before,:is() .btn-success:before,:is() .btn-danger:before,:is() .btn-warning:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}:is() .btn-primary:hover:before,:is() .btn-secondary:hover:before,:is() .btn-success:hover:before,:is() .btn-danger:hover:before,:is() .btn-warning:hover:before{width:300px;height:300px}:is() .btn-success{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}:is() .btn-success:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}:is() .btn-warning{background:linear-gradient(135deg,var(--warning) 0%,#d97706 100%);color:#fff}:is() .btn-warning:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}:is() .modal{animation:fadeIn .3s ease}:is() .modal-content{animation:scaleIn .4s ease;border-radius:20px;box-shadow:0 20px 60px #00000080}:is() .modal-header{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%);border-radius:20px 20px 0 0;padding:20px 24px}:is() .modal-header h3{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .close-btn,:is() .modal-close{transition:all .3s ease}:is() .close-btn:hover,:is() .modal-close:hover{transform:rotate(90deg);color:var(--danger)}:is() .status-badge{padding:6px 14px;border-radius:20px;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease;display:inline-flex;align-items:center;gap:6px}:is() .status-badge:hover{transform:scale(1.05)}:is() .status-badge.status-completed{background:linear-gradient(135deg,#10b98133,#10b9811a);color:var(--success);border:1px solid rgba(16,185,129,.3)}:is() .status-badge.status-pending{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--warning);border:1px solid rgba(245,158,11,.3)}:is() .status-badge.status-in_progress{background:linear-gradient(135deg,#3b82f633,#3b82f61a);color:#3b82f6;border:1px solid rgba(59,130,246,.3)}:is() .status-badge.status-terminated,:is() .status-badge.status-failed{background:linear-gradient(135deg,#ef444433,#ef44441a);color:var(--danger);border:1px solid rgba(239,68,68,.3)}:is() .empty-state{text-align:center;padding:80px 20px;color:var(--text-secondary);font-size:16px;background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.03) 100%);border-radius:16px;border:2px dashed var(--border);animation:fadeIn .6s ease}:is() .empty-state:before{content:"📭";display:block;font-size:64px;margin-bottom:20px;animation:bounce 2s infinite}:is() .view-header{animation:fadeInDown .6s ease}:is() .view-header h2{position:relative;display:inline-block}:is() .view-header h2:after{content:"";position:absolute;bottom:-5px;left:0;width:60px;height:4px;background:linear-gradient(90deg,var(--primary) 0%,var(--secondary) 100%);border-radius:2px}:is() .group-card,:is() .task-card,:is() .document-card,:is() .knowledge-card,:is() .workflow-card,:is() .file-card{animation:fadeInUp .5s ease;animation-fill-mode:both}:is() .group-card:nth-child(1){animation-delay:.1s}:is() .group-card:nth-child(2){animation-delay:.2s}:is() .group-card:nth-child(3){animation-delay:.3s}:is() .group-card:nth-child(4){animation-delay:.4s}:is() .group-card:nth-child(5){animation-delay:.5s}:is() .group-card:nth-child(6){animation-delay:.6s}:is() .form-group input:focus,:is() .form-group select:focus,:is() .form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}:is() .loading{position:relative;color:var(--text-secondary)}:is() .loading:after{content:"";display:inline-block;width:20px;height:20px;margin-left:10px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}:is() .help-sections{grid-template-columns:1fr}:is() .stats-grid{grid-template-columns:repeat(2,1fr)}:is() .task-detail-info,:is() .members-table-header,:is() .members-table-row{grid-template-columns:1fr}:is() .backup-stats{grid-template-columns:repeat(2,1fr)}@media (max-width: 600px){:is() .stats-grid,:is() .backup-stats{grid-template-columns:1fr}:is() .view-header{flex-direction:column;align-items:flex-start}:is() .view-header>div{width:100%}}:is() ::-webkit-scrollbar{width:10px;height:10px}:is() ::-webkit-scrollbar-track{background:var(--bg-dark);border-radius:5px}:is() ::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-radius:5px;transition:all .3s ease}:is() ::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%)}:is() [title]{position:relative;cursor:help}:is() button:focus-visible,:is() input:focus-visible,:is() select:focus-visible,:is() textarea:focus-visible{outline:2px solid var(--primary);outline-offset:2px}:is() *{transition-timing-function:cubic-bezier(.4,0,.2,1)}@media print{:is() .sidebar,:is() .nav-menu,:is() .btn-logout,:is() .modal,:is() button{display:none!important}:is() .main-content{margin:0;padding:0}:is() .view-header h2:after{display:none}}:is() img,:is() video,:is() canvas{max-width:100%;height:auto}:is() *{word-wrap:break-word;overflow-wrap:break-word}@media (max-width: 1024px){:is() .sidebar{width:240px}:is() .main-content{padding:20px}:is() .view-header{flex-direction:column;align-items:flex-start;gap:12px}:is() .view-header h2{font-size:24px}:is() .groups-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}:is() .documents-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}:is() .knowledge-list{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}:is() .backup-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}:is() .settings-cards-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}:is() .collab-tools-tabs-modern{gap:8px}:is() .collab-tab-btn{min-width:100px;padding:12px 16px;font-size:13px}:is() .modal-content{width:85%;max-width:700px;padding:24px}:is() .task-detail-info{grid-template-columns:1fr;gap:12px}:is() .stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}}@media (max-width: 768px){:is() .dashboard{flex-direction:column;height:auto;min-height:100vh}:is() .sidebar{width:100%;height:auto;max-height:none;border-right:none;border-bottom:2px solid var(--border);padding:12px;overflow-y:visible;position:sticky;top:0;z-index:100;background:var(--bg-card)}:is() .sidebar-header{margin-bottom:12px}:is() .sidebar-header h2{font-size:18px}:is() .user-info{padding:10px;margin-bottom:12px}:is() .avatar{width:36px;height:36px;font-size:16px}:is() .username{font-size:14px}:is() .user-role{font-size:12px}:is() .nav-menu{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;gap:8px;padding-bottom:8px;-webkit-overflow-scrolling:touch}:is() .nav-menu::-webkit-scrollbar{height:4px}:is() .nav-menu::-webkit-scrollbar-track{background:var(--bg-dark);border-radius:2px}:is() .nav-menu::-webkit-scrollbar-thumb{background:var(--primary);border-radius:2px}:is() .nav-item{flex-shrink:0;padding:10px 14px;font-size:13px;white-space:nowrap}:is() .nav-item .icon{font-size:16px}:is() .sidebar-footer{display:flex;flex-direction:row;gap:8px;margin-top:12px}:is() .sidebar-footer .nav-item{flex:1}:is() .btn-logout{padding:10px;font-size:13px;margin-top:8px}:is() .main-content{padding:16px;height:auto;max-height:none}:is() .view-header{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:20px}:is() .view-header h2{font-size:22px}:is() .view-header button{width:100%}:is() .groups-grid,:is() .documents-list,:is() .knowledge-list,:is() .files-list{grid-template-columns:1fr;gap:12px}:is() .group-card,:is() .document-card,:is() .knowledge-card,:is() .file-card{padding:16px}:is() .group-card h3,:is() .document-card h3,:is() .knowledge-card h3{font-size:16px}:is() .tasks-list{gap:12px}:is() .task-card{padding:16px}:is() .task-card h3{font-size:16px}:is() .task-meta,:is() .task-actions{flex-direction:column;gap:8px}:is() .task-actions button{width:100%}:is() .modal{padding:10px}:is() .modal-content{width:95%;max-width:none;padding:20px;max-height:90vh;overflow-y:auto}:is() .modal-header h3{font-size:20px}:is() .form-group{margin-bottom:16px}:is() .form-group label{font-size:13px}:is() .form-group input,:is() .form-group select,:is() .form-group textarea{padding:10px 12px;font-size:14px}:is() .btn-primary,:is() .btn-secondary,:is() .btn-danger,:is() .btn-success,:is() .btn-warning{padding:12px 16px;font-size:14px;width:100%}:is() .btn-sm{padding:8px 12px;font-size:12px}:is() .chat-container{height:calc(100vh - 200px);min-height:400px}:is() .messages{padding:12px;gap:12px}:is() .message{max-width:85%}:is() .message-content{padding:10px 12px;font-size:14px}:is() .chat-input{padding:12px;gap:8px}:is() .chat-input input{padding:10px 12px;font-size:14px}:is() .editor-container{height:calc(100vh - 250px);min-height:300px;padding:12px}:is() .editor-toolbar{flex-wrap:wrap;gap:8px}:is() #editor{padding:12px;font-size:14px}:is() .search-box{flex-direction:column;gap:8px}:is() .search-box input,:is() .search-box button{width:100%}:is() .search-filters{flex-direction:column;gap:12px}:is() .audit-stats{grid-template-columns:repeat(2,1fr);gap:12px}:is() .stat-number{font-size:24px}:is() .audit-header{display:none}:is() .audit-row{grid-template-columns:1fr;gap:8px;padding:12px}:is() .audit-row>div{display:flex;justify-content:space-between;align-items:center;gap:8px}:is() .audit-row>div:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:12px}:is() .backup-stats{grid-template-columns:1fr;gap:12px}:is() .backup-header{display:none}:is() .backup-row{grid-template-columns:1fr;gap:8px;padding:12px}:is() .backup-row>div{display:flex;justify-content:space-between;align-items:center}:is() .backup-actions{justify-content:flex-start;flex-wrap:wrap}:is() .settings-cards-grid{grid-template-columns:1fr;gap:12px}:is() .setting-card{padding:20px}:is() .setting-icon{font-size:40px}:is() .settings-detail-modern{padding:16px}:is() .settings-header-modern{padding:24px 16px}:is() .settings-icon-large{font-size:48px}:is() .settings-header-modern h2{font-size:24px}:is() .setting-card-detail{flex-direction:column;text-align:center;padding:16px}:is() .setting-card-header{flex-direction:column;gap:12px}:is() .settings-actions{flex-direction:column}:is() .btn-primary-large,:is() .btn-secondary-large{width:100%;justify-content:center;padding:14px 24px;font-size:15px}:is() .language-selector-modern{grid-template-columns:1fr}:is() .language-card{padding:16px}:is() .data-stats-cards{grid-template-columns:1fr;gap:12px}:is() .features-grid{grid-template-columns:1fr}:is() .help-sections{grid-template-columns:1fr;gap:16px}:is() .help-footer{flex-direction:column;text-align:center}:is() .help-footer button{width:100%}:is() .task-detail-view{padding:20px}:is() .task-detail-header{flex-direction:column;align-items:flex-start;gap:12px}:is() .task-detail-header h2{font-size:20px}:is() .task-detail-info{grid-template-columns:1fr;gap:10px;padding:16px}:is() .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}:is() .stat-card{padding:16px}:is() .stat-value{font-size:24px}:is() .members-table-header,:is() .members-table-row{grid-template-columns:1fr;gap:8px;padding:12px}:is() .members-table-header{display:none}:is() .members-table-row>div{display:flex;justify-content:space-between;align-items:center}:is() .collab-tools-tabs-modern{flex-direction:column;gap:8px}:is() .collab-tab-btn{width:100%;flex-direction:row;justify-content:center;padding:12px 16px}:is() .tab-icon{font-size:20px}:is() .tab-text{font-size:13px}:is() .whiteboard-container{min-height:400px}:is() .whiteboard-toolbar{flex-wrap:wrap;gap:8px;padding:12px}:is() .tool-btn{font-size:12px;padding:8px 12px}:is() #whiteboard{margin:12px;max-height:400px}:is() #brushSize{width:100%}:is() .whiteboard-footer{flex-direction:column;gap:12px;padding:12px}:is() .poll-creator{padding:16px;max-height:calc(100vh - 200px)}:is() .poll-creator h3{font-size:20px}:is() .code-editor{min-height:400px}:is() .editor-toolbar{flex-wrap:wrap;padding:12px}:is() #codeEditor{padding:12px;font-size:13px}:is() .code-output{max-height:150px}:is() .mindmap-container{min-height:400px}:is() .mindmap-toolbar{flex-wrap:wrap;gap:8px;padding:12px}:is() .mindmap-toolbar button{font-size:12px;padding:8px 12px}:is() .mindmap-canvas{min-height:300px}:is() .mindmap-node{min-width:100px;padding:10px 12px;font-size:13px}:is() .mindmap-node.root{min-width:140px;padding:12px 16px;font-size:16px}:is() .mindmap-legend{font-size:11px;padding:10px}:is() .legend-color{width:16px;height:16px}:is() .login-container{padding:16px}:is() .login-card{padding:24px;max-width:100%}:is() .logo{font-size:28px}:is() .auth-form{gap:16px}:is() .call-panel{padding:20px}:is() .call-controls{flex-direction:column;align-items:stretch;gap:12px}:is() .call-controls input{width:100%}:is() .called-members{grid-template-columns:repeat(2,1fr);gap:12px}:is() .export-container{grid-template-columns:1fr;gap:14px}:is() .export-section{padding:14px}:is() .export-actions{flex-direction:column}:is() .export-actions button{width:100%}:is() .knowledge-filters{flex-direction:column;gap:10px}:is() .knowledge-filters input,:is() .knowledge-filters select{width:100%;min-width:auto}:is() .poll-options-results{gap:10px}:is() .poll-option-result{padding:12px}:is() .poll-option-header{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 480px){:is() .main-content{padding:12px}:is() .view-header h2{font-size:20px}:is() .modal-content{padding:16px}:is() .btn-primary,:is() .btn-secondary{padding:10px 12px;font-size:13px}:is() .audit-stats,:is() .stats-grid,:is() .called-members{grid-template-columns:1fr}:is() .setting-icon{font-size:36px}:is() .settings-icon-large{font-size:40px}:is() .task-detail-header h2{font-size:18px}:is() .stat-value{font-size:20px}}@media (max-width: 768px) and (orientation: landscape){:is() .sidebar{position:fixed;top:0;left:0;right:0;z-index:1000;max-height:60px;overflow:hidden}:is() .sidebar-header,:is() .user-info,:is() .sidebar-footer{display:none}:is() .nav-menu{margin:0;padding:8px}:is() .main-content{margin-top:60px}:is() .chat-container,:is() .editor-container{height:calc(100vh - 120px)}}@media (hover: none) and (pointer: coarse){:is() .nav-item,:is() .btn-primary,:is() .btn-secondary,:is() button{min-height:44px;min-width:44px}:is() .nav-item:hover,:is() .btn-primary:hover,:is() .group-card:hover,:is() .document-card:hover{transform:none}:is() *{-webkit-overflow-scrolling:touch}:is() *{touch-action:manipulation}}@media print{:is() .sidebar,:is() .nav-menu,:is() .btn-logout,:is() .view-header button,:is() .task-actions,:is() .modal,:is() .whiteboard-toolbar,:is() .editor-toolbar,:is() .mindmap-toolbar{display:none!important}:is() .main-content{padding:0;max-height:none;overflow:visible}:is() .dashboard{display:block}:is() *{background:#fff!important;color:#000!important}}@media (prefers-contrast: high){:is() :root{--border: #ffffff;--text-primary: #ffffff;--text-secondary: #cccccc}:is() .btn-primary,:is() .btn-secondary,:is() .nav-item{border-width:3px}}@media (prefers-reduced-motion: reduce){:is() *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}}
|
package/dist/index.html
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="zh-CN">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
+
<title>CollabDocChat - 协作文档聊天平台</title>
|
|
7
|
+
<link href="https://cdn.quilljs.com/1.3.6/quill.snow.css" rel="stylesheet">
|
|
8
|
+
<script src="https://cdn.quilljs.com/1.3.6/quill.js"></script>
|
|
9
|
+
<script type="module" crossorigin src="/assets/index-BXsUUS0E.js"></script>
|
|
10
|
+
<link rel="stylesheet" crossorigin href="/assets/index-D8ZqeoaM.css">
|
|
11
|
+
</head>
|
|
12
|
+
<body>
|
|
13
|
+
<div id="app"></div>
|
|
14
|
+
</body>
|
|
15
|
+
</html>
|
|
16
|
+
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "collabdocchat",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.5.0",
|
|
4
4
|
"description": "开源的实时协作文档聊天平台 - 集成任务管理、多人文档编辑、智能点名功能",
|
|
5
5
|
"main": "./server/index.js",
|
|
6
6
|
"type": "module",
|
|
@@ -12,6 +12,7 @@
|
|
|
12
12
|
"server",
|
|
13
13
|
"src",
|
|
14
14
|
"scripts",
|
|
15
|
+
"dist",
|
|
15
16
|
"README.md",
|
|
16
17
|
"LICENSE",
|
|
17
18
|
"package.json",
|
|
@@ -67,8 +68,8 @@
|
|
|
67
68
|
"preview": "vite preview",
|
|
68
69
|
"serve": "node server/index.js",
|
|
69
70
|
"fix": "node scripts/fix-startup-issues.js",
|
|
70
|
-
"
|
|
71
|
-
"
|
|
71
|
+
"prepublishOnly": "npm run build && node scripts/pre-publish-check.js",
|
|
72
|
+
"prepack": "node scripts/pre-publish-check.js"
|
|
72
73
|
},
|
|
73
74
|
"dependencies": {
|
|
74
75
|
"archiver": "^6.0.2",
|
package/scripts/start-app.js
CHANGED
|
@@ -24,6 +24,12 @@ function checkDevDependencies() {
|
|
|
24
24
|
return existsSync(vitePath);
|
|
25
25
|
}
|
|
26
26
|
|
|
27
|
+
// 检查是否有构建后的前端
|
|
28
|
+
function checkBuiltFrontend() {
|
|
29
|
+
const distPath = join(rootDir, 'dist', 'index.html');
|
|
30
|
+
return existsSync(distPath);
|
|
31
|
+
}
|
|
32
|
+
|
|
27
33
|
// 安装 devDependencies
|
|
28
34
|
function installDevDependencies() {
|
|
29
35
|
return new Promise((resolve, reject) => {
|
|
@@ -189,8 +195,12 @@ async function main() {
|
|
|
189
195
|
|
|
190
196
|
// 检查是否有开发依赖(全局安装时可能没有)
|
|
191
197
|
const hasDevDeps = checkDevDependencies();
|
|
198
|
+
const hasBuiltFrontend = checkBuiltFrontend();
|
|
192
199
|
|
|
193
|
-
if (
|
|
200
|
+
if (hasBuiltFrontend) {
|
|
201
|
+
console.log('✅ 检测到完整前端(已构建)');
|
|
202
|
+
console.log('💡 您将看到完整的图形界面\n');
|
|
203
|
+
} else if (!hasDevDeps) {
|
|
194
204
|
console.log('⚠️ 检测到全局安装模式(无开发依赖)');
|
|
195
205
|
console.log('💡 将只启动服务器,不启动客户端\n');
|
|
196
206
|
console.log('📝 如需完整开发环境,请:');
|
|
@@ -213,8 +223,22 @@ async function main() {
|
|
|
213
223
|
|
|
214
224
|
let client = null;
|
|
215
225
|
|
|
216
|
-
//
|
|
217
|
-
if (
|
|
226
|
+
// 如果有构建后的前端,直接打开浏览器
|
|
227
|
+
if (hasBuiltFrontend) {
|
|
228
|
+
console.log('\n✅ 服务器启动成功!');
|
|
229
|
+
console.log('\n💡 提示:');
|
|
230
|
+
console.log(` • 完整应用: http://localhost:${PORT}`);
|
|
231
|
+
console.log(' • 默认账号: admin / admin123');
|
|
232
|
+
console.log('\n🌐 正在打开浏览器...\n');
|
|
233
|
+
|
|
234
|
+
setTimeout(() => {
|
|
235
|
+
openBrowser(`http://localhost:${PORT}`);
|
|
236
|
+
}, 1000);
|
|
237
|
+
|
|
238
|
+
console.log('⚠️ 按 Ctrl+C 停止服务\n');
|
|
239
|
+
}
|
|
240
|
+
// 只有在有开发依赖且没有构建前端时才启动开发服务器
|
|
241
|
+
else if (hasDevDeps) {
|
|
218
242
|
// 启动客户端
|
|
219
243
|
client = startClient();
|
|
220
244
|
|
|
@@ -236,7 +260,7 @@ async function main() {
|
|
|
236
260
|
}
|
|
237
261
|
}, 3000);
|
|
238
262
|
} else {
|
|
239
|
-
//
|
|
263
|
+
// 全局安装模式,只有服务器,自动打开浏览器
|
|
240
264
|
console.log('\n✅ 服务器启动成功!');
|
|
241
265
|
console.log('\n💡 提示:');
|
|
242
266
|
console.log(` • API 服务器: http://localhost:${PORT}`);
|
|
@@ -244,7 +268,14 @@ async function main() {
|
|
|
244
268
|
console.log('\n📝 注意:');
|
|
245
269
|
console.log(' 全局安装模式仅提供 API 服务器');
|
|
246
270
|
console.log(' 如需完整的前端界面,请在本地项目中运行');
|
|
247
|
-
console.log('\n
|
|
271
|
+
console.log('\n🌐 正在打开浏览器...\n');
|
|
272
|
+
|
|
273
|
+
// 延迟1秒后打开浏览器
|
|
274
|
+
setTimeout(() => {
|
|
275
|
+
openBrowser(`http://localhost:${PORT}`);
|
|
276
|
+
}, 1000);
|
|
277
|
+
|
|
278
|
+
console.log('⚠️ 按 Ctrl+C 停止服务\n');
|
|
248
279
|
}
|
|
249
280
|
|
|
250
281
|
// 处理退出信号
|
package/server/index.js
CHANGED
|
@@ -4,6 +4,9 @@ import { WebSocketServer } from 'ws';
|
|
|
4
4
|
import cors from 'cors';
|
|
5
5
|
import dotenv from 'dotenv';
|
|
6
6
|
import mongoose from 'mongoose';
|
|
7
|
+
import { fileURLToPath } from 'url';
|
|
8
|
+
import { dirname, join } from 'path';
|
|
9
|
+
import { existsSync } from 'fs';
|
|
7
10
|
import authRoutes from './routes/auth.js';
|
|
8
11
|
import taskRoutes from './routes/tasks.js';
|
|
9
12
|
import documentRoutes from './routes/documents.js';
|
|
@@ -23,6 +26,9 @@ import { initDefaultAdmin } from './utils/initAdmin.js';
|
|
|
23
26
|
import { errorHandler, notFoundHandler } from './middleware/errorHandler.js';
|
|
24
27
|
import backupService from './utils/backup.js';
|
|
25
28
|
|
|
29
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
30
|
+
const __dirname = dirname(__filename);
|
|
31
|
+
|
|
26
32
|
dotenv.config();
|
|
27
33
|
|
|
28
34
|
const app = express();
|
|
@@ -50,6 +56,21 @@ mongoose.connect(process.env.MONGODB_URI || 'mongodb://localhost:27017/collabdoc
|
|
|
50
56
|
// 静态文件服务(用于文件下载)
|
|
51
57
|
app.use('/uploads', express.static('uploads'));
|
|
52
58
|
|
|
59
|
+
// 静态页面服务
|
|
60
|
+
// 优先提供构建后的前端(如果存在)
|
|
61
|
+
const distPath = join(__dirname, '..', 'dist');
|
|
62
|
+
const publicPath = join(__dirname, 'public');
|
|
63
|
+
|
|
64
|
+
if (existsSync(distPath)) {
|
|
65
|
+
// 完整模式:提供构建后的前端
|
|
66
|
+
app.use(express.static(distPath));
|
|
67
|
+
console.log('✅ 前端模式:完整界面');
|
|
68
|
+
} else {
|
|
69
|
+
// API 模式:提供欢迎页面
|
|
70
|
+
app.use(express.static(publicPath));
|
|
71
|
+
console.log('✅ API 模式:欢迎页面');
|
|
72
|
+
}
|
|
73
|
+
|
|
53
74
|
// API 路由
|
|
54
75
|
app.use('/api/auth', authRoutes);
|
|
55
76
|
app.use('/api/tasks', taskRoutes);
|
|
@@ -74,6 +95,26 @@ app.get('/health', (req, res) => {
|
|
|
74
95
|
res.json({ status: 'ok', timestamp: new Date().toISOString() });
|
|
75
96
|
});
|
|
76
97
|
|
|
98
|
+
// SPA 路由支持 - 所有非 API 路由都返回 index.html
|
|
99
|
+
app.get('*', (req, res, next) => {
|
|
100
|
+
// 如果是 API 路由,跳过
|
|
101
|
+
if (req.path.startsWith('/api/')) {
|
|
102
|
+
return next();
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// 尝试提供构建后的 index.html
|
|
106
|
+
const distIndexPath = join(__dirname, '..', 'dist', 'index.html');
|
|
107
|
+
const publicIndexPath = join(__dirname, 'public', 'index.html');
|
|
108
|
+
|
|
109
|
+
if (existsSync(distIndexPath)) {
|
|
110
|
+
res.sendFile(distIndexPath);
|
|
111
|
+
} else if (existsSync(publicIndexPath)) {
|
|
112
|
+
res.sendFile(publicIndexPath);
|
|
113
|
+
} else {
|
|
114
|
+
next();
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
|
|
77
118
|
// 404 处理
|
|
78
119
|
app.use(notFoundHandler);
|
|
79
120
|
|
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="zh-CN">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
+
<title>CollabDocChat - API 服务器</title>
|
|
7
|
+
<style>
|
|
8
|
+
* {
|
|
9
|
+
margin: 0;
|
|
10
|
+
padding: 0;
|
|
11
|
+
box-sizing: border-box;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
body {
|
|
15
|
+
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
|
|
16
|
+
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
|
17
|
+
min-height: 100vh;
|
|
18
|
+
display: flex;
|
|
19
|
+
align-items: center;
|
|
20
|
+
justify-content: center;
|
|
21
|
+
padding: 20px;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.container {
|
|
25
|
+
background: white;
|
|
26
|
+
border-radius: 20px;
|
|
27
|
+
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
|
|
28
|
+
max-width: 800px;
|
|
29
|
+
width: 100%;
|
|
30
|
+
padding: 40px;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.header {
|
|
34
|
+
text-align: center;
|
|
35
|
+
margin-bottom: 40px;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
.logo {
|
|
39
|
+
font-size: 48px;
|
|
40
|
+
margin-bottom: 10px;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
h1 {
|
|
44
|
+
color: #333;
|
|
45
|
+
font-size: 32px;
|
|
46
|
+
margin-bottom: 10px;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.subtitle {
|
|
50
|
+
color: #666;
|
|
51
|
+
font-size: 16px;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.status {
|
|
55
|
+
background: #f0fdf4;
|
|
56
|
+
border: 2px solid #86efac;
|
|
57
|
+
border-radius: 12px;
|
|
58
|
+
padding: 20px;
|
|
59
|
+
margin-bottom: 30px;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.status-title {
|
|
63
|
+
color: #16a34a;
|
|
64
|
+
font-weight: bold;
|
|
65
|
+
font-size: 18px;
|
|
66
|
+
margin-bottom: 10px;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.status-item {
|
|
70
|
+
color: #166534;
|
|
71
|
+
margin: 8px 0;
|
|
72
|
+
padding-left: 20px;
|
|
73
|
+
position: relative;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.status-item::before {
|
|
77
|
+
content: "✓";
|
|
78
|
+
position: absolute;
|
|
79
|
+
left: 0;
|
|
80
|
+
color: #16a34a;
|
|
81
|
+
font-weight: bold;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
.info-box {
|
|
85
|
+
background: #f8fafc;
|
|
86
|
+
border-radius: 12px;
|
|
87
|
+
padding: 20px;
|
|
88
|
+
margin-bottom: 20px;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
.info-title {
|
|
92
|
+
font-weight: bold;
|
|
93
|
+
color: #334155;
|
|
94
|
+
margin-bottom: 15px;
|
|
95
|
+
font-size: 18px;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.info-item {
|
|
99
|
+
display: flex;
|
|
100
|
+
justify-content: space-between;
|
|
101
|
+
padding: 10px 0;
|
|
102
|
+
border-bottom: 1px solid #e2e8f0;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.info-item:last-child {
|
|
106
|
+
border-bottom: none;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
.info-label {
|
|
110
|
+
color: #64748b;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
.info-value {
|
|
114
|
+
color: #0f172a;
|
|
115
|
+
font-weight: 500;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
.api-link {
|
|
119
|
+
color: #667eea;
|
|
120
|
+
text-decoration: none;
|
|
121
|
+
font-weight: 500;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
.api-link:hover {
|
|
125
|
+
text-decoration: underline;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
.warning-box {
|
|
129
|
+
background: #fef3c7;
|
|
130
|
+
border: 2px solid #fbbf24;
|
|
131
|
+
border-radius: 12px;
|
|
132
|
+
padding: 20px;
|
|
133
|
+
margin-bottom: 20px;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
.warning-title {
|
|
137
|
+
color: #92400e;
|
|
138
|
+
font-weight: bold;
|
|
139
|
+
margin-bottom: 10px;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
.warning-text {
|
|
143
|
+
color: #78350f;
|
|
144
|
+
line-height: 1.6;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
.action-box {
|
|
148
|
+
background: #eff6ff;
|
|
149
|
+
border-radius: 12px;
|
|
150
|
+
padding: 20px;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
.action-title {
|
|
154
|
+
color: #1e40af;
|
|
155
|
+
font-weight: bold;
|
|
156
|
+
margin-bottom: 15px;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
.action-steps {
|
|
160
|
+
color: #1e3a8a;
|
|
161
|
+
line-height: 1.8;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
.action-steps li {
|
|
165
|
+
margin: 8px 0;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
code {
|
|
169
|
+
background: #1e293b;
|
|
170
|
+
color: #e2e8f0;
|
|
171
|
+
padding: 2px 8px;
|
|
172
|
+
border-radius: 4px;
|
|
173
|
+
font-family: 'Courier New', monospace;
|
|
174
|
+
font-size: 14px;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
.footer {
|
|
178
|
+
text-align: center;
|
|
179
|
+
margin-top: 30px;
|
|
180
|
+
color: #64748b;
|
|
181
|
+
font-size: 14px;
|
|
182
|
+
}
|
|
183
|
+
</style>
|
|
184
|
+
</head>
|
|
185
|
+
<body>
|
|
186
|
+
<div class="container">
|
|
187
|
+
<div class="header">
|
|
188
|
+
<div class="logo">🎉</div>
|
|
189
|
+
<h1>CollabDocChat</h1>
|
|
190
|
+
<p class="subtitle">开源的实时协作文档聊天平台</p>
|
|
191
|
+
</div>
|
|
192
|
+
|
|
193
|
+
<div class="status">
|
|
194
|
+
<div class="status-title">✅ API 服务器运行中</div>
|
|
195
|
+
<div class="status-item">MongoDB 已连接</div>
|
|
196
|
+
<div class="status-item">WebSocket 服务已启动</div>
|
|
197
|
+
<div class="status-item">所有 API 端点可用</div>
|
|
198
|
+
</div>
|
|
199
|
+
|
|
200
|
+
<div class="info-box">
|
|
201
|
+
<div class="info-title">📍 服务器信息</div>
|
|
202
|
+
<div class="info-item">
|
|
203
|
+
<span class="info-label">API 地址</span>
|
|
204
|
+
<span class="info-value"><a href="/api" class="api-link" target="_blank">http://localhost:3000/api</a></span>
|
|
205
|
+
</div>
|
|
206
|
+
<div class="info-item">
|
|
207
|
+
<span class="info-label">健康检查</span>
|
|
208
|
+
<span class="info-value"><a href="/health" class="api-link" target="_blank">http://localhost:3000/health</a></span>
|
|
209
|
+
</div>
|
|
210
|
+
<div class="info-item">
|
|
211
|
+
<span class="info-label">WebSocket</span>
|
|
212
|
+
<span class="info-value">ws://localhost:3000</span>
|
|
213
|
+
</div>
|
|
214
|
+
<div class="info-item">
|
|
215
|
+
<span class="info-label">默认账号</span>
|
|
216
|
+
<span class="info-value">admin / admin123</span>
|
|
217
|
+
</div>
|
|
218
|
+
</div>
|
|
219
|
+
|
|
220
|
+
<div class="warning-box">
|
|
221
|
+
<div class="warning-title">⚠️ 全局安装模式</div>
|
|
222
|
+
<p class="warning-text">
|
|
223
|
+
当前运行在全局安装模式下,仅提供 API 服务器。
|
|
224
|
+
如需完整的前端界面和开发环境,请按照下方步骤操作。
|
|
225
|
+
</p>
|
|
226
|
+
</div>
|
|
227
|
+
|
|
228
|
+
<div class="action-box">
|
|
229
|
+
<div class="action-title">🚀 获取完整功能</div>
|
|
230
|
+
<ol class="action-steps">
|
|
231
|
+
<li>克隆或下载项目到本地目录</li>
|
|
232
|
+
<li>运行 <code>npm install</code> 安装所有依赖</li>
|
|
233
|
+
<li>运行 <code>npm run dev</code> 启动完整应用</li>
|
|
234
|
+
<li>访问 <code>http://localhost:5173</code> 使用前端界面</li>
|
|
235
|
+
</ol>
|
|
236
|
+
</div>
|
|
237
|
+
|
|
238
|
+
<div class="footer">
|
|
239
|
+
<p>CollabDocChat v2.4.8 | MIT License</p>
|
|
240
|
+
<p><a href="https://github.com/shijinghao/collabdocchat" class="api-link" target="_blank">GitHub</a> |
|
|
241
|
+
<a href="https://www.npmjs.com/package/collabdocchat" class="api-link" target="_blank">NPM</a></p>
|
|
242
|
+
</div>
|
|
243
|
+
</div>
|
|
244
|
+
</body>
|
|
245
|
+
</html>
|
|
246
|
+
|