legacy.css 0.1.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/LICENSE +21 -0
- package/README.md +242 -0
- package/dist/legacy.css +1045 -0
- package/dist/legacy.js +1466 -0
- package/dist/legacy.min.css +1 -0
- package/dist/legacy.min.js +1 -0
- package/mcp/server.js +524 -0
- package/package.json +52 -0
- package/src/alerts.css +21 -0
- package/src/badges.css +39 -0
- package/src/base.css +43 -0
- package/src/buttons.css +40 -0
- package/src/dragdrop.css +49 -0
- package/src/features/dragdrop.ts +273 -0
- package/src/features/modal.ts +265 -0
- package/src/features/multiselect.ts +390 -0
- package/src/features/pagination.ts +483 -0
- package/src/features/popover.ts +322 -0
- package/src/features/tabs.ts +199 -0
- package/src/features/theme.ts +59 -0
- package/src/features/toast.ts +216 -0
- package/src/forms.css +57 -0
- package/src/internal.ts +210 -0
- package/src/jquery.ts +141 -0
- package/src/legacy.css +22 -0
- package/src/legacy.ts +31 -0
- package/src/lists.css +21 -0
- package/src/modal.css +46 -0
- package/src/multiselect.css +118 -0
- package/src/navigation.css +18 -0
- package/src/pagination.css +53 -0
- package/src/panels.css +22 -0
- package/src/popover.css +36 -0
- package/src/progress.css +117 -0
- package/src/sidebar.css +62 -0
- package/src/tables.css +31 -0
- package/src/tabs.css +43 -0
- package/src/toast.css +78 -0
- package/src/toolbars.css +33 -0
- package/src/typography.css +48 -0
- package/src/utilities.css +23 -0
- package/src/variables.css +83 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
:root{color-scheme:light;--legacy-font-sans:verdana, arial, helvetica, sans-serif;--legacy-font-mono:"Courier New", courier, monospace;--legacy-font-size:12px;--legacy-page-bg:#d9d9d9;--legacy-surface:#f4f4f4;--legacy-surface-raised:#fff;--legacy-surface-alt:#f7f7f7;--legacy-border:#9a9a9a;--legacy-border-dark:#666;--legacy-text:#1f1f1f;--legacy-muted:#555;--legacy-link:#0645ad;--legacy-link-visited:#551a8b;--legacy-primary:#0b4f8a;--legacy-primary-dark:#07355d;--legacy-primary-contrast:#fff;--legacy-header-bg:#d6e3f0;--legacy-header-hover-bg:#e8eef5;--legacy-focus:#f4c430;--legacy-danger-bg:#f8d7da;--legacy-danger-border:#b94a48;--legacy-warning-bg:#fff3cd;--legacy-warning-border:#c79c00;--legacy-success-bg:#dff0d8;--legacy-success-border:#468847;--legacy-info-bg:#d9edf7;--legacy-info-border:#3a87ad;--legacy-radius:2px;--legacy-control-bg:#fff;--legacy-button-bg-top:#fdfdfd;--legacy-button-bg-bottom:#d5d5d5;--legacy-button-hover-bottom:#c6d3df;--legacy-button-active-bg:#c8c8c8;--legacy-button-border:#7f7f7f;--legacy-space-1:.25rem;--legacy-space-2:.5rem;--legacy-space-3:.75rem;--legacy-space-4:1rem;--legacy-space-6:1.5rem;--legacy-line-height:1.45}[data-legacy-theme=light]{color-scheme:light}[data-legacy-theme=dark]{color-scheme:dark;--legacy-page-bg:#151515;--legacy-surface:#242424;--legacy-surface-raised:#303030;--legacy-surface-alt:#262626;--legacy-border:#696969;--legacy-border-dark:#8a8a8a;--legacy-text:#efefef;--legacy-muted:#b8b8b8;--legacy-link:#8ab4f8;--legacy-link-visited:#c7a8ff;--legacy-primary:#5f8fbd;--legacy-primary-dark:#b7d6f2;--legacy-primary-contrast:#101010;--legacy-header-bg:#21384b;--legacy-header-hover-bg:#2d4559;--legacy-focus:#f4c430;--legacy-danger-bg:#4a2327;--legacy-danger-border:#d78387;--legacy-warning-bg:#4a3b15;--legacy-warning-border:#e1bd4c;--legacy-success-bg:#233f28;--legacy-success-border:#82ba7c;--legacy-info-bg:#203c4a;--legacy-info-border:#82b9d0;--legacy-control-bg:#1f1f1f;--legacy-button-bg-top:#424242;--legacy-button-bg-bottom:#2b2b2b;--legacy-button-hover-bottom:#38495a;--legacy-button-active-bg:#1f1f1f;--legacy-button-border:#8a8a8a}*{box-sizing:border-box}html{background:var(--legacy-page-bg);color:var(--legacy-text);font-family:var(--legacy-font-sans);font-size:var(--legacy-font-size);line-height:var(--legacy-line-height)}body{max-width:1120px;min-height:100vh;padding:var(--legacy-space-4);margin:0 auto}main{background:var(--legacy-surface);border:1px solid var(--legacy-border);padding:var(--legacy-space-4)}hr{border:0;border-top:1px solid var(--legacy-border);margin:var(--legacy-space-4) 0}img,svg,video{max-width:100%}code,kbd,pre,samp{font-family:var(--legacy-font-mono)}h1,h2,h3,h4,h5,h6{color:var(--legacy-primary-dark);margin:0 0 var(--legacy-space-3);line-height:1.2}h1{border-bottom:3px double var(--legacy-border-dark);padding-bottom:var(--legacy-space-2);font-size:1.65rem}h2{border-bottom:1px solid var(--legacy-border);padding-bottom:var(--legacy-space-1);font-size:1.3rem}p{margin:0 0 var(--legacy-space-3)}a{color:var(--legacy-link);text-decoration:underline}a:visited{color:var(--legacy-link-visited)}small,figcaption{color:var(--legacy-muted);font-size:.875rem}blockquote{background:var(--legacy-surface-raised);border-left:4px solid var(--legacy-border-dark);margin:var(--legacy-space-4) 0;padding:var(--legacy-space-3) var(--legacy-space-4)}ul,ol{margin:0 0 var(--legacy-space-4) var(--legacy-space-6);padding:0}li{margin-bottom:var(--legacy-space-1)}dl{margin:0 0 var(--legacy-space-4)}dt{font-weight:700}dd{margin:0 0 var(--legacy-space-2) var(--legacy-space-4)}form{margin:0 0 var(--legacy-space-4)}fieldset{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border);margin:0 0 var(--legacy-space-4);padding:var(--legacy-space-3) var(--legacy-space-4) var(--legacy-space-4)}legend{background:var(--legacy-primary);border:1px solid var(--legacy-primary-dark);color:var(--legacy-primary-contrast);padding:var(--legacy-space-1) var(--legacy-space-2);font-weight:700}label{margin:var(--legacy-space-2) 0 var(--legacy-space-1);font-weight:700;display:inline-block}input,select,textarea{background:var(--legacy-control-bg);border:1px solid var(--legacy-border-dark);border-radius:var(--legacy-radius);color:var(--legacy-text);font:inherit;width:100%;max-width:100%;padding:.35rem .45rem;display:block}input[type=checkbox],input[type=radio]{margin-right:var(--legacy-space-1);width:auto;display:inline-block}textarea{resize:vertical;min-height:7rem}input:focus,select:focus,textarea:focus{outline:2px solid var(--legacy-focus);outline-offset:1px}.multiselect{margin:0 0 var(--legacy-space-2);max-width:100%;position:relative}.multiselect-source{display:none}.multiselect-toggle{text-align:left;justify-content:space-between;align-items:center;width:100%;min-height:2rem;display:flex}.multiselect-toggle:after{border-left:.28rem solid #0000;border-right:.28rem solid #0000;border-top:.38rem solid var(--legacy-text);content:"";margin-left:var(--legacy-space-2);flex:none}.multiselect-toggle[aria-expanded=true]:after{border-bottom:.38rem solid var(--legacy-text);border-top:0}.multiselect-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.multiselect-menu{background:var(--legacy-control-bg);border:1px solid var(--legacy-border-dark);min-width:100%;max-height:14rem;padding:var(--legacy-space-1);z-index:20;margin-top:1px;display:none;position:absolute;top:100%;left:0;overflow:auto;box-shadow:2px 2px #0000002e}.multiselect.is-open .multiselect-menu{display:block}.multiselect-option{color:var(--legacy-text);cursor:pointer;font:inherit;align-items:start;gap:var(--legacy-space-1);line-height:var(--legacy-line-height);min-height:auto;padding:.2rem var(--legacy-space-1);text-align:left;background:0 0;border:0;border-radius:0;width:100%;margin:0;display:flex}.multiselect-option:before{background:var(--legacy-control-bg);border:1px solid var(--legacy-border-dark);content:"";flex:none;width:.85rem;height:.85rem;margin-top:.15rem}.multiselect-option:hover,.multiselect-option:focus{background:var(--legacy-info-bg);outline:1px solid var(--legacy-info-border);outline-offset:-1px}.multiselect-option[aria-selected=true]:before{background:linear-gradient(45deg, transparent 45%, var(--legacy-primary-dark) 45% 58%, transparent 58%), linear-gradient(-45deg, transparent 48%, var(--legacy-primary-dark) 48% 62%, transparent 62%), var(--legacy-control-bg)}.multiselect-option[aria-disabled=true]{color:var(--legacy-muted);cursor:default}.multiselect-option[aria-disabled=true]:hover,.multiselect-option[aria-disabled=true]:focus{background:0 0;outline:0}.multiselect-empty{color:var(--legacy-muted);padding:var(--legacy-space-1)}button,input[type=button],input[type=reset],input[type=submit]{background:linear-gradient(var(--legacy-button-bg-top), var(--legacy-button-bg-bottom));border:1px solid var(--legacy-button-border);border-radius:var(--legacy-radius);color:var(--legacy-text);cursor:pointer;font-family:var(--legacy-font-sans);text-align:center;width:auto;min-height:1.75rem;padding:.16rem .55rem;font-size:.92rem;font-weight:400;line-height:1.2;display:inline-block}button:hover,input[type=button]:hover,input[type=reset]:hover,input[type=submit]:hover{background:linear-gradient(var(--legacy-button-bg-top), var(--legacy-button-hover-bottom));border-color:var(--legacy-primary)}button:active,input[type=button]:active,input[type=reset]:active,input[type=submit]:active{background:var(--legacy-button-active-bg)}.toolbar{background:var(--legacy-surface);border:1px solid var(--legacy-border);align-items:center;gap:var(--legacy-space-2);margin:0 0 var(--legacy-space-4);padding:var(--legacy-space-2);flex-wrap:wrap;display:flex}.toolbar-group{align-items:center;gap:var(--legacy-space-1);flex-wrap:wrap;display:inline-flex}.toolbar label{margin:0}.toolbar input,.toolbar select,.toolbar textarea{width:auto;margin:0}.toolbar input[type=search],.toolbar input[type=text]{min-width:12rem}table{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border-dark);border-collapse:collapse;margin:0 0 var(--legacy-space-4);width:100%}caption{color:var(--legacy-primary-dark);margin-bottom:var(--legacy-space-2);text-align:left;font-weight:700}th,td{border:1px solid var(--legacy-border);text-align:left;vertical-align:top;padding:.45rem .55rem}th{background:var(--legacy-header-bg);color:var(--legacy-primary-dark)}tbody tr:nth-child(2n){background:var(--legacy-surface-alt)}nav{background:var(--legacy-primary);border:1px solid var(--legacy-primary-dark);margin:0 0 var(--legacy-space-4);padding:var(--legacy-space-2)}nav a,nav a:visited{color:var(--legacy-primary-contrast);margin-right:var(--legacy-space-3);font-weight:700;display:inline-block}nav a:hover{background:var(--legacy-primary-dark)}.sidebar-layout{align-items:flex-start;gap:var(--legacy-space-4);grid-template-columns:14rem minmax(0,1fr);display:grid}.sidebar{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border)}.sidebar>header{background:var(--legacy-header-bg);border-bottom:1px solid var(--legacy-border);color:var(--legacy-primary-dark);padding:var(--legacy-space-2) var(--legacy-space-3);font-weight:700}.sidebar nav{padding:var(--legacy-space-2) 0;background:0 0;border:0;margin:0}.sidebar a,.sidebar a:visited{color:var(--legacy-link);padding:var(--legacy-space-1) var(--legacy-space-3);margin:0;font-weight:400;display:block}.sidebar a:hover{background:var(--legacy-header-hover-bg);color:var(--legacy-primary-dark)}.sidebar a[aria-current=page]{background:var(--legacy-primary);color:var(--legacy-primary-contrast);font-weight:700}.sidebar-section{border-top:1px solid var(--legacy-border);margin-top:var(--legacy-space-2);padding-top:var(--legacy-space-2)}.sidebar-content{min-width:0}@media (width<=720px){.sidebar-layout{grid-template-columns:1fr}}.pagination{background:var(--legacy-surface);border:1px solid var(--legacy-border);align-items:center;gap:var(--legacy-space-2);margin:0 0 var(--legacy-space-4);padding:var(--legacy-space-2);flex-wrap:wrap;display:flex}.pagination-summary{color:var(--legacy-muted);margin-right:auto}.pagination-pages{align-items:center;gap:var(--legacy-space-1);flex-wrap:wrap;display:inline-flex}.pagination-page[aria-current=page]{background:var(--legacy-primary);border-color:var(--legacy-primary-dark);color:var(--legacy-primary-contrast);font-weight:700}.pagination-ellipsis{color:var(--legacy-muted);padding:0 var(--legacy-space-1);display:inline-block}.pagination-size{align-items:center;gap:var(--legacy-space-1);display:inline-flex}.pagination-size label{align-items:center;gap:var(--legacy-space-1);margin:0;display:inline-flex}.pagination-size select{width:auto;margin:0}.container{max-width:1120px;margin:0 auto}.panel{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border);margin:0 0 var(--legacy-space-4)}.panel>header{background:var(--legacy-header-bg);border-bottom:1px solid var(--legacy-border);color:var(--legacy-primary-dark);padding:var(--legacy-space-2) var(--legacy-space-3);font-weight:700}.panel>:not(header){padding:var(--legacy-space-3)}dialog.modal{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border-dark);border-radius:var(--legacy-radius);color:var(--legacy-text);max-width:min(36rem, calc(100vw - var(--legacy-space-4)));width:min(36rem, calc(100vw - var(--legacy-space-4)));padding:0;box-shadow:0 16px 40px #00000059}dialog.modal[open]{display:block}dialog.modal::backdrop{background:#1f1f1f73}dialog.modal>header{background:var(--legacy-header-bg);border-bottom:1px solid var(--legacy-border);color:var(--legacy-primary-dark);align-items:center;gap:var(--legacy-space-2);padding:var(--legacy-space-2) var(--legacy-space-3);justify-content:space-between;display:flex}dialog.modal>:not(header,footer){padding:var(--legacy-space-3)}dialog.modal>footer{background:var(--legacy-surface);border-top:1px solid var(--legacy-border);gap:var(--legacy-space-2);padding:var(--legacy-space-3);justify-content:flex-end;display:flex}dialog.modal button[data-modal-close]{flex:none}.popover{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border-dark);border-radius:var(--legacy-radius);color:var(--legacy-text);max-width:min(20rem, calc(100vw - var(--legacy-space-4)));padding:var(--legacy-space-3);z-index:50;width:max-content;position:fixed;box-shadow:2px 2px #00000038}.popover[hidden]{display:none}.popover>header{background:var(--legacy-header-bg);border-bottom:1px solid var(--legacy-border);color:var(--legacy-primary-dark);margin:calc(var(--legacy-space-3) * -1) calc(var(--legacy-space-3) * -1) var(--legacy-space-2);padding:var(--legacy-space-2) var(--legacy-space-3);font-weight:700}.popover>:last-child{margin-bottom:0}.popover-actions{gap:var(--legacy-space-2);margin-top:var(--legacy-space-3);justify-content:flex-end;display:flex}.tabs{margin:0 0 var(--legacy-space-4)}.tabs-list{border-bottom:1px solid var(--legacy-border);align-items:end;gap:var(--legacy-space-1);margin:0;padding:0;display:flex}.tabs-list [role=tab]{background:linear-gradient(var(--legacy-button-bg-top), var(--legacy-button-bg-bottom));border:1px solid var(--legacy-border);border-radius:var(--legacy-radius) var(--legacy-radius) 0 0;color:var(--legacy-text);cursor:pointer;font:inherit;min-height:auto;padding:var(--legacy-space-2) var(--legacy-space-3);border-bottom:0;margin:0 0 -1px}.tabs-list [role=tab][aria-selected=true]{background:var(--legacy-surface-raised);border-color:var(--legacy-border-dark);border-bottom:1px solid var(--legacy-surface-raised);color:var(--legacy-primary-dark);font-weight:700}.tabs-panel{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border-dark);padding:var(--legacy-space-3);border-top:0}.dragdrop{align-items:stretch;gap:var(--legacy-space-3);margin:0 0 var(--legacy-space-4);grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));display:grid}.dragdrop-column{background:var(--legacy-surface);border:1px solid var(--legacy-border);min-height:8rem;padding:var(--legacy-space-2)}.dragdrop-column>header{background:var(--legacy-header-bg);border:1px solid var(--legacy-border);color:var(--legacy-primary-dark);margin:0 0 var(--legacy-space-2);padding:var(--legacy-space-2);font-weight:700}.dragdrop-column.is-drag-over{background:var(--legacy-info-bg);outline:2px solid var(--legacy-info-border);outline-offset:-2px}.dragdrop-item,[data-dragdrop-item]{background:var(--legacy-surface-raised);border:1px solid var(--legacy-border-dark);cursor:move;margin:0 0 var(--legacy-space-2);padding:var(--legacy-space-2)}.dragdrop-item:focus,[data-dragdrop-item]:focus{outline:2px solid var(--legacy-focus);outline-offset:1px}.dragdrop-item.is-dragging,[data-dragdrop-item].is-dragging{opacity:.55}progress,.progress{background:var(--legacy-surface);border:1px solid var(--legacy-border-dark);border-radius:var(--legacy-radius);color:var(--legacy-primary);height:1rem;margin:0 0 var(--legacy-space-3);width:100%;display:block;overflow:hidden}progress{appearance:none}progress::-webkit-progress-bar{background:var(--legacy-surface)}progress::-webkit-progress-value{background:var(--legacy-primary)}progress:not([value]){background:linear-gradient(45deg, var(--legacy-info-bg) 25%, var(--legacy-surface-raised) 25%, var(--legacy-surface-raised) 50%, var(--legacy-info-bg) 50%, var(--legacy-info-bg) 75%, var(--legacy-surface-raised) 75%, var(--legacy-surface-raised));background-size:1rem 1rem;animation:1s linear infinite legacy-progress-loading}progress:not([value])::-webkit-progress-bar{background:linear-gradient(45deg, var(--legacy-info-bg) 25%, var(--legacy-surface-raised) 25%, var(--legacy-surface-raised) 50%, var(--legacy-info-bg) 50%, var(--legacy-info-bg) 75%, var(--legacy-surface-raised) 75%, var(--legacy-surface-raised));background-size:1rem 1rem;animation:1s linear infinite legacy-progress-loading}progress::-moz-progress-bar{background:var(--legacy-primary)}progress:not([value])::-moz-progress-bar{background:0 0}.progress-bar{background:var(--legacy-primary);height:100%;display:block}.progress-loading .progress-bar{background:linear-gradient(45deg, var(--legacy-info-bg) 25%, var(--legacy-surface-raised) 25%, var(--legacy-surface-raised) 50%, var(--legacy-info-bg) 50%, var(--legacy-info-bg) 75%, var(--legacy-surface-raised) 75%, var(--legacy-surface-raised));background-size:1rem 1rem;width:100%;animation:1s linear infinite legacy-progress-loading}.progress-label{color:var(--legacy-muted);margin:calc(var(--legacy-space-2) * -1) 0 var(--legacy-space-3);display:block}@keyframes legacy-progress-loading{0%{background-position:0 0}to{background-position:1rem 0}}@media (prefers-reduced-motion:reduce){progress:not([value]){animation:none}progress:not([value])::-webkit-progress-bar{animation:none}.progress-loading .progress-bar{animation:none}}.alert{background:var(--legacy-info-bg);border:1px solid var(--legacy-info-border);margin:0 0 var(--legacy-space-4);padding:var(--legacy-space-3)}.alert-success{background:var(--legacy-success-bg);border-color:var(--legacy-success-border)}.alert-warning{background:var(--legacy-warning-bg);border-color:var(--legacy-warning-border)}.alert-danger{background:var(--legacy-danger-bg);border-color:var(--legacy-danger-border)}.toast-region{gap:var(--legacy-space-2);inset:auto var(--legacy-space-4) var(--legacy-space-4) auto;max-width:min(24rem, calc(100vw - var(--legacy-space-4) * 2));z-index:1000;flex-direction:column;width:24rem;display:flex;position:fixed}.toast-region[data-position=top-left]{inset:var(--legacy-space-4) auto auto var(--legacy-space-4)}.toast-region[data-position=top-right]{inset:var(--legacy-space-4) var(--legacy-space-4) auto auto}.toast-region[data-position=bottom-left]{inset:auto auto var(--legacy-space-4) var(--legacy-space-4)}.toast{background:var(--legacy-info-bg);border:1px solid var(--legacy-info-border);border-radius:var(--legacy-radius);color:var(--legacy-text);gap:var(--legacy-space-2);padding:var(--legacy-space-3);display:flex;box-shadow:2px 2px #0003}.toast-success{background:var(--legacy-success-bg);border-color:var(--legacy-success-border)}.toast-warning{background:var(--legacy-warning-bg);border-color:var(--legacy-warning-border)}.toast-danger{background:var(--legacy-danger-bg);border-color:var(--legacy-danger-border)}.toast-muted{background:var(--legacy-surface);border-color:var(--legacy-border);color:var(--legacy-muted)}.toast-body{flex:auto;min-width:0}.toast-title{color:var(--legacy-primary-dark);margin:0 0 var(--legacy-space-1);display:block}.toast-close{flex:none}@media (width<=32rem){.toast-region,.toast-region[data-position]{inset:auto var(--legacy-space-2) var(--legacy-space-2);width:auto;max-width:none}}.badge{background:var(--legacy-info-bg);border:1px solid var(--legacy-info-border);border-radius:var(--legacy-radius);color:var(--legacy-text);vertical-align:baseline;white-space:nowrap;padding:.12rem .35rem;font-size:.85em;font-weight:700;line-height:1.2;display:inline-block}.badge-info{background:var(--legacy-info-bg);border-color:var(--legacy-info-border)}.badge-success{background:var(--legacy-success-bg);border-color:var(--legacy-success-border)}.badge-warning{background:var(--legacy-warning-bg);border-color:var(--legacy-warning-border)}.badge-danger{background:var(--legacy-danger-bg);border-color:var(--legacy-danger-border)}.badge-muted{background:var(--legacy-surface);border-color:var(--legacy-border);color:var(--legacy-muted)}.text-right{text-align:right}.text-center{text-align:center}.muted{color:var(--legacy-muted)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
(function(){function e(e){return typeof e==`object`&&!!e&&`jquery`in e}function t(e){return typeof e==`object`&&!!e&&`nodeType`in e&&e.nodeType===1}function n(e){return t(e)&&e.nodeName===`SELECT`}function r(e){return t(e.target)?e.target:null}function i(e){return t(e.currentTarget)?e.currentTarget:null}function a(e,t,n){e.addEventListener(t,n)}var o=new WeakSet,s=new WeakMap,c=`[data-dragdrop], .dragdrop`,l=`[data-dragdrop-column], .dragdrop-column`,u=`[data-dragdrop-item], .dragdrop-item`,d=null;function f(n){function f(n){return n?e(n)?f(n[0]):typeof n==`string`?document.querySelector(n):t(n)?n.matches(c)?n:n.closest(c):null:null}function p(e){return Array.from(e.querySelectorAll(u)).filter(t=>t.closest(l)===e)}function m(e){return e.getAttribute(`data-column`)||e.id||null}function h(e,t){return p(t).indexOf(e)}function g(e,t){return p(e).filter(e=>!e.classList.contains(`is-dragging`)).reduce((e,n)=>{let r=n.getBoundingClientRect(),i=t-r.top-r.height/2;return i<0&&i>e.offset?{offset:i,item:n}:e},{offset:-1/0,item:null}).item}function _(e,t){if(!d)return null;let n=t||d.item.closest(l);return{board:d.board,item:d.item,fromColumn:d.fromColumn,toColumn:n,fromColumnId:m(d.fromColumn),toColumnId:n?m(n):null,fromIndex:d.fromIndex,toIndex:n?h(d.item,n):-1,originalEvent:e}}function v(e,t,n){let r=(s.get(e)||{})[t];typeof r==`function`&&r.call(e,n)}function y(){d&&(d.item.classList.remove(`is-dragging`),d.board.querySelectorAll(`.is-drag-over`).forEach(e=>e.classList.remove(`is-drag-over`))),d=null}function b(e){let t=r(e),n=t?t.closest(u):null,a=f(i(e));if(!n||!a||!a.contains(n))return;let o=n.closest(l);!o||!a.contains(o)||(d={board:a,item:n,fromColumn:o,fromIndex:h(n,o)},n.classList.add(`is-dragging`),e.dataTransfer&&(e.dataTransfer.effectAllowed=`move`,e.dataTransfer.setData(`text/plain`,n.getAttribute(`data-id`)||n.id||``)),v(a,`onDrag`,_(e,o)))}function x(e){if(!d)return;let t=r(e),n=t?t.closest(l):null;if(!n||!d.board.contains(n))return;e.preventDefault(),e.dataTransfer&&(e.dataTransfer.dropEffect=`move`),d.board.querySelectorAll(`.is-drag-over`).forEach(e=>{e!==n&&e.classList.remove(`is-drag-over`)}),n.classList.add(`is-drag-over`);let i=g(n,e.clientY);n.insertBefore(d.item,i)}function S(e){if(!d)return;let t=r(e),n=t?t.closest(l):null;if(!n||!d.board.contains(n))return;e.preventDefault();let i=_(e,n);if(!i)return;let a=i.fromColumn!==i.toColumn,o=i.fromIndex!==i.toIndex;(a||o)&&(v(i.board,`onDrop`,i),a&&v(i.board,`onChangeColumn`,i)),y()}function C(){y()}function w(e,t){let n=f(e);return n?(t===void 0?s.has(n)||s.set(n,{}):s.set(n,Object.assign({},s.get(n),t||{})),n.querySelectorAll(u).forEach(e=>{e.hasAttribute(`draggable`)||e.setAttribute(`draggable`,`true`)}),o.has(n)?n:(o.add(n),a(n,`dragstart`,b),a(n,`dragover`,x),a(n,`drop`,S),a(n,`dragend`,C),n)):null}n.dragdrop={setup(e,t){return w(e,t)}},document.addEventListener(`DOMContentLoaded`,function(){document.querySelectorAll(c).forEach(e=>{w(e)})})}function p(e,t){e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.modal&&(e.jQuery.fn.modal=function(e){let n=e||`open`;return this.each(function(){if(n===`close`){t.modal.close(this);return}if(n===`toggle`){t.modal.toggle(this);return}t.modal.open(this)})}),e.jQuery&&!e.jQuery.toast&&(e.jQuery.toast=function(e,n){return t.toast.show(e,n)}),e.jQuery&&!e.jQuery.theme&&(e.jQuery.theme=function(e){return e===void 0?t.theme.get():t.theme.set(e)}),e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.toast&&(e.jQuery.fn.toast=function(e){return this.each(function(){if(e===`close`){t.toast.close(this);return}t.toast.show(this,typeof e==`object`?e:void 0)})}),e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.tabs&&(e.jQuery.fn.tabs=function(e,n){return this.each(function(){if(e===`select`&&n!==void 0){t.tabs.select(this,n);return}t.tabs.setup(this)})}),e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.popover&&(e.jQuery.fn.popover=function(e){return this.each(function(){if(e===`open`){t.popover.open(this);return}if(e===`close`){t.popover.close(this);return}if(e===`toggle`){t.popover.toggle(this);return}t.popover.setup(this)})}),e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.dragdrop&&(e.jQuery.fn.dragdrop=function(e){return this.each(function(){t.dragdrop.setup(this,e)})}),e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.multiselect&&(e.jQuery.fn.multiselect=function(e){return this.each(function(){if(e===`open`){t.multiselect.open(this);return}if(e===`close`){t.multiselect.close(this);return}if(e===`toggle`){t.multiselect.toggle(this);return}t.multiselect.setup(this)})}),e.jQuery&&e.jQuery.fn&&!e.jQuery.fn.pagination&&(e.jQuery.fn.pagination=function(e,n){return this.each(function(){if(e===`goTo`&&n!==void 0){t.pagination.goTo(this,n);return}if(e===`pageSize`&&n!==void 0){t.pagination.pageSize(this,n);return}if(e===`refresh`){t.pagination.refresh(this);return}t.pagination.setup(this,typeof e==`object`?e:void 0)})})}var m=[],h=new WeakMap,g=new WeakSet,_=new WeakSet,v=e=>typeof e.showModal==`function`,y=0,b=``,x=``,S=[`a[href]`,`button:not([disabled])`,`input:not([disabled])`,`select:not([disabled])`,`textarea:not([disabled])`,`[tabindex]:not([tabindex="-1"])`].join(`, `);function C(n){function i(n){return n?e(n)?i(n[0]):typeof n==`string`?document.querySelector(n):typeof HTMLDialogElement<`u`&&n instanceof HTMLDialogElement||t(n)&&n.nodeName===`DIALOG`?n:null:null}function a(e){return e.querySelector(`[autofocus], [data-modal-autofocus], `+S)}function o(e){let t=a(e);if(t){try{t.focus({preventScroll:!0})}catch{t.focus()}return}e.hasAttribute(`tabindex`)||e.setAttribute(`tabindex`,`-1`);try{e.focus({preventScroll:!0})}catch{e.focus()}}function s(){if(y>0){y+=1;return}b=document.body.style.overflow,x=document.documentElement.style.overflow,document.body.style.overflow=`hidden`,document.documentElement.style.overflow=`hidden`,y=1}function c(){y!==0&&(--y,!(y>0)&&(document.body.style.overflow=b,document.documentElement.style.overflow=x))}function l(e){let t=m.indexOf(e);t>=0&&m.splice(t,1)}function u(e){let t=h.get(e);if(t&&typeof t.focus==`function`&&document.contains(t))try{t.focus({preventScroll:!0})}catch{t.focus()}h.delete(e)}function d(e){let t=e.currentTarget;l(t),t.removeAttribute(`aria-modal`),u(t),g.has(t)&&(g.delete(t),c(),y===0&&document.removeEventListener(`keydown`,C))}function f(e,t=``){return e?(e.open&&(typeof e.close==`function`?e.close(t):(e.removeAttribute(`open`),d({currentTarget:e}))),e):null}function p(e){let t=e.currentTarget,n=r(e);if(n===t){f(t);return}n&&n.closest(`[data-modal-close]`)&&f(t)}function C(e){if(e.key!==`Escape`)return;let t=m[m.length-1];!t||!g.has(t)||(e.preventDefault(),f(t))}function w(e){_.has(e)||(_.add(e),e.addEventListener(`close`,d),e.addEventListener(`click`,p))}function T(e){if(!e)return null;if(w(e),e.open)return e;h.set(e,document.activeElement instanceof HTMLElement?document.activeElement:null),e.setAttribute(`aria-modal`,`true`);try{if(e.isConnected&&v(e))e.showModal();else throw Error(`dialog.showModal is unavailable`)}catch{e.setAttribute(`open`,``),g.add(e),s()}return m.includes(e)||m.push(e),o(e),g.has(e)&&document.addEventListener(`keydown`,C),e}function E(e){return e?e.open?f(e):T(e):null}n.modal={open(e){return T(i(e))},close(e,t){return f(i(e),t)},toggle(e){return E(i(e))}}}var w=new WeakSet,T=new WeakMap,E=`select[multiple][data-multiselect], select[multiple].multiselect-source`,D=0;function O(a){function o(r){if(!r)return null;if(e(r))return o(r[0]);if(typeof r==`string`)return o(document.querySelector(r));if(!t(r))return null;if(n(r)&&r.matches(`select[multiple]`))return r;let i=r.matches(`.multiselect`)?r:r.closest(`.multiselect`);return i&&n(i.previousElementSibling)?i.previousElementSibling:null}function s(e){return e.getAttribute(`data-placeholder`)||`Select options`}function c(e){let t=e.getAttribute(`aria-label`);if(t)return t;if(!e.id)return``;try{let t=document.querySelector(`label[for="`+CSS.escape(e.id)+`"]`);return t&&t.textContent?t.textContent.trim():``}catch{return``}}function l(e){return Array.from(e.options).filter(e=>e.selected)}function u(e){let t=l(e);return t.length===0?s(e):t.length<=2?t.map(e=>e.text).join(`, `):t.length+` selected`}function d(e){return Array.from(e.querySelectorAll(`.multiselect-option`))}function f(e){let t=T.get(e);return t?(t.label.textContent=u(e),t.options.forEach((t,n)=>{let r=e.options[n];t.setAttribute(`aria-selected`,r.selected?`true`:`false`),t.setAttribute(`aria-disabled`,r.disabled?`true`:`false`),t.disabled=r.disabled||e.disabled}),t.toggle.disabled=e.disabled,e):e}function p(e){if(!e)return null;let t=T.get(e);return t?(t.root.classList.remove(`is-open`),t.toggle.setAttribute(`aria-expanded`,`false`),e):e}function m(e){if(!e)return null;let t=T.get(e);return!t||e.disabled?e:(document.querySelectorAll(`.multiselect.is-open`).forEach(t=>{let r=t.previousElementSibling;n(r)&&r!==e&&p(r)}),t.root.classList.add(`is-open`),t.toggle.setAttribute(`aria-expanded`,`true`),e)}function h(e){if(!e)return null;let t=T.get(e);return t?t.root.classList.contains(`is-open`)?p(e):m(e):e}function g(e,t){let n=e.options[t];!n||n.disabled||e.disabled||(n.selected=!n.selected,f(e),e.dispatchEvent(new Event(`change`,{bubbles:!0})))}function _(e,t){let n=d(e).filter(e=>!e.disabled)[t];n&&n.focus()}function v(e){let t=o(i(e)),n=r(e),a=n?n.closest(`.multiselect-option`):null;if(t){if(a){g(t,Number(a.getAttribute(`data-index`)));return}n&&n.closest(`.multiselect-toggle`)&&h(t)}}function y(e){let t=o(i(e)),n=t?T.get(t):null,a=r(e);if(!n||!a||!t)return;if(e.key===`Escape`){p(t),n.toggle.focus();return}if(e.target===n.toggle){(e.key===`ArrowDown`||e.key===`Enter`||e.key===` `)&&(e.preventDefault(),m(t),_(n.root,0));return}let s=d(n.root).filter(e=>!e.disabled),c=s.indexOf(a);c<0||(e.key===`ArrowDown`?(e.preventDefault(),_(n.root,(c+1)%s.length)):e.key===`ArrowUp`?(e.preventDefault(),_(n.root,(c-1+s.length)%s.length)):e.key===`Home`?(e.preventDefault(),_(n.root,0)):e.key===`End`?(e.preventDefault(),_(n.root,s.length-1)):(e.key===`Enter`||e.key===` `)&&(e.preventDefault(),g(t,Number(a.getAttribute(`data-index`)))))}function b(e){let t=r(e);t&&document.querySelectorAll(`.multiselect.is-open`).forEach(e=>{e.contains(t)||p(n(e.previousElementSibling)?e.previousElementSibling:null)})}function x(e,t,n){let r=document.createElement(`button`);return r.className=`multiselect-option`,r.type=`button`,r.id=n+`-option-`+t,r.setAttribute(`role`,`option`),r.setAttribute(`data-index`,String(t)),r.textContent=e.text,r}function S(e){let t=o(e);if(!t||!t.matches(`select[multiple]`))return null;if(w.has(t))return f(t),t;let n=document.createElement(`div`),r=document.createElement(`button`),i=document.createElement(`span`),a=document.createElement(`div`),s=t.id||t.name||`multiselect-`+ ++D,l=s+`-menu`,u=Array.from(t.options).map((e,t)=>x(e,t,s));n.className=`multiselect`,r.className=`multiselect-toggle`,r.id=s+`-toggle`,r.type=`button`,r.setAttribute(`aria-expanded`,`false`),r.setAttribute(`aria-haspopup`,`listbox`),r.setAttribute(`aria-controls`,l),i.className=`multiselect-label`,a.className=`multiselect-menu`,a.id=l,a.setAttribute(`role`,`listbox`),a.setAttribute(`aria-multiselectable`,`true`);let d=c(t);if(d&&r.setAttribute(`aria-label`,d),r.append(i),u.length===0){let e=document.createElement(`div`);e.className=`multiselect-empty`,e.textContent=`No options`,a.append(e)}else u.forEach(e=>a.append(e));return n.append(r,a),t.classList.add(`multiselect-source`),t.after(n),T.set(t,{label:i,menu:a,options:u,root:n,toggle:r}),w.add(t),n.addEventListener(`click`,v),n.addEventListener(`keydown`,y),t.addEventListener(`change`,()=>f(t)),t.form&&t.form.addEventListener(`reset`,()=>{setTimeout(()=>f(t),0)}),f(t),t}a.multiselect={setup(e){return S(e)},open(e){return m(o(e))},close(e){return p(o(e))},toggle(e){return h(o(e))}},document.addEventListener(`DOMContentLoaded`,function(){document.querySelectorAll(E).forEach(S)}),document.addEventListener(`click`,b)}var k=new WeakSet,A=new WeakMap,j=new WeakMap,M=`[data-pagination], .pagination`;function N(o){function s(n){return n?e(n)?s(n[0]):typeof n==`string`?document.querySelector(n):t(n)?n.matches(M)?n:n.closest(M):null:null}function c(e,t){let n=Number(e);return Number.isFinite(n)&&n>0?n:t}function l(e,t){let n=t.pageSizes||e.getAttribute(`data-page-sizes`)||e.getAttribute(`data-page-size-options`),r=(Array.isArray(n)?n:String(n||`10,25,50`).split(`,`)).map(e=>c(e,0)).filter((e,t,n)=>e>0&&n.indexOf(e)===t);return r.length>0?r:[10,25,50]}function u(e,t){if(t.target)return typeof t.target==`string`?document.querySelector(t.target):t.target instanceof Element?t.target:null;let n=e.getAttribute(`data-target`);return n?document.querySelector(n):null}function d(e,t,n){if(typeof t.load==`function`)return t.load.call(e,{page:n.page,pageSize:n.pageSize,offset:(n.page-1)*n.pageSize});let r=Array.isArray(t.data)?t.data:[],i=(n.page-1)*n.pageSize;return{items:r.slice(i,i+n.pageSize),total:r.length}}function f(e,t){let n=Array.isArray(e)?{items:e,total:e.length}:e&&typeof e==`object`?e:{},r=Array.isArray(n.items)?n.items:[],i=c(n.total,r.length),a=Math.max(1,Math.ceil(i/t.pageSize));return{items:r,page:c(n.page,t.page),pageCount:a,pageSize:c(n.pageSize,t.pageSize),total:i}}function p(e,t,n,r){if(typeof n.renderItem==`function`)return n.renderItem(e,t,r);let i=document.createElement(`tr`);return(e&&typeof e==`object`?Object.values(e):[e]).forEach(e=>{let t=document.createElement(`td`);t.textContent=e==null?``:String(e),i.append(t)}),i}function m(e,t){let n=A.get(e)||{},r=n.target;r&&(r.replaceChildren(),t.items.forEach((e,i)=>{let a=p(e,i,n,t);typeof a==`string`?r.insertAdjacentHTML(`beforeend`,a):a&&r.append(a)}))}function h(e,t,n){let r=[];if(t<=n){for(let e=1;e<=t;e+=1)r.push(e);return r}r.push(1);let i=Math.max(1,Math.floor((n-3)/2)),a=Math.max(2,e-i),o=Math.min(t-1,e+i);a>2&&r.push(`ellipsis-start`);for(let e=a;e<=o;e+=1)r.push(e);return o<t-1&&r.push(`ellipsis-end`),r.push(t),r}function g(e,t,n){let r=document.createElement(`button`);return r.type=`button`,r.setAttribute(`data-pagination-action`,t),r.textContent=e,r.disabled=n,r}function _(e,t){let n=A.get(e)||{},r=t.pageCount,i=Math.min(t.page,r),a=c(n.maxPages,7),o=document.createElement(`span`),s=document.createElement(`span`),l=document.createElement(`span`),u=document.createElement(`label`),d=document.createElement(`select`);o.className=`pagination-summary`,o.textContent=`Page `+i+` of `+r+` (`+t.total+` items)`,s.className=`pagination-pages`,s.setAttribute(`role`,`group`),s.setAttribute(`aria-label`,`Pages`),s.append(g(`Previous`,`previous`,i<=1)),h(i,r,a).forEach(e=>{if(typeof e!=`number`){let e=document.createElement(`span`);e.className=`pagination-ellipsis`,e.setAttribute(`aria-hidden`,`true`),e.textContent=`...`,s.append(e);return}let t=g(String(e),`page`,!1);t.className=`pagination-page`,t.setAttribute(`data-pagination-page`,String(e)),t.setAttribute(`aria-label`,`Page `+e),e===i&&t.setAttribute(`aria-current`,`page`),s.append(t)}),s.append(g(`Next`,`next`,i>=r)),l.className=`pagination-size`,u.textContent=`Page size`,(n.pageSizes||[t.pageSize]).forEach(e=>{let n=document.createElement(`option`);n.value=String(e),n.textContent=String(e),n.selected=e===t.pageSize,d.append(n)}),d.setAttribute(`data-pagination-size`,``),u.append(d),l.append(u),e.replaceChildren(o,s,l)}function v(e,t){e.setAttribute(`aria-busy`,t?`true`:`false`),e.querySelectorAll(`button, select`).forEach(e=>{e.disabled=t})}function y(e,t,n,r){n===t.request&&(t.result?_(e,t.result):v(e,!1),e.dispatchEvent(new CustomEvent(`pagination:error`,{bubbles:!0,detail:{error:r}})))}function b(e){let t=e?A.get(e):null,n=e?j.get(e):null;if(!e||!t||!n)return e;n.request+=1;let r=n.request;v(e,!0);try{Promise.resolve(d(e,t,n)).then(t=>{if(r!==n.request)return;let i=f(t,n);n.page=Math.min(i.page,i.pageCount),n.pageSize=i.pageSize,n.result=i,m(e,i),_(e,i),e.dispatchEvent(new CustomEvent(`pagination:change`,{bubbles:!0,detail:i}))}).catch(t=>{y(e,n,r,t)})}catch(t){y(e,n,r,t)}return e}function x(e,t){let n=e?j.get(e):null;return n?(n.page=c(t,n.page),b(e)):null}function S(e,t){let n=e?j.get(e):null;return n?(n.page=1,n.pageSize=c(t,n.pageSize),b(e)):null}function C(e){let t=s(i(e)),n=r(e),a=n?n.closest(`[data-pagination-action]`):null,o=t?j.get(t):null;if(!a||!o||a.disabled)return;let c=a.getAttribute(`data-pagination-action`);c===`previous`?x(t,o.page-1):c===`next`?x(t,o.page+1):c===`page`&&x(t,a.getAttribute(`data-pagination-page`))}function w(e){let t=r(e),a=s(i(e));n(t)&&a&&t.matches(`[data-pagination-size]`)&&S(a,t.value)}function T(e,n={}){let r=s(e);if(!r)return null;let i=Object.assign({},A.get(r),n||{});i.target=u(r,i),i.pageSizes=l(r,i),i.pageSize=c(i.pageSize||r.getAttribute(`data-page-size`),i.pageSizes[0]),i.maxPages=c(i.maxPages||r.getAttribute(`data-max-pages`),7);let o={data:i.data,load:i.load,maxPages:i.maxPages,pageSize:i.pageSize,pageSizes:i.pageSizes,renderItem:i.renderItem,target:t(i.target)?i.target:null};if(A.set(r,o),j.has(r)){let e=j.get(r);e&&n.pageSize&&(e.page=1,e.pageSize=i.pageSize)}else j.set(r,{page:c(r.getAttribute(`data-page`),1),pageSize:i.pageSize,request:0});return k.has(r)||(k.add(r),a(r,`click`,C),a(r,`change`,w)),b(r),r}o.pagination={setup(e,t){return T(e,t)},goTo(e,t){return x(s(e),t)},pageSize(e,t){return S(s(e),t)},refresh(e){return b(s(e))}},document.addEventListener(`DOMContentLoaded`,function(){document.querySelectorAll(`[data-pagination]`).forEach(e=>{T(e)})})}var P=[`top`,`right`,`bottom`,`left`],F=new WeakSet,I=`[data-popover-target], [data-popover]`,L=null;function R(e){return typeof e==`string`&&P.includes(e)}function z(n){function o(n){return n?e(n)?o(n[0]):typeof n==`string`?document.querySelector(n):t(n)?n:null:null}function s(e){let t=o(e);return t?t.matches(I)?t:t.closest(I):null}function c(e){let t=o(e);if(!t)return null;if(t.matches(`.popover, [data-popover-content]`))return t;let n=s(t);return n?l(n):null}function l(e){let t=e.getAttribute(`data-popover-target`)||e.getAttribute(`data-popover`)||e.getAttribute(`aria-controls`);return t?t.charAt(0)===`#`?document.querySelector(t):document.getElementById(t):null}function u(e){let t=e.getAttribute(`data-popover-placement`);return R(t)?t:`bottom`}function d(e,t){let n=u(e),r=e.getBoundingClientRect(),i=t.getBoundingClientRect(),a=r.bottom+4,o=r.left;n===`top`?(a=r.top-i.height-4,o=r.left):n===`right`?(a=r.top,o=r.right+4):n===`left`&&(a=r.top,o=r.left-i.width-4),a=Math.max(8,Math.min(a,window.innerHeight-i.height-8)),o=Math.max(8,Math.min(o,window.innerWidth-i.width-8)),t.style.top=a+`px`,t.style.left=o+`px`}function f(e){let t=e||L,n=t?l(t):null;return!t||!n?null:(n.hidden=!0,t.setAttribute(`aria-expanded`,`false`),L===t&&(L=null),n)}function p(e){let t=e?l(e):null;return!e||!t?null:(L&&L!==e&&f(L),b(e),t.hidden=!1,e.setAttribute(`aria-expanded`,`true`),L=e,d(e,t),t)}function m(e){let t=e?l(e):null;return t?t.hidden?p(e):f(e):null}function h(e){e.preventDefault(),m(i(e))}function g(e){if(e.key!==`Escape`)return;let t=i(e);if(!t)return;let n=l(t);!n||n.hidden||(e.preventDefault(),f(t),t instanceof HTMLElement&&t.focus())}function _(e){if(!L)return;let t=r(e);if(!t)return;let n=l(L);L.contains(t)||n&&n.contains(t)||f(L)}function v(e){e.key!==`Escape`||!L||(e.preventDefault(),f(L))}function y(){if(!L)return;let e=l(L);e&&!e.hidden&&d(L,e)}function b(e){let t=l(e);return t?(!t.id&&e.getAttribute(`data-popover-target`)&&(t.id=(e.getAttribute(`data-popover-target`)||``).replace(/^#/,``)),e.setAttribute(`aria-haspopup`,`dialog`),e.setAttribute(`aria-expanded`,t.hidden?`false`:`true`),t.id&&e.setAttribute(`aria-controls`,t.id),t.hasAttribute(`role`)||t.setAttribute(`role`,`dialog`),F.has(e)||(F.add(e),a(e,`click`,h),a(e,`keydown`,g)),e):e}function x(e){let t=s(e);return t?b(t):null}n.popover={setup(e){return x(e)},open(e){return p(s(e))},close(e){let t=s(e);if(t)return f(t);let n=c(e);return n&&L&&l(L)===n?f(L):n},toggle(e){return m(s(e))}},document.addEventListener(`DOMContentLoaded`,function(){document.querySelectorAll(I).forEach(x)}),document.addEventListener(`click`,_),document.addEventListener(`keydown`,v),window.addEventListener(`resize`,y),window.addEventListener(`scroll`,y,!0)}var B=new WeakSet;function V(n){function o(n){return n?e(n)?o(n[0]):typeof n==`string`?document.querySelector(n):t(n)?n.matches(`[data-tabs], .tabs`)?n:n.closest(`[data-tabs], .tabs`):null:null}function s(e){let t=Array.from(e.children).find(e=>e.matches(`[role="tablist"], .tabs-list`));return t?Array.from(t.children).filter(e=>e.matches(`[role="tab"]`)):[]}function c(e){return Array.from(e.children).filter(e=>e.matches(`[role="tabpanel"]`))}function l(e,t){let n=t.getAttribute(`aria-controls`);if(!n)return null;try{return e.querySelector(`#`+CSS.escape(n))}catch{return document.getElementById(n)}}function u(e,t){let n=o(e);return!n||!e?null:(s(n).forEach(t=>{let r=t===e,i=l(n,t);t.setAttribute(`aria-selected`,r?`true`:`false`),t.setAttribute(`tabindex`,r?`0`:`-1`),i&&(i.hidden=!r)}),t&&e instanceof HTMLElement&&e.focus(),e)}function d(e,t,n){let r=s(e)[t];return r?u(r,n):null}function f(e){let t=r(e),n=t?t.closest(`[role="tab"]`):null;n&&u(n,!1)}function p(e){let t=o(i(e)),n=r(e);if(!t||!n)return;let a=s(t),c=a.indexOf(n);if(c<0)return;let l=c;if(e.key===`ArrowRight`||e.key===`ArrowDown`)l=(c+1)%a.length;else if(e.key===`ArrowLeft`||e.key===`ArrowUp`)l=(c-1+a.length)%a.length;else if(e.key===`Home`)l=0;else if(e.key===`End`)l=a.length-1;else return;e.preventDefault(),d(t,l,!0)}function m(e){let t=o(e);if(!t||B.has(t))return t;B.add(t),a(t,`click`,f),a(t,`keydown`,p);let n=s(t),r=n.find(e=>e.getAttribute(`aria-selected`)===`true`)||n[0];return c(t).forEach(e=>{e.hasAttribute(`tabindex`)||e.setAttribute(`tabindex`,`0`)}),r&&u(r,!1),t}n.tabs={setup(e){return m(e)},select(e,t){let n=o(e);return n?typeof t==`number`?d(n,t,!1):u(n.querySelector(t),!1):null}},document.addEventListener(`DOMContentLoaded`,function(){document.querySelectorAll(`[data-tabs], .tabs`).forEach(m)})}var H=[`light`,`dark`],U=`legacy.css.theme`;function W(e){function t(e){return typeof e==`string`&&H.includes(e)}function n(e){return t(e)?e:`light`}function r(){try{return window.localStorage.getItem(U)}catch{return null}}function i(e){try{window.localStorage.setItem(U,e)}catch{return}}function a(e,t=!0){let r=n(e);return document.documentElement.dataset.legacyTheme=r,t&&i(r),r}e.theme={apply(e){return a(e||r())},get(){return n(document.documentElement.dataset.legacyTheme||r())},set(e){return a(e)}},t(r())&&a(r(),!1)}var G=[`top-left`,`top-right`,`bottom-left`,`bottom-right`],K=new WeakMap;function q(e){return typeof e==`string`&&G.includes(e)}function J(n){function r(n){return n?e(n)?r(n[0]):typeof n==`string`?document.querySelector(n):t(n)&&n.matches(`.toast, [data-toast]`)?n:null:null}function i(e){return q(e)?e:`bottom-right`}function a(e){let t=i(e),n=document.querySelector(`[data-toast-region][data-position="`+t+`"], .toast-region[data-position="`+t+`"]`);return n||(n=document.createElement(`div`),n.className=`toast-region`,n.dataset.position=t,n.dataset.toastRegion=``,n.setAttribute(`aria-live`,`polite`),n.setAttribute(`aria-atomic`,`false`),document.body.append(n),n)}function o(t,n){return t&&typeof t==`object`&&!(`nodeType`in t)&&!(`jquery`in t)?Object.assign({},t):Object.assign({},n,{message:e(t)?t[0]:t})}function s(n){return n?e(n)?s(n[0]):typeof n==`string`?document.querySelector(n):t(n)?n:null:null}function c(e,t){let n=document.createElement(`div`);if(n.className=`toast-body`,t.title){let e=document.createElement(`strong`);e.className=`toast-title`,e.textContent=t.title,n.append(e)}if(t.message&&typeof t.message==`object`&&`nodeType`in t.message)n.append(t.message);else{let e=document.createElement(`span`);e.textContent=t.message||``,n.append(e)}e.append(n)}function l(e){if(!e)return null;let t=K.get(e);return t&&(window.clearTimeout(t),K.delete(e)),e.dispatchEvent(new CustomEvent(`toast:close`,{bubbles:!0})),e.remove(),e}function u(e,t){let n=o(e,t),r=n.type&&[`info`,`success`,`warning`,`danger`,`muted`].includes(n.type)?n.type:`info`,i=n.container?s(n.container):a(n.position),u=document.createElement(`section`),d=typeof n.duration==`number`?n.duration:5e3;if(!i)return null;if(u.className=`toast`,u.dataset.toast=``,u.setAttribute(`role`,r===`danger`?`alert`:`status`),r!==`info`&&u.classList.add(`toast-`+r),c(u,n),n.dismissible!==!1){let e=document.createElement(`button`);e.type=`button`,e.className=`toast-close`,e.setAttribute(`aria-label`,n.closeLabel||`Close notification`),e.textContent=n.closeText||`Close`,e.addEventListener(`click`,function(){l(u)}),u.append(e)}return i.append(u),u.dispatchEvent(new CustomEvent(`toast:show`,{bubbles:!0})),d>0&&K.set(u,window.setTimeout(function(){l(u)},d)),u}function d(e){let t=e?s(e):document,n=t?Array.from(t.querySelectorAll(`.toast, [data-toast]`)):[];return n.forEach(l),n}n.toast={show(e,t){return u(e,t)},close(e){return l(r(e))},clear(e){return d(e)}}}(function(){let e=window;e.LegacyCss||={};let t=e.LegacyCss;W(t),C(t),J(t),z(t),V(t),f(t),O(t),N(t),p(e,t)})()})();
|
package/mcp/server.js
ADDED
|
@@ -0,0 +1,524 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
import { readFile } from "node:fs/promises";
|
|
4
|
+
import { dirname, join, relative } from "node:path";
|
|
5
|
+
import { fileURLToPath } from "node:url";
|
|
6
|
+
|
|
7
|
+
const root = dirname(dirname(fileURLToPath(import.meta.url)));
|
|
8
|
+
const srcDir = join(root, "src");
|
|
9
|
+
|
|
10
|
+
const cssModules = [
|
|
11
|
+
"variables.css",
|
|
12
|
+
"base.css",
|
|
13
|
+
"typography.css",
|
|
14
|
+
"lists.css",
|
|
15
|
+
"forms.css",
|
|
16
|
+
"multiselect.css",
|
|
17
|
+
"buttons.css",
|
|
18
|
+
"toolbars.css",
|
|
19
|
+
"tables.css",
|
|
20
|
+
"navigation.css",
|
|
21
|
+
"pagination.css",
|
|
22
|
+
"panels.css",
|
|
23
|
+
"modal.css",
|
|
24
|
+
"popover.css",
|
|
25
|
+
"tabs.css",
|
|
26
|
+
"dragdrop.css",
|
|
27
|
+
"progress.css",
|
|
28
|
+
"alerts.css",
|
|
29
|
+
"toast.css",
|
|
30
|
+
"badges.css",
|
|
31
|
+
"utilities.css",
|
|
32
|
+
];
|
|
33
|
+
|
|
34
|
+
const snippets = {
|
|
35
|
+
form: {
|
|
36
|
+
title: "Administrative form",
|
|
37
|
+
html: `<main class="container">
|
|
38
|
+
<h1>Fornecedor</h1>
|
|
39
|
+
|
|
40
|
+
<form>
|
|
41
|
+
<fieldset>
|
|
42
|
+
<legend>Dados cadastrais</legend>
|
|
43
|
+
|
|
44
|
+
<label for="name">Nome</label>
|
|
45
|
+
<input id="name" name="name" type="text">
|
|
46
|
+
|
|
47
|
+
<label for="status">Status</label>
|
|
48
|
+
<select id="status" name="status">
|
|
49
|
+
<option>Ativo</option>
|
|
50
|
+
<option>Inativo</option>
|
|
51
|
+
</select>
|
|
52
|
+
</fieldset>
|
|
53
|
+
|
|
54
|
+
<button type="submit">Salvar</button>
|
|
55
|
+
<button type="reset">Limpar</button>
|
|
56
|
+
</form>
|
|
57
|
+
</main>`,
|
|
58
|
+
},
|
|
59
|
+
table: {
|
|
60
|
+
title: "Data table",
|
|
61
|
+
html: `<table>
|
|
62
|
+
<caption>Pedidos recentes</caption>
|
|
63
|
+
<thead>
|
|
64
|
+
<tr>
|
|
65
|
+
<th scope="col">Pedido</th>
|
|
66
|
+
<th scope="col">Cliente</th>
|
|
67
|
+
<th scope="col">Status</th>
|
|
68
|
+
</tr>
|
|
69
|
+
</thead>
|
|
70
|
+
<tbody>
|
|
71
|
+
<tr>
|
|
72
|
+
<td>1001</td>
|
|
73
|
+
<td>Acme Ltda.</td>
|
|
74
|
+
<td><span class="badge success">Aprovado</span></td>
|
|
75
|
+
</tr>
|
|
76
|
+
</tbody>
|
|
77
|
+
</table>`,
|
|
78
|
+
},
|
|
79
|
+
panel: {
|
|
80
|
+
title: "Panel with alert",
|
|
81
|
+
html: `<section class="panel">
|
|
82
|
+
<header class="panel-header">
|
|
83
|
+
<h2>Resumo</h2>
|
|
84
|
+
</header>
|
|
85
|
+
<div class="panel-body">
|
|
86
|
+
<p class="alert info">A rotina foi executada com sucesso.</p>
|
|
87
|
+
</div>
|
|
88
|
+
</section>`,
|
|
89
|
+
},
|
|
90
|
+
tabs: {
|
|
91
|
+
title: "Tabs",
|
|
92
|
+
html: `<div class="tabs" data-tabs>
|
|
93
|
+
<div class="tab-list" role="tablist">
|
|
94
|
+
<button type="button" role="tab" aria-selected="true">Geral</button>
|
|
95
|
+
<button type="button" role="tab">Histórico</button>
|
|
96
|
+
</div>
|
|
97
|
+
<section class="tab-panel" role="tabpanel">
|
|
98
|
+
<h2>Geral</h2>
|
|
99
|
+
<p>Dados principais do registro.</p>
|
|
100
|
+
</section>
|
|
101
|
+
<section class="tab-panel" role="tabpanel" hidden>
|
|
102
|
+
<h2>Histórico</h2>
|
|
103
|
+
<p>Eventos recentes do registro.</p>
|
|
104
|
+
</section>
|
|
105
|
+
</div>`,
|
|
106
|
+
},
|
|
107
|
+
progress: {
|
|
108
|
+
title: "Progress and loading",
|
|
109
|
+
html: `<label for="case-progress">Progresso</label>
|
|
110
|
+
<progress id="case-progress" value="62" max="100">62%</progress>
|
|
111
|
+
<small class="progress-label">62% concluído</small>
|
|
112
|
+
|
|
113
|
+
<div class="progress progress-loading" role="progressbar" aria-label="Carregando" aria-valuetext="Carregando">
|
|
114
|
+
<span class="progress-bar"></span>
|
|
115
|
+
</div>`,
|
|
116
|
+
},
|
|
117
|
+
toast: {
|
|
118
|
+
title: "Toast notification",
|
|
119
|
+
html: `<button type="button" onclick="LegacyCss.toast.show({ title: 'Salvo', message: 'Registro atualizado.', type: 'success', position: 'top-right' })">
|
|
120
|
+
Mostrar notificação
|
|
121
|
+
</button>`,
|
|
122
|
+
},
|
|
123
|
+
popover: {
|
|
124
|
+
title: "Popover",
|
|
125
|
+
html: `<button type="button" data-popover-target="#actions-popover">
|
|
126
|
+
Mostrar ações
|
|
127
|
+
</button>
|
|
128
|
+
|
|
129
|
+
<div class="popover" id="actions-popover" hidden aria-labelledby="actions-popover-title">
|
|
130
|
+
<header id="actions-popover-title">Ações</header>
|
|
131
|
+
<p>Escolha a próxima etapa administrativa.</p>
|
|
132
|
+
<div class="popover-actions">
|
|
133
|
+
<button type="button">Atribuir</button>
|
|
134
|
+
<button type="button">Arquivar</button>
|
|
135
|
+
</div>
|
|
136
|
+
</div>`,
|
|
137
|
+
},
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
const resourceMap = new Map([
|
|
141
|
+
[
|
|
142
|
+
"legacy://readme",
|
|
143
|
+
{
|
|
144
|
+
name: "legacy.css README",
|
|
145
|
+
description: "Project overview, usage, scripts, and philosophy.",
|
|
146
|
+
path: join(root, "README.md"),
|
|
147
|
+
mimeType: "text/markdown",
|
|
148
|
+
},
|
|
149
|
+
],
|
|
150
|
+
[
|
|
151
|
+
"legacy://css/entry",
|
|
152
|
+
{
|
|
153
|
+
name: "CSS entry point",
|
|
154
|
+
description: "The source entry point that imports all CSS modules in order.",
|
|
155
|
+
path: join(srcDir, "legacy.css"),
|
|
156
|
+
mimeType: "text/css",
|
|
157
|
+
},
|
|
158
|
+
],
|
|
159
|
+
[
|
|
160
|
+
"legacy://css/dist",
|
|
161
|
+
{
|
|
162
|
+
name: "Built CSS",
|
|
163
|
+
description: "The bundled stylesheet generated from src/legacy.css.",
|
|
164
|
+
path: join(root, "dist", "legacy.css"),
|
|
165
|
+
mimeType: "text/css",
|
|
166
|
+
},
|
|
167
|
+
],
|
|
168
|
+
]);
|
|
169
|
+
|
|
170
|
+
for (const moduleName of cssModules) {
|
|
171
|
+
resourceMap.set(`legacy://css/module/${moduleName}`, {
|
|
172
|
+
name: moduleName,
|
|
173
|
+
description: `Source CSS module: ${moduleName}`,
|
|
174
|
+
path: join(srcDir, moduleName),
|
|
175
|
+
mimeType: "text/css",
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
function writeMessage(message) {
|
|
180
|
+
const body = JSON.stringify(message);
|
|
181
|
+
process.stdout.write(`Content-Length: ${Buffer.byteLength(body)}\r\n\r\n${body}`);
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
function result(id, value) {
|
|
185
|
+
writeMessage({ jsonrpc: "2.0", id, result: value });
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
function error(id, code, message) {
|
|
189
|
+
writeMessage({ jsonrpc: "2.0", id, error: { code, message } });
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
function textContent(text) {
|
|
193
|
+
return {
|
|
194
|
+
content: [
|
|
195
|
+
{
|
|
196
|
+
type: "text",
|
|
197
|
+
text,
|
|
198
|
+
},
|
|
199
|
+
],
|
|
200
|
+
};
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
async function readProjectFile(path) {
|
|
204
|
+
return readFile(path, "utf8");
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
async function getModule(moduleName) {
|
|
208
|
+
if (!cssModules.includes(moduleName)) {
|
|
209
|
+
throw new Error(
|
|
210
|
+
`Unknown CSS module "${moduleName}". Use list_css_modules to inspect valid modules.`,
|
|
211
|
+
);
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
return readProjectFile(join(srcDir, moduleName));
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
function extractTokens(css) {
|
|
218
|
+
return Array.from(
|
|
219
|
+
css.matchAll(/--legacy-[\w-]+:\s*([^;]+);/g),
|
|
220
|
+
([match, value]) => {
|
|
221
|
+
const name = match.slice(0, match.indexOf(":"));
|
|
222
|
+
return { name, value: value.trim() };
|
|
223
|
+
},
|
|
224
|
+
);
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
function extractSelectors(css) {
|
|
228
|
+
return Array.from(css.matchAll(/(^|\n)([^@{}\n][^{}]+)\s*\{/g), ([, , raw]) =>
|
|
229
|
+
raw
|
|
230
|
+
.split(",")
|
|
231
|
+
.map((selector) => selector.trim())
|
|
232
|
+
.filter(Boolean),
|
|
233
|
+
).flat();
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
async function searchCss(query) {
|
|
237
|
+
const normalizedQuery = query.toLowerCase();
|
|
238
|
+
const matches = [];
|
|
239
|
+
|
|
240
|
+
for (const moduleName of cssModules) {
|
|
241
|
+
const css = await getModule(moduleName);
|
|
242
|
+
const lines = css.split("\n");
|
|
243
|
+
|
|
244
|
+
lines.forEach((line, index) => {
|
|
245
|
+
if (line.toLowerCase().includes(normalizedQuery)) {
|
|
246
|
+
matches.push({
|
|
247
|
+
module: moduleName,
|
|
248
|
+
line: index + 1,
|
|
249
|
+
text: line.trim(),
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
});
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
return matches;
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
function listTools() {
|
|
259
|
+
return [
|
|
260
|
+
{
|
|
261
|
+
name: "list_css_modules",
|
|
262
|
+
description: "List source CSS modules in import order.",
|
|
263
|
+
inputSchema: {
|
|
264
|
+
type: "object",
|
|
265
|
+
properties: {},
|
|
266
|
+
},
|
|
267
|
+
},
|
|
268
|
+
{
|
|
269
|
+
name: "get_css_module",
|
|
270
|
+
description: "Read a source CSS module by filename, for example buttons.css.",
|
|
271
|
+
inputSchema: {
|
|
272
|
+
type: "object",
|
|
273
|
+
properties: {
|
|
274
|
+
module: {
|
|
275
|
+
type: "string",
|
|
276
|
+
description: "CSS module filename from list_css_modules.",
|
|
277
|
+
},
|
|
278
|
+
},
|
|
279
|
+
required: ["module"],
|
|
280
|
+
},
|
|
281
|
+
},
|
|
282
|
+
{
|
|
283
|
+
name: "get_design_tokens",
|
|
284
|
+
description: "Return CSS custom properties defined by legacy.css.",
|
|
285
|
+
inputSchema: {
|
|
286
|
+
type: "object",
|
|
287
|
+
properties: {},
|
|
288
|
+
},
|
|
289
|
+
},
|
|
290
|
+
{
|
|
291
|
+
name: "search_css",
|
|
292
|
+
description: "Search legacy.css source modules for selectors, properties, or token names.",
|
|
293
|
+
inputSchema: {
|
|
294
|
+
type: "object",
|
|
295
|
+
properties: {
|
|
296
|
+
query: {
|
|
297
|
+
type: "string",
|
|
298
|
+
description: "Case-insensitive search query.",
|
|
299
|
+
},
|
|
300
|
+
},
|
|
301
|
+
required: ["query"],
|
|
302
|
+
},
|
|
303
|
+
},
|
|
304
|
+
{
|
|
305
|
+
name: "usage_snippet",
|
|
306
|
+
description: "Return a semantic HTML snippet styled by legacy.css.",
|
|
307
|
+
inputSchema: {
|
|
308
|
+
type: "object",
|
|
309
|
+
properties: {
|
|
310
|
+
pattern: {
|
|
311
|
+
type: "string",
|
|
312
|
+
enum: Object.keys(snippets),
|
|
313
|
+
description: "Snippet pattern to return.",
|
|
314
|
+
},
|
|
315
|
+
},
|
|
316
|
+
required: ["pattern"],
|
|
317
|
+
},
|
|
318
|
+
},
|
|
319
|
+
];
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
async function callTool(name, args = {}) {
|
|
323
|
+
switch (name) {
|
|
324
|
+
case "list_css_modules":
|
|
325
|
+
return textContent(cssModules.join("\n"));
|
|
326
|
+
|
|
327
|
+
case "get_css_module": {
|
|
328
|
+
const css = await getModule(args.module);
|
|
329
|
+
return textContent(css);
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
case "get_design_tokens": {
|
|
333
|
+
const css = await getModule("variables.css");
|
|
334
|
+
return textContent(JSON.stringify(extractTokens(css), null, 2));
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
case "search_css": {
|
|
338
|
+
if (!args.query) {
|
|
339
|
+
throw new Error("search_css requires a query argument.");
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
const matches = await searchCss(args.query);
|
|
343
|
+
return textContent(JSON.stringify(matches, null, 2));
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
case "usage_snippet": {
|
|
347
|
+
const snippet = snippets[args.pattern];
|
|
348
|
+
|
|
349
|
+
if (!snippet) {
|
|
350
|
+
throw new Error(
|
|
351
|
+
`Unknown snippet pattern "${args.pattern}". Expected one of: ${Object.keys(
|
|
352
|
+
snippets,
|
|
353
|
+
).join(", ")}.`,
|
|
354
|
+
);
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
return textContent(`${snippet.title}\n\n${snippet.html}`);
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
default:
|
|
361
|
+
throw new Error(`Unknown tool "${name}".`);
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
async function handleRequest(message) {
|
|
366
|
+
const { id, method, params } = message;
|
|
367
|
+
|
|
368
|
+
if (method === "initialize") {
|
|
369
|
+
result(id, {
|
|
370
|
+
protocolVersion: params?.protocolVersion ?? "2024-11-05",
|
|
371
|
+
capabilities: {
|
|
372
|
+
resources: {},
|
|
373
|
+
tools: {},
|
|
374
|
+
},
|
|
375
|
+
serverInfo: {
|
|
376
|
+
name: "legacy-css-mcp",
|
|
377
|
+
version: "0.1.0",
|
|
378
|
+
},
|
|
379
|
+
});
|
|
380
|
+
return;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
if (method === "notifications/initialized") {
|
|
384
|
+
return;
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
if (method === "tools/list") {
|
|
388
|
+
result(id, { tools: listTools() });
|
|
389
|
+
return;
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
if (method === "tools/call") {
|
|
393
|
+
const toolResult = await callTool(params?.name, params?.arguments ?? {});
|
|
394
|
+
result(id, toolResult);
|
|
395
|
+
return;
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
if (method === "resources/list") {
|
|
399
|
+
result(id, {
|
|
400
|
+
resources: Array.from(resourceMap, ([uri, resource]) => ({
|
|
401
|
+
uri,
|
|
402
|
+
name: resource.name,
|
|
403
|
+
description: resource.description,
|
|
404
|
+
mimeType: resource.mimeType,
|
|
405
|
+
})),
|
|
406
|
+
});
|
|
407
|
+
return;
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
if (method === "resources/read") {
|
|
411
|
+
const resource = resourceMap.get(params?.uri);
|
|
412
|
+
|
|
413
|
+
if (!resource) {
|
|
414
|
+
throw new Error(`Unknown resource URI "${params?.uri}".`);
|
|
415
|
+
}
|
|
416
|
+
|
|
417
|
+
result(id, {
|
|
418
|
+
contents: [
|
|
419
|
+
{
|
|
420
|
+
uri: params.uri,
|
|
421
|
+
mimeType: resource.mimeType,
|
|
422
|
+
text: await readProjectFile(resource.path),
|
|
423
|
+
},
|
|
424
|
+
],
|
|
425
|
+
});
|
|
426
|
+
return;
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
if (method === "prompts/list") {
|
|
430
|
+
result(id, { prompts: [] });
|
|
431
|
+
return;
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
if (method === "ping") {
|
|
435
|
+
result(id, {});
|
|
436
|
+
return;
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
error(id, -32601, `Method not found: ${method}`);
|
|
440
|
+
}
|
|
441
|
+
|
|
442
|
+
function parseContentLengthMessages(buffer) {
|
|
443
|
+
const messages = [];
|
|
444
|
+
|
|
445
|
+
while (buffer.toString("utf8", 0, 15) === "Content-Length:") {
|
|
446
|
+
const text = buffer.toString("utf8");
|
|
447
|
+
const headerEnd = buffer.indexOf("\r\n\r\n");
|
|
448
|
+
|
|
449
|
+
if (headerEnd === -1) {
|
|
450
|
+
break;
|
|
451
|
+
}
|
|
452
|
+
|
|
453
|
+
const header = text.slice(0, headerEnd);
|
|
454
|
+
const length = Number(header.match(/Content-Length:\s*(\d+)/i)?.[1]);
|
|
455
|
+
const bodyStart = headerEnd + 4;
|
|
456
|
+
|
|
457
|
+
if (!Number.isFinite(length) || buffer.length < bodyStart + length) {
|
|
458
|
+
break;
|
|
459
|
+
}
|
|
460
|
+
|
|
461
|
+
const body = buffer.toString("utf8", bodyStart, bodyStart + length);
|
|
462
|
+
messages.push(JSON.parse(body));
|
|
463
|
+
buffer = buffer.slice(bodyStart + length);
|
|
464
|
+
}
|
|
465
|
+
|
|
466
|
+
return { messages, buffer };
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
async function dispatch(raw, framedMessage) {
|
|
470
|
+
if (!framedMessage && !raw.trim()) {
|
|
471
|
+
return;
|
|
472
|
+
}
|
|
473
|
+
|
|
474
|
+
try {
|
|
475
|
+
await handleRequest(framedMessage ?? JSON.parse(raw));
|
|
476
|
+
} catch (caught) {
|
|
477
|
+
const parsed = framedMessage ?? JSON.parse(raw);
|
|
478
|
+
error(parsed.id ?? null, -32000, caught.message);
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
if (process.argv.includes("--self-test")) {
|
|
483
|
+
const variables = await getModule("variables.css");
|
|
484
|
+
const selectors = extractSelectors(await getModule("buttons.css"));
|
|
485
|
+
|
|
486
|
+
process.stdout.write(
|
|
487
|
+
JSON.stringify(
|
|
488
|
+
{
|
|
489
|
+
modules: cssModules.length,
|
|
490
|
+
tokens: extractTokens(variables).length,
|
|
491
|
+
buttonSelectors: selectors.length,
|
|
492
|
+
root: relative(process.cwd(), root) || ".",
|
|
493
|
+
},
|
|
494
|
+
null,
|
|
495
|
+
2,
|
|
496
|
+
),
|
|
497
|
+
);
|
|
498
|
+
process.stdout.write("\n");
|
|
499
|
+
} else {
|
|
500
|
+
let buffer = Buffer.alloc(0);
|
|
501
|
+
process.stdin.on("data", (chunk) => {
|
|
502
|
+
buffer = Buffer.concat([buffer, chunk]);
|
|
503
|
+
|
|
504
|
+
if (buffer.toString("utf8", 0, 15) === "Content-Length:") {
|
|
505
|
+
const parsed = parseContentLengthMessages(buffer);
|
|
506
|
+
buffer = parsed.buffer;
|
|
507
|
+
|
|
508
|
+
for (const message of parsed.messages) {
|
|
509
|
+
dispatch("", message);
|
|
510
|
+
}
|
|
511
|
+
|
|
512
|
+
return;
|
|
513
|
+
}
|
|
514
|
+
|
|
515
|
+
let newlineIndex = buffer.indexOf("\n");
|
|
516
|
+
|
|
517
|
+
while (newlineIndex !== -1) {
|
|
518
|
+
const raw = buffer.toString("utf8", 0, newlineIndex).trim();
|
|
519
|
+
buffer = buffer.slice(newlineIndex + 1);
|
|
520
|
+
dispatch(raw);
|
|
521
|
+
newlineIndex = buffer.indexOf("\n");
|
|
522
|
+
}
|
|
523
|
+
});
|
|
524
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "legacy.css",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "A classless CSS framework inspired by classic corporate administrative systems.",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"author": "Moises Duarte",
|
|
7
|
+
"packageManager": "pnpm@10.12.1",
|
|
8
|
+
"type": "module",
|
|
9
|
+
"main": "dist/legacy.css",
|
|
10
|
+
"style": "dist/legacy.css",
|
|
11
|
+
"bin": {
|
|
12
|
+
"legacy-css-mcp": "./mcp/server.js"
|
|
13
|
+
},
|
|
14
|
+
"files": [
|
|
15
|
+
"dist",
|
|
16
|
+
"mcp",
|
|
17
|
+
"src",
|
|
18
|
+
"README.md",
|
|
19
|
+
"LICENSE"
|
|
20
|
+
],
|
|
21
|
+
"scripts": {
|
|
22
|
+
"lint": "stylelint \"src/**/*.css\"",
|
|
23
|
+
"mcp": "node mcp/server.js",
|
|
24
|
+
"test": "pnpm run test:unit",
|
|
25
|
+
"test:unit": "vitest run",
|
|
26
|
+
"test:unit:coverage": "vitest run --coverage",
|
|
27
|
+
"typecheck": "tsc --noEmit",
|
|
28
|
+
"build": "lightningcss --bundle src/legacy.css -o dist/legacy.css",
|
|
29
|
+
"build:min": "lightningcss --bundle --minify src/legacy.css -o dist/legacy.min.css",
|
|
30
|
+
"build:js": "mkdir -p dist && vite build --mode development && vite build",
|
|
31
|
+
"build:all": "pnpm run build && pnpm run build:min && pnpm run build:js",
|
|
32
|
+
"build:docs": "pnpm run build:all && mkdir -p docs/assets && cp dist/legacy.css docs/assets/legacy.css && cp dist/legacy.min.css docs/assets/legacy.min.css && cp dist/legacy.js docs/assets/legacy.js && cp dist/legacy.min.js docs/assets/legacy.min.js",
|
|
33
|
+
"watch": "lightningcss --bundle --watch src/legacy.css -o dist/legacy.css"
|
|
34
|
+
},
|
|
35
|
+
"keywords": [
|
|
36
|
+
"css",
|
|
37
|
+
"classless",
|
|
38
|
+
"framework",
|
|
39
|
+
"semantic-html",
|
|
40
|
+
"admin"
|
|
41
|
+
],
|
|
42
|
+
"devDependencies": {
|
|
43
|
+
"@vitest/coverage-v8": "^4.1.8",
|
|
44
|
+
"jsdom": "^29.1.1",
|
|
45
|
+
"lightningcss-cli": "^1.30.1",
|
|
46
|
+
"stylelint": "^16.19.1",
|
|
47
|
+
"stylelint-config-standard": "^38.0.0",
|
|
48
|
+
"typescript": "^6.0.3",
|
|
49
|
+
"vite": "^8.0.16",
|
|
50
|
+
"vitest": "^4.1.8"
|
|
51
|
+
}
|
|
52
|
+
}
|