@yungu-fed/class-student-roster 0.0.2 → 0.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs.js CHANGED
@@ -1,4 +1,14 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var o=require("react");function _(m){return m&&typeof m=="object"&&"default"in m?m:{default:m}}var $=_(o);const ee="_iconfont_zvw5p_7",se="_csrMask_zvw5p_14",te="_csrModal_zvw5p_24",ce="_csrHeader_zvw5p_34",re="_csrTitle_zvw5p_44",ne="_csrClose_zvw5p_50",ae="_csrBody_zvw5p_62",de="_csrPanel_zvw5p_69",ie="_csrPanelHeader_zvw5p_81",Ae="_csrSearch_zvw5p_86",ue="_csrSearchIcon_zvw5p_102",me="_csrTree_zvw5p_113",oe="_csrTreeItem_zvw5p_118",le="_csrTreeItemText_zvw5p_135",he="_csrMeta_zvw5p_138",fe="_csrTreeItemActive_zvw5p_142",we="_csrTreeChildren_zvw5p_151",Ie="_csrList_zvw5p_154",ve="_csrListItem_zvw5p_161",Ce="_csrOps_zvw5p_185",Le="_hasSelected_zvw5p_196",pe="_clearBtn_zvw5p_201",ge="_csrChipWrap_zvw5p_205",ze="_csrChipList_zvw5p_210",Ee="_deleteIcon_zvw5p_218",Ne="_csrChip_zvw5p_205",Be="_csrFooter_zvw5p_238",Fe="_csrBtn_zvw5p_245",Me="_csrBtnPrimary_zvw5p_254",Pe="_csrBtnCancel_zvw5p_259",Ze="_csrEmpty_zvw5p_264",be="_csrCheck_zvw5p_279",We="_csrCheckLabel_zvw5p_289";var t={iconfont:ee,csrMask:se,csrModal:te,csrHeader:ce,csrTitle:re,csrClose:ne,csrBody:ae,csrPanel:de,csrPanelHeader:ie,csrSearch:Ae,csrSearchIcon:ue,csrTree:me,csrTreeItem:oe,csrTreeItemText:le,csrMeta:he,csrTreeItemActive:fe,csrTreeChildren:we,csrList:Ie,csrListItem:ve,csrOps:Ce,hasSelected:Le,clearBtn:pe,csrChipWrap:ge,csrChipList:ze,deleteIcon:Ee,csrChip:Ne,csrFooter:Be,csrBtn:Fe,csrBtnPrimary:Me,csrBtnCancel:Pe,csrEmpty:Ze,csrCheck:be,csrCheckLabel:We},Q="",S={exports:{}},W={};/**
1
+ const __CSR_CSS__ = "@font-face{font-family:iconfont;src:url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff2?t=1766568844647) format(\"woff2\"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff?t=1766568844647) format(\"woff\"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.ttf?t=1766568844647) format(\"truetype\")}._iconfont_15jnl_7{font-family:iconfont!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}._csrMask_15jnl_14{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;font-family:PingFangSC-Regular}._csrModal_15jnl_24{width:980px;background:#fff;border-radius:11px;box-shadow:0 12px 40px #00000029;display:flex;flex-direction:column;overflow:hidden;font-family:PingFangSC-Regular}._csrHeader_15jnl_34{height:56px;min-height:56px;padding:0 12px;border-bottom:1px solid #E6E7EC;display:flex;align-items:center;justify-content:center;position:relative}._csrTitle_15jnl_44{margin:0;font-size:16px;font-weight:600;color:#01113d}._csrClose_15jnl_50{position:absolute;right:16px;top:50%;border:none;background:transparent;font-size:18px;cursor:pointer;color:#27355a;font-weight:600;margin-top:-9px}._csrBody_15jnl_62{flex:1;overflow:hidden;display:flex;background:#f5f6f7;padding:12px}._csrPanel_15jnl_69{background:#fff;border-radius:11px;display:flex;flex-direction:column;min-height:0;flex:1;height:450px}._csrPanel_15jnl_69:nth-child(2){margin:0 10px}._csrPanelHeader_15jnl_81{padding:12px 12px 8px;font-weight:600;color:#333}._csrSearch_15jnl_86{padding:10px 12px;display:flex;align-items:center;position:relative;border-bottom:1px solid #E6E7EC}._csrSearch_15jnl_86 input{padding:9px 30px 9px 10px;border-radius:7px;border:1px solid #E6E7EC;font-size:14px;width:100%;z-index:1;position:relative}._csrSearch_15jnl_86 ._csrSearchIcon_15jnl_102{position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:14px;color:#5a6481;font-weight:600;z-index:2;cursor:pointer}._csrTree_15jnl_113{flex:1;overflow:auto;padding:10px 12px}._csrTreeItem_15jnl_118{display:flex;align-items:center;padding:6px 8px 6px 2px;border-radius:4px;cursor:pointer;color:#01113d;font-size:14px;font-family:PingFangSC-Regular;position:relative;margin-bottom:8px;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}._csrTreeItem_15jnl_118:hover{background:rgba(4,69,252,.06);transform:translate(2px)}._csrTreeItem_15jnl_118 ._csrTreeItemText_15jnl_135{padding-right:32px}._csrTreeItem_15jnl_118 ._csrMeta_15jnl_138{position:absolute;right:11px}._csrTreeItemActive_15jnl_142{background:rgba(4,69,252,.05);border-radius:2px;transform:translate(4px)}._csrTreeItemActive_15jnl_142 span{color:#0445fc;font-weight:500}._csrTreeChildren_15jnl_151{padding-left:22px}._csrList_15jnl_154{list-style:none;margin:0;padding:10px 12px 12px;flex:1;overflow:auto}._csrList_15jnl_154 ._csrListItem_15jnl_161{display:flex;align-items:center;font-size:14px;font-family:PingFangSC-Regular;padding:8px 4px;margin-bottom:4px;border-radius:4px;color:#01113d;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}._csrList_15jnl_154 ._csrListItemDisabled_15jnl_172{opacity:.55;cursor:not-allowed}._csrList_15jnl_154 ._csrListItem_15jnl_161:hover{background:rgba(4,69,252,.05);transform:translate(2px)}._csrList_15jnl_154 ._csrListItemDisabled_15jnl_172:hover{background:transparent;transform:none}._csrList_15jnl_154 ._csrListItem_15jnl_161:last-child{border-bottom:none}._csrMeta_15jnl_138{display:flex;align-items:center;gap:6px;font-size:12px;color:#666}._csrOps_15jnl_194{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:56px;font-size:14px;color:#01113d;font-family:PingFangSC-Regular;border-bottom:1px solid #E6E7EC}._csrOps_15jnl_194 ._hasSelected_15jnl_205{font-size:14px;font-weight:500;color:#01113d}._csrOps_15jnl_194 ._clearBtn_15jnl_210{color:#0445fc;cursor:pointer}._csrChipWrap_15jnl_214{flex:1;overflow:auto;padding:10px 12px 12px}._csrChipList_15jnl_219{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}._csrChipList_15jnl_219 ._deleteIcon_15jnl_227{margin-left:8px;cursor:pointer;font-size:14px}._csrChipList_15jnl_219 ._deleteIconDisabled_15jnl_232{cursor:not-allowed;opacity:.45}._csrChip_15jnl_214{display:inline-flex;align-items:center;background:#F2F3F5;border-radius:4px;padding:4px 10px;font-size:12px;color:#01113d}._csrChip_15jnl_214 button{border:none;background:transparent;cursor:pointer;color:#666}._csrFooter_15jnl_251{border-top:1px solid #f0f0f0;padding:12px 16px;display:flex;justify-content:flex-end;gap:12px}._csrBtn_15jnl_258{min-width:76px;height:32px;border-radius:7px;cursor:pointer;border:1px solid #d9d9d9;background:#fff;font-size:14px}._csrBtnPrimary_15jnl_267{background:#0445FC;border-color:#0445fc;color:#fff}._csrBtnCancel_15jnl_272{background:#EDEEF1;border-color:#edeef1;color:#01113d}._csrEmpty_15jnl_277{color:#01113da6;padding:8px 12px;font-size:13px;display:flex;align-items:center;justify-content:center;flex-direction:column;height:80%}._csrEmpty_15jnl_277 img{width:120px;height:120px;margin-bottom:12px}._csrCheck_15jnl_292{margin-right:8px;width:14px;height:14px;accent-color:#0445FC;transition:transform .12s ease}._csrCheck_15jnl_292:active{transform:scale(.9)}._csrCheck_15jnl_292:disabled{cursor:not-allowed;opacity:.6}._csrCheckLabel_15jnl_306{display:flex;align-items:center}\n";
2
+ if (typeof document !== 'undefined') {
3
+ const __id = 'class-student-roster__style';
4
+ if (!document.getElementById(__id)) {
5
+ const __style = document.createElement('style');
6
+ __style.id = __id;
7
+ __style.textContent = __CSR_CSS__;
8
+ document.head.appendChild(__style);
9
+ }
10
+ }
11
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var u=require("react");function te(h){return h&&typeof h=="object"&&"default"in h?h:{default:h}}var ne=te(u);const re="_iconfont_15jnl_7",ae="_csrMask_15jnl_14",de="_csrModal_15jnl_24",le="_csrHeader_15jnl_34",ie="_csrTitle_15jnl_44",oe="_csrClose_15jnl_50",Ae="_csrBody_15jnl_62",me="_csrPanel_15jnl_69",ue="_csrPanelHeader_15jnl_81",he="_csrSearch_15jnl_86",Ie="_csrSearchIcon_15jnl_102",fe="_csrTree_15jnl_113",Ce="_csrTreeItem_15jnl_118",Le="_csrTreeItemText_15jnl_135",je="_csrMeta_15jnl_138",ge="_csrTreeItemActive_15jnl_142",we="_csrTreeChildren_15jnl_151",pe="_csrList_15jnl_154",ve="_csrListItem_15jnl_161",be="_csrListItemDisabled_15jnl_172",Be="_csrOps_15jnl_194",Ee="_hasSelected_15jnl_205",Me="_clearBtn_15jnl_210",Ne="_csrChipWrap_15jnl_214",Fe="_csrChipList_15jnl_219",Pe="_deleteIcon_15jnl_227",Se="_deleteIconDisabled_15jnl_232",ye="_csrChip_15jnl_214",Ze="_csrFooter_15jnl_251",We="_csrBtn_15jnl_258",Te="_csrBtnPrimary_15jnl_267",ke="_csrBtnCancel_15jnl_272",ze="_csrEmpty_15jnl_277",Oe="_csrCheck_15jnl_292",xe="_csrCheckLabel_15jnl_306";var t={iconfont:re,csrMask:ae,csrModal:de,csrHeader:le,csrTitle:ie,csrClose:oe,csrBody:Ae,csrPanel:me,csrPanelHeader:ue,csrSearch:he,csrSearchIcon:Ie,csrTree:fe,csrTreeItem:Ce,csrTreeItemText:Le,csrMeta:je,csrTreeItemActive:ge,csrTreeChildren:we,csrList:pe,csrListItem:ve,csrListItemDisabled:be,csrOps:Be,hasSelected:Ee,clearBtn:Me,csrChipWrap:Ne,csrChipList:Fe,deleteIcon:Pe,deleteIconDisabled:Se,csrChip:ye,csrFooter:Ze,csrBtn:We,csrBtnPrimary:Te,csrBtnCancel:ke,csrEmpty:ze,csrCheck:Oe,csrCheckLabel:xe},G="",H={exports:{}},T={};/**
2
12
  * @license React
3
13
  * react-jsx-runtime.production.min.js
4
14
  *
@@ -6,4 +16,4 @@
6
16
  *
7
17
  * This source code is licensed under the MIT license found in the
8
18
  * LICENSE file in the root directory of this source tree.
9
- */var ye=$.default,Se=Symbol.for("react.element"),je=Symbol.for("react.fragment"),Oe=Object.prototype.hasOwnProperty,ke=ye.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,Te={key:!0,ref:!0,__self:!0,__source:!0};function H(m,l,E){var h,p={},f=null,B=null;E!==void 0&&(f=""+E),l.key!==void 0&&(f=""+l.key),l.ref!==void 0&&(B=l.ref);for(h in l)Oe.call(l,h)&&!Te.hasOwnProperty(h)&&(p[h]=l[h]);if(m&&m.defaultProps)for(h in l=m.defaultProps,l)p[h]===void 0&&(p[h]=l[h]);return{$$typeof:Se,type:m,key:f,ref:B,props:p,_owner:ke.current}}W.Fragment=je;W.jsx=H;W.jsxs=H;S.exports=W;const i=S.exports.jsx,A=S.exports.jsxs;function xe({visible:m=!1,onClose:l,onSave:E,loadData:h,title:p="\u9009\u62E9\u5B66\u751F"}){const[f,B]=o.useState([]),[F,J]=o.useState([]),[M,I]=o.useState(null),[N,v]=o.useState(null),[C,g]=o.useState(new Set),[z,D]=o.useState(""),[y,j]=o.useState(!1),[P,O]=o.useState(""),G=e=>Array.isArray(e==null?void 0:e.grades)&&e.grades.length?e.grades:Array.isArray(e==null?void 0:e.classes)&&e.classes.length?[{id:"virtual-grade",name:e.defaultGradeName||"\u6240\u6709\u73ED\u7EA7",classes:e.classes}]:[];o.useEffect(()=>{if(!m)return;let e=!0;return(async()=>{var r,s;try{j(!0),O("");const a=h?await h():{grades:[],students:[]};if(!e)return;const d=G(a);B(d),J(a.students||[]);const c=d==null?void 0:d[0];I((c==null?void 0:c.id)||null),v(((s=(r=c==null?void 0:c.classes)==null?void 0:r[0])==null?void 0:s.id)||null)}catch(a){if(!e)return;O((a==null?void 0:a.message)||"\u52A0\u8F7D\u5931\u8D25")}finally{e&&j(!1)}})(),()=>{e=!1}},[m,h]);const Z=o.useMemo(()=>{const e=new Map;return F.forEach(r=>e.set(r.id,r)),e},[F]),L=o.useMemo(()=>{var a,d,c;if(!M)return[];const e=f.find(n=>n.id===M);if(!e)return[];const r=new Set;if(N){const n=(a=e.classes)==null?void 0:a.find(u=>u.id===N);(d=n==null?void 0:n.studentIds)==null||d.forEach(u=>r.add(u))}else(c=e.classes)==null||c.forEach(n=>{var u;return(u=n.studentIds)==null?void 0:u.forEach(w=>r.add(w))});let s=Array.from(r).map(n=>Z.get(n)).filter(Boolean);if(z.trim()){const n=z.trim().toLowerCase();s=s.filter(u=>u.name.toLowerCase().includes(n))}return s},[M,N,f,Z,z]),b=o.useMemo(()=>Array.from(C).map(e=>Z.get(e)).filter(Boolean),[C,Z]),k=e=>{g(r=>{const s=new Set(r);return s.has(e)?s.delete(e):s.add(e),s})},V=e=>{if(e){const r=L.map(s=>s.id);g(s=>new Set([...s,...r]))}else g(r=>{const s=new Set(r);return L.forEach(a=>s.delete(a.id)),s})},Y=(e,r,s)=>{const a=(r==null?void 0:r.studentIds)||[];g(d=>{const c=new Set(d);return s?a.forEach(n=>c.add(n)):a.forEach(n=>c.delete(n)),c}),I(e),v((r==null?void 0:r.id)||null)},K=(e,r)=>{var a;const s=[];(a=e.classes)==null||a.forEach(d=>{var c;return(c=d.studentIds)==null?void 0:c.forEach(n=>s.push(n))}),g(d=>{const c=new Set(d);return r?s.forEach(n=>c.add(n)):s.forEach(n=>c.delete(n)),c}),I(e.id),v(null)},R=(e,r)=>{var u;const s=f.find(w=>w.id===e),a=(u=s==null?void 0:s.classes)==null?void 0:u.find(w=>w.id===r),d=(a==null?void 0:a.studentIds)||[],c=d.length,n=d.filter(w=>C.has(w)).length;return{checked:c>0&&n===c,indeterminate:n>0&&n<c}},T=e=>{var d;const r=[];(d=e.classes)==null||d.forEach(c=>{var n;return(n=c.studentIds)==null?void 0:n.forEach(u=>r.push(u))});const s=r.length,a=r.filter(c=>C.has(c)).length;return{checked:s>0&&a===s,indeterminate:a>0&&a<s}},X=(e,r)=>{var n;const s=f.find(u=>u.id===e),a=(n=s==null?void 0:s.classes)==null?void 0:n.find(u=>u.id===r),d=(a==null?void 0:a.studentIds)||[];return{selectedCount:d.filter(u=>C.has(u)).length,total:d.length}},q=()=>g(new Set),U=()=>{const e=b.map(r=>({id:r.id,name:r.name}));E&&E(e)};return o.useEffect(()=>{const e=z.trim().toLowerCase();if(!e)return;const r=f.find(c=>{var n;return(n=c.name)==null?void 0:n.toLowerCase().includes(e)});if(r){I(r.id),v(null);return}let s=null,a=null;if(f.some(c=>{var u;const n=(u=c.classes)==null?void 0:u.find(w=>{var x;return(x=w.name)==null?void 0:x.toLowerCase().includes(e)});return n?(s=n,a=c.id,!0):!1}),s){I(a),v(s.id);return}const d=F.find(c=>{var n;return(n=c.name)==null?void 0:n.toLowerCase().includes(e)});d&&(I(d.gradeId||null),v(d.classId||null))},[z,f,F]),m?i("div",{className:t.csrMask,children:A("div",{className:t.csrModal,children:[A("div",{className:t.csrHeader,children:[i("h3",{className:t.csrTitle,children:p}),i("i",{className:`${t.iconfont} ${t.csrClose}`,onClick:l,children:"\uE6A9"})]}),A("div",{className:t.csrBody,children:[A("div",{className:t.csrPanel,children:[A("div",{className:t.csrSearch,children:[i("input",{placeholder:"\u8BF7\u8F93\u5165\u5B66\u751F\u59D3\u540D/\u5B66\u53F7\u641C\u7D22",value:z,onChange:e=>D(e.target.value)}),i("i",{className:`${t.iconfont} ${t.csrSearchIcon}`,children:"\uE61D"})]}),A("div",{className:t.csrTree,children:[y&&i("div",{className:t.csrEmpty,children:"\u52A0\u8F7D\u4E2D..."}),P&&i("div",{className:t.csrEmpty,children:P}),!y&&!P&&f.map(e=>{var r;return A("div",{children:[A("div",{className:`${t.csrTreeItem} ${M===e.id&&!N?t.csrTreeItemActive:""}`,children:[i("input",{className:t.csrCheck,type:"checkbox",name:"grade",checked:T(e).checked,ref:s=>{s&&(s.indeterminate=T(e).indeterminate)},onClick:s=>s.stopPropagation(),onChange:s=>K(e,s.target.checked)}),i("span",{className:t.csrTreeItemText,onClick:()=>{I(e.id),v(null)},children:e.name})]}),i("div",{className:t.csrTreeChildren,children:(r=e.classes)==null?void 0:r.map(s=>{const a=X(e.id,s.id),d=R(e.id,s.id);return A("div",{className:`${t.csrTreeItem} ${N===s.id?t.csrTreeItemActive:""}`,children:[i("input",{className:t.csrCheck,type:"checkbox",name:"class",checked:d.checked,ref:c=>{c&&(c.indeterminate=d.indeterminate)},onClick:c=>c.stopPropagation(),onChange:c=>Y(e.id,s,c.target.checked)}),i("span",{className:t.csrTreeItemText,onClick:()=>{I(e.id),v(s.id)},children:s.name}),A("span",{className:t.csrMeta,children:[a.selectedCount,a.total?`/${a.total}`:""]})]},s.id)})})]},e.id)}),!y&&!P&&!f.length&&A("div",{className:t.csrEmpty,children:[i("img",{src:Q,alt:"blank"}),i("span",{children:"\u6682\u65E0\u6570\u636E"})]})]})]}),A("div",{className:t.csrPanel,children:[A("div",{className:t.csrOps,children:[A("label",{className:t.csrCheckLabel,children:[i("input",{className:t.csrCheck,type:"checkbox",checked:L.length>0&&L.every(e=>C.has(e.id)),onChange:e=>V(e.target.checked)}),"\u5168\u9009"]}),A("span",{className:t.csrMeta,children:["\u5171 ",L.length," \u4EBA"]})]}),A("ul",{className:t.csrList,children:[L.map(e=>A("li",{className:t.csrListItem,children:[i("input",{className:t.csrCheck,type:"checkbox",checked:C.has(e.id),onChange:()=>k(e.id)}),i("div",{children:e.name})]},e.id)),!L.length&&A("div",{className:t.csrEmpty,children:[i("img",{src:Q,alt:"blank"}),i("span",{children:"\u6682\u65E0\u5B66\u751F"})]})]})]}),A("div",{className:t.csrPanel,children:[A("div",{className:t.csrOps,children:[A("span",{className:t.hasSelected,children:["\u5DF2\u9009 ",b.length," \u4EBA"]}),i("span",{className:t.clearBtn,onClick:q,children:"\u6E05\u7A7A"})]}),i("div",{className:t.csrChipWrap,children:b.length?i("ul",{className:t.csrChipList,children:b.map(e=>A("li",{className:t.csrChip,children:[i("span",{children:e.name}),i("i",{className:`${t.iconfont} ${t.deleteIcon}`,onClick:()=>k(e.id),children:"\uE6A9"})]},e.id))}):i("div",{className:t.csrEmpty,children:"\u8BF7\u9009\u62E9"})})]})]}),A("div",{className:t.csrFooter,children:[i("button",{className:`${t.csrBtn} ${t.csrBtnCancel}`,onClick:l,children:"\u53D6\u6D88"}),i("button",{className:`${t.csrBtn} ${t.csrBtnPrimary}`,onClick:U,children:"\u4FDD\u5B58"})]})]})}):null}exports.default=xe;
19
+ */var He=ne.default,Qe=Symbol.for("react.element"),De=Symbol.for("react.fragment"),Je=Object.prototype.hasOwnProperty,Ve=He.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,Ye={key:!0,ref:!0,__self:!0,__source:!0};function K(h,f,E){var I,w={},M=null,N=null;E!==void 0&&(M=""+E),f.key!==void 0&&(M=""+f.key),f.ref!==void 0&&(N=f.ref);for(I in f)Je.call(f,I)&&!Ye.hasOwnProperty(I)&&(w[I]=f[I]);if(h&&h.defaultProps)for(I in f=h.defaultProps,f)w[I]===void 0&&(w[I]=f[I]);return{$$typeof:Qe,type:h,key:M,ref:N,props:w,_owner:Ve.current}}T.Fragment=De;T.jsx=K;T.jsxs=K;H.exports=T;const i=H.exports.jsx,o=H.exports.jsxs;function Ge({visible:h=!1,onClose:f,onSave:E,data:I,loadData:w,title:M="\u9009\u62E9\u5B66\u751F",selectedIds:N=[],disableIds:Q=[]}){const[L,D]=u.useState([]),[P,J]=u.useState([]),[S,j]=u.useState(null),[F,g]=u.useState(null),[p,v]=u.useState(new Set),[B,R]=u.useState(""),[k,z]=u.useState(!1),[y,O]=u.useState(""),A=u.useMemo(()=>new Set(Q||[]),[Q]),V=e=>Array.isArray(e==null?void 0:e.grades)&&e.grades.length?e.grades:Array.isArray(e==null?void 0:e.classes)&&e.classes.length?[{id:"virtual-grade",name:e.defaultGradeName||"\u6240\u6709\u73ED\u7EA7",classes:e.classes}]:[];u.useEffect(()=>{if(!h)return;let e=!0;return(async()=>{var n,s,r,l;try{if(I){z(!1),O("");const C=V(I);D(C),J(I.students||[]);const m=C==null?void 0:C[0];j((m==null?void 0:m.id)||null),g(((s=(n=m==null?void 0:m.classes)==null?void 0:n[0])==null?void 0:s.id)||null);return}z(!0),O("");const a=w?await w():{grades:[],students:[]};if(!e)return;const c=V(a);D(c),J(a.students||[]);const d=c==null?void 0:c[0];j((d==null?void 0:d.id)||null),g(((l=(r=d==null?void 0:d.classes)==null?void 0:r[0])==null?void 0:l.id)||null)}catch(a){if(!e)return;O((a==null?void 0:a.message)||"\u52A0\u8F7D\u5931\u8D25")}finally{e&&z(!1)}})(),()=>{e=!1}},[h,w,I]),u.useEffect(()=>{!h||v(new Set(N||[]))},[h,N]);const Z=u.useMemo(()=>{const e=new Map;return P.forEach(n=>e.set(n.id,n)),e},[P]),b=u.useMemo(()=>{var r,l,a;if(!S)return[];const e=L.find(c=>c.id===S);if(!e)return[];const n=new Set;if(F){const c=(r=e.classes)==null?void 0:r.find(d=>d.id===F);(l=c==null?void 0:c.studentIds)==null||l.forEach(d=>n.add(d))}else(a=e.classes)==null||a.forEach(c=>{var d;return(d=c.studentIds)==null?void 0:d.forEach(C=>n.add(C))});let s=Array.from(n).map(c=>Z.get(c)).filter(Boolean);if(B.trim()){const c=B.trim().toLowerCase();s=s.filter(d=>d.name.toLowerCase().includes(c))}return s},[S,F,L,Z,B]),W=u.useMemo(()=>Array.from(p).map(e=>Z.get(e)).filter(Boolean),[p,Z]),x=u.useMemo(()=>{const e=b.filter(r=>!A.has(r.id)),n=e.length,s=e.filter(r=>p.has(r.id)).length;return{checked:n>0&&s===n,indeterminate:s>0&&s<n,disabled:n===0}},[b,p,A]),Y=e=>{A.has(e)||v(n=>{const s=new Set(n);return s.has(e)?s.delete(e):s.add(e),s})},X=e=>{if(e){const n=b.filter(s=>!A.has(s.id)).map(s=>s.id);v(s=>new Set([...s,...n]))}else v(n=>{const s=new Set(n);return b.forEach(r=>{A.has(r.id)||s.delete(r.id)}),s})},q=(e,n,s)=>{const r=(n==null?void 0:n.studentIds)||[];v(l=>{const a=new Set(l);return s?r.forEach(c=>{A.has(c)||a.add(c)}):r.forEach(c=>{A.has(c)||a.delete(c)}),a}),j(e),g((n==null?void 0:n.id)||null)},U=(e,n)=>{var r;const s=[];(r=e.classes)==null||r.forEach(l=>{var a;return(a=l.studentIds)==null?void 0:a.forEach(c=>s.push(c))}),v(l=>{const a=new Set(l);return n?s.forEach(c=>{A.has(c)||a.add(c)}):s.forEach(c=>{A.has(c)||a.delete(c)}),a}),j(e.id),g(null)},_=(e,n)=>{var C;const s=L.find(m=>m.id===e),r=(C=s==null?void 0:s.classes)==null?void 0:C.find(m=>m.id===n),a=((r==null?void 0:r.studentIds)||[]).filter(m=>!A.has(m)),c=a.length,d=a.filter(m=>p.has(m)).length;return{checked:c>0&&d===c,indeterminate:d>0&&d<c,disabled:c===0}},$=e=>{var a;const n=[];(a=e.classes)==null||a.forEach(c=>{var d;return(d=c.studentIds)==null?void 0:d.forEach(C=>n.push(C))});const s=n.filter(c=>!A.has(c)),r=s.length,l=s.filter(c=>p.has(c)).length;return{checked:r>0&&l===r,indeterminate:l>0&&l<r,disabled:r===0}},ee=(e,n)=>{var c;const s=L.find(d=>d.id===e),r=(c=s==null?void 0:s.classes)==null?void 0:c.find(d=>d.id===n),l=(r==null?void 0:r.studentIds)||[];return{selectedCount:l.filter(d=>p.has(d)).length,total:l.length}},se=()=>v(e=>{const n=new Set(e);return A.forEach(s=>{e.has(s)&&n.add(s)}),e.forEach(s=>{A.has(s)||n.delete(s)}),n}),ce=()=>{const e=W.map(n=>({id:n.id,name:n.name}));E&&E(e)};return u.useEffect(()=>{const e=B.trim().toLowerCase();if(!e)return;const n=L.find(a=>{var c;return(c=a.name)==null?void 0:c.toLowerCase().includes(e)});if(n){j(n.id),g(null);return}let s=null,r=null;if(L.some(a=>{var d;const c=(d=a.classes)==null?void 0:d.find(C=>{var m;return(m=C.name)==null?void 0:m.toLowerCase().includes(e)});return c?(s=c,r=a.id,!0):!1}),s){j(r),g(s.id);return}const l=P.find(a=>{var c;return(c=a.name)==null?void 0:c.toLowerCase().includes(e)});l&&(j(l.gradeId||null),g(l.classId||null))},[B,L,P]),h?i("div",{className:t.csrMask,children:o("div",{className:t.csrModal,children:[o("div",{className:t.csrHeader,children:[i("span",{className:t.csrTitle,children:M}),i("i",{className:`${t.iconfont} ${t.csrClose}`,onClick:f,children:"\uE6A9"})]}),o("div",{className:t.csrBody,children:[o("div",{className:t.csrPanel,children:[o("div",{className:t.csrSearch,children:[i("input",{placeholder:"\u8BF7\u8F93\u5165\u5B66\u751F\u59D3\u540D/\u5B66\u53F7\u641C\u7D22",value:B,onChange:e=>R(e.target.value)}),i("i",{className:`${t.iconfont} ${t.csrSearchIcon}`,children:"\uE61D"})]}),o("div",{className:t.csrTree,children:[k&&i("div",{className:t.csrEmpty,children:"\u52A0\u8F7D\u4E2D..."}),y&&i("div",{className:t.csrEmpty,children:y}),!k&&!y&&L.map(e=>{var n;return o("div",{children:[(()=>{const s=$(e);return o("div",{onClick:()=>{j(e.id),g(null)},className:`${t.csrTreeItem} ${S===e.id&&!F?t.csrTreeItemActive:""}`,children:[i("input",{className:t.csrCheck,type:"checkbox",name:"grade",checked:s.checked,ref:r=>{r&&(r.indeterminate=s.indeterminate)},disabled:s.disabled,onClick:r=>r.stopPropagation(),onChange:r=>U(e,r.target.checked)}),i("span",{className:t.csrTreeItemText,children:e.name})]})})(),i("div",{className:t.csrTreeChildren,children:(n=e.classes)==null?void 0:n.map(s=>{const r=ee(e.id,s.id),l=_(e.id,s.id);return o("div",{onClick:()=>{j(e.id),g(s.id)},className:`${t.csrTreeItem} ${F===s.id?t.csrTreeItemActive:""}`,children:[i("input",{className:t.csrCheck,type:"checkbox",name:"class",checked:l.checked,ref:a=>{a&&(a.indeterminate=l.indeterminate)},disabled:l.disabled,onClick:a=>a.stopPropagation(),onChange:a=>q(e.id,s,a.target.checked)}),i("span",{className:t.csrTreeItemText,children:s.name}),o("span",{className:t.csrMeta,children:[r.selectedCount,r.total?`/${r.total}`:""]})]},s.id)})})]},e.id)}),!k&&!y&&!L.length&&o("div",{className:t.csrEmpty,children:[i("img",{src:G,alt:"blank"}),i("span",{children:"\u6682\u65E0\u6570\u636E"})]})]})]}),o("div",{className:t.csrPanel,children:[o("div",{className:t.csrOps,children:[o("label",{className:t.csrCheckLabel,children:[i("input",{className:t.csrCheck,type:"checkbox",checked:x.checked,ref:e=>{e&&(e.indeterminate=x.indeterminate)},disabled:x.disabled,onChange:e=>X(e.target.checked)}),"\u5168\u9009"]}),o("span",{className:t.csrMeta,children:["\u5171 ",b.length," \u4EBA"]})]}),o("ul",{className:t.csrList,children:[b.map(e=>o("li",{className:`${t.csrListItem} ${A.has(e.id)?t.csrListItemDisabled:""}`,children:[i("input",{className:t.csrCheck,type:"checkbox",checked:p.has(e.id),disabled:A.has(e.id),onChange:()=>Y(e.id)}),i("div",{children:e.name})]},e.id)),!b.length&&o("div",{className:t.csrEmpty,children:[i("img",{src:G,alt:"blank"}),i("span",{children:"\u6682\u65E0\u5B66\u751F"})]})]})]}),o("div",{className:t.csrPanel,children:[o("div",{className:t.csrOps,children:[o("span",{className:t.hasSelected,children:["\u5DF2\u9009 ",W.length," \u4EBA"]}),i("span",{className:t.clearBtn,onClick:se,children:"\u6E05\u7A7A"})]}),i("div",{className:t.csrChipWrap,children:W.length?i("ul",{className:t.csrChipList,children:W.map(e=>o("li",{className:t.csrChip,children:[i("span",{children:e.name}),i("i",{className:`${t.iconfont} ${t.deleteIcon} ${A.has(e.id)?t.deleteIconDisabled:""}`,onClick:()=>{A.has(e.id)||Y(e.id)},children:"\uE6A9"})]},e.id))}):i("div",{className:t.csrEmpty,children:"\u8BF7\u9009\u62E9"})})]})]}),o("div",{className:t.csrFooter,children:[i("button",{className:`${t.csrBtn} ${t.csrBtnCancel}`,onClick:f,children:"\u53D6\u6D88"}),i("button",{className:`${t.csrBtn} ${t.csrBtnPrimary}`,onClick:ce,children:"\u4FDD\u5B58"})]})]})}):null}exports.default=Ge;
package/dist/index.es.js CHANGED
@@ -1,71 +1,85 @@
1
- import require$$0, { useState, useEffect, useMemo } from "react";
2
- const iconfont = "_iconfont_zvw5p_7";
3
- const csrMask = "_csrMask_zvw5p_14";
4
- const csrModal = "_csrModal_zvw5p_24";
5
- const csrHeader = "_csrHeader_zvw5p_34";
6
- const csrTitle = "_csrTitle_zvw5p_44";
7
- const csrClose = "_csrClose_zvw5p_50";
8
- const csrBody = "_csrBody_zvw5p_62";
9
- const csrPanel = "_csrPanel_zvw5p_69";
10
- const csrPanelHeader = "_csrPanelHeader_zvw5p_81";
11
- const csrSearch = "_csrSearch_zvw5p_86";
12
- const csrSearchIcon = "_csrSearchIcon_zvw5p_102";
13
- const csrTree = "_csrTree_zvw5p_113";
14
- const csrTreeItem = "_csrTreeItem_zvw5p_118";
15
- const csrTreeItemText = "_csrTreeItemText_zvw5p_135";
16
- const csrMeta = "_csrMeta_zvw5p_138";
17
- const csrTreeItemActive = "_csrTreeItemActive_zvw5p_142";
18
- const csrTreeChildren = "_csrTreeChildren_zvw5p_151";
19
- const csrList = "_csrList_zvw5p_154";
20
- const csrListItem = "_csrListItem_zvw5p_161";
21
- const csrOps = "_csrOps_zvw5p_185";
22
- const hasSelected = "_hasSelected_zvw5p_196";
23
- const clearBtn = "_clearBtn_zvw5p_201";
24
- const csrChipWrap = "_csrChipWrap_zvw5p_205";
25
- const csrChipList = "_csrChipList_zvw5p_210";
26
- const deleteIcon = "_deleteIcon_zvw5p_218";
27
- const csrChip = "_csrChip_zvw5p_205";
28
- const csrFooter = "_csrFooter_zvw5p_238";
29
- const csrBtn = "_csrBtn_zvw5p_245";
30
- const csrBtnPrimary = "_csrBtnPrimary_zvw5p_254";
31
- const csrBtnCancel = "_csrBtnCancel_zvw5p_259";
32
- const csrEmpty = "_csrEmpty_zvw5p_264";
33
- const csrCheck = "_csrCheck_zvw5p_279";
34
- const csrCheckLabel = "_csrCheckLabel_zvw5p_289";
1
+ const __CSR_CSS__ = "@font-face{font-family:iconfont;src:url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff2?t=1766568844647) format(\"woff2\"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff?t=1766568844647) format(\"woff\"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.ttf?t=1766568844647) format(\"truetype\")}._iconfont_15jnl_7{font-family:iconfont!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}._csrMask_15jnl_14{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;font-family:PingFangSC-Regular}._csrModal_15jnl_24{width:980px;background:#fff;border-radius:11px;box-shadow:0 12px 40px #00000029;display:flex;flex-direction:column;overflow:hidden;font-family:PingFangSC-Regular}._csrHeader_15jnl_34{height:56px;min-height:56px;padding:0 12px;border-bottom:1px solid #E6E7EC;display:flex;align-items:center;justify-content:center;position:relative}._csrTitle_15jnl_44{margin:0;font-size:16px;font-weight:600;color:#01113d}._csrClose_15jnl_50{position:absolute;right:16px;top:50%;border:none;background:transparent;font-size:18px;cursor:pointer;color:#27355a;font-weight:600;margin-top:-9px}._csrBody_15jnl_62{flex:1;overflow:hidden;display:flex;background:#f5f6f7;padding:12px}._csrPanel_15jnl_69{background:#fff;border-radius:11px;display:flex;flex-direction:column;min-height:0;flex:1;height:450px}._csrPanel_15jnl_69:nth-child(2){margin:0 10px}._csrPanelHeader_15jnl_81{padding:12px 12px 8px;font-weight:600;color:#333}._csrSearch_15jnl_86{padding:10px 12px;display:flex;align-items:center;position:relative;border-bottom:1px solid #E6E7EC}._csrSearch_15jnl_86 input{padding:9px 30px 9px 10px;border-radius:7px;border:1px solid #E6E7EC;font-size:14px;width:100%;z-index:1;position:relative}._csrSearch_15jnl_86 ._csrSearchIcon_15jnl_102{position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:14px;color:#5a6481;font-weight:600;z-index:2;cursor:pointer}._csrTree_15jnl_113{flex:1;overflow:auto;padding:10px 12px}._csrTreeItem_15jnl_118{display:flex;align-items:center;padding:6px 8px 6px 2px;border-radius:4px;cursor:pointer;color:#01113d;font-size:14px;font-family:PingFangSC-Regular;position:relative;margin-bottom:8px;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}._csrTreeItem_15jnl_118:hover{background:rgba(4,69,252,.06);transform:translate(2px)}._csrTreeItem_15jnl_118 ._csrTreeItemText_15jnl_135{padding-right:32px}._csrTreeItem_15jnl_118 ._csrMeta_15jnl_138{position:absolute;right:11px}._csrTreeItemActive_15jnl_142{background:rgba(4,69,252,.05);border-radius:2px;transform:translate(4px)}._csrTreeItemActive_15jnl_142 span{color:#0445fc;font-weight:500}._csrTreeChildren_15jnl_151{padding-left:22px}._csrList_15jnl_154{list-style:none;margin:0;padding:10px 12px 12px;flex:1;overflow:auto}._csrList_15jnl_154 ._csrListItem_15jnl_161{display:flex;align-items:center;font-size:14px;font-family:PingFangSC-Regular;padding:8px 4px;margin-bottom:4px;border-radius:4px;color:#01113d;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}._csrList_15jnl_154 ._csrListItemDisabled_15jnl_172{opacity:.55;cursor:not-allowed}._csrList_15jnl_154 ._csrListItem_15jnl_161:hover{background:rgba(4,69,252,.05);transform:translate(2px)}._csrList_15jnl_154 ._csrListItemDisabled_15jnl_172:hover{background:transparent;transform:none}._csrList_15jnl_154 ._csrListItem_15jnl_161:last-child{border-bottom:none}._csrMeta_15jnl_138{display:flex;align-items:center;gap:6px;font-size:12px;color:#666}._csrOps_15jnl_194{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:56px;font-size:14px;color:#01113d;font-family:PingFangSC-Regular;border-bottom:1px solid #E6E7EC}._csrOps_15jnl_194 ._hasSelected_15jnl_205{font-size:14px;font-weight:500;color:#01113d}._csrOps_15jnl_194 ._clearBtn_15jnl_210{color:#0445fc;cursor:pointer}._csrChipWrap_15jnl_214{flex:1;overflow:auto;padding:10px 12px 12px}._csrChipList_15jnl_219{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}._csrChipList_15jnl_219 ._deleteIcon_15jnl_227{margin-left:8px;cursor:pointer;font-size:14px}._csrChipList_15jnl_219 ._deleteIconDisabled_15jnl_232{cursor:not-allowed;opacity:.45}._csrChip_15jnl_214{display:inline-flex;align-items:center;background:#F2F3F5;border-radius:4px;padding:4px 10px;font-size:12px;color:#01113d}._csrChip_15jnl_214 button{border:none;background:transparent;cursor:pointer;color:#666}._csrFooter_15jnl_251{border-top:1px solid #f0f0f0;padding:12px 16px;display:flex;justify-content:flex-end;gap:12px}._csrBtn_15jnl_258{min-width:76px;height:32px;border-radius:7px;cursor:pointer;border:1px solid #d9d9d9;background:#fff;font-size:14px}._csrBtnPrimary_15jnl_267{background:#0445FC;border-color:#0445fc;color:#fff}._csrBtnCancel_15jnl_272{background:#EDEEF1;border-color:#edeef1;color:#01113d}._csrEmpty_15jnl_277{color:#01113da6;padding:8px 12px;font-size:13px;display:flex;align-items:center;justify-content:center;flex-direction:column;height:80%}._csrEmpty_15jnl_277 img{width:120px;height:120px;margin-bottom:12px}._csrCheck_15jnl_292{margin-right:8px;width:14px;height:14px;accent-color:#0445FC;transition:transform .12s ease}._csrCheck_15jnl_292:active{transform:scale(.9)}._csrCheck_15jnl_292:disabled{cursor:not-allowed;opacity:.6}._csrCheckLabel_15jnl_306{display:flex;align-items:center}\n";
2
+ if (typeof document !== 'undefined') {
3
+ const __id = 'class-student-roster__style';
4
+ if (!document.getElementById(__id)) {
5
+ const __style = document.createElement('style');
6
+ __style.id = __id;
7
+ __style.textContent = __CSR_CSS__;
8
+ document.head.appendChild(__style);
9
+ }
10
+ }
11
+ import require$$0, { useState, useMemo, useEffect } from "react";
12
+ const iconfont$1 = "_iconfont_15jnl_7";
13
+ const csrMask$1 = "_csrMask_15jnl_14";
14
+ const csrModal$1 = "_csrModal_15jnl_24";
15
+ const csrHeader$1 = "_csrHeader_15jnl_34";
16
+ const csrTitle$1 = "_csrTitle_15jnl_44";
17
+ const csrClose$1 = "_csrClose_15jnl_50";
18
+ const csrBody$1 = "_csrBody_15jnl_62";
19
+ const csrPanel$1 = "_csrPanel_15jnl_69";
20
+ const csrPanelHeader$1 = "_csrPanelHeader_15jnl_81";
21
+ const csrSearch$1 = "_csrSearch_15jnl_86";
22
+ const csrSearchIcon$1 = "_csrSearchIcon_15jnl_102";
23
+ const csrTree$1 = "_csrTree_15jnl_113";
24
+ const csrTreeItem$1 = "_csrTreeItem_15jnl_118";
25
+ const csrTreeItemText$1 = "_csrTreeItemText_15jnl_135";
26
+ const csrMeta$1 = "_csrMeta_15jnl_138";
27
+ const csrTreeItemActive$1 = "_csrTreeItemActive_15jnl_142";
28
+ const csrTreeChildren$1 = "_csrTreeChildren_15jnl_151";
29
+ const csrList$1 = "_csrList_15jnl_154";
30
+ const csrListItem$1 = "_csrListItem_15jnl_161";
31
+ const csrListItemDisabled$1 = "_csrListItemDisabled_15jnl_172";
32
+ const csrOps$1 = "_csrOps_15jnl_194";
33
+ const hasSelected$1 = "_hasSelected_15jnl_205";
34
+ const clearBtn$1 = "_clearBtn_15jnl_210";
35
+ const csrChipWrap$1 = "_csrChipWrap_15jnl_214";
36
+ const csrChipList$1 = "_csrChipList_15jnl_219";
37
+ const deleteIcon$1 = "_deleteIcon_15jnl_227";
38
+ const deleteIconDisabled$1 = "_deleteIconDisabled_15jnl_232";
39
+ const csrChip$1 = "_csrChip_15jnl_214";
40
+ const csrFooter$1 = "_csrFooter_15jnl_251";
41
+ const csrBtn$1 = "_csrBtn_15jnl_258";
42
+ const csrBtnPrimary$1 = "_csrBtnPrimary_15jnl_267";
43
+ const csrBtnCancel$1 = "_csrBtnCancel_15jnl_272";
44
+ const csrEmpty$1 = "_csrEmpty_15jnl_277";
45
+ const csrCheck$1 = "_csrCheck_15jnl_292";
46
+ const csrCheckLabel$1 = "_csrCheckLabel_15jnl_306";
35
47
  var styles = {
36
- iconfont,
37
- csrMask,
38
- csrModal,
39
- csrHeader,
40
- csrTitle,
41
- csrClose,
42
- csrBody,
43
- csrPanel,
44
- csrPanelHeader,
45
- csrSearch,
46
- csrSearchIcon,
47
- csrTree,
48
- csrTreeItem,
49
- csrTreeItemText,
50
- csrMeta,
51
- csrTreeItemActive,
52
- csrTreeChildren,
53
- csrList,
54
- csrListItem,
55
- csrOps,
56
- hasSelected,
57
- clearBtn,
58
- csrChipWrap,
59
- csrChipList,
60
- deleteIcon,
61
- csrChip,
62
- csrFooter,
63
- csrBtn,
64
- csrBtnPrimary,
65
- csrBtnCancel,
66
- csrEmpty,
67
- csrCheck,
68
- csrCheckLabel
48
+ iconfont: iconfont$1,
49
+ csrMask: csrMask$1,
50
+ csrModal: csrModal$1,
51
+ csrHeader: csrHeader$1,
52
+ csrTitle: csrTitle$1,
53
+ csrClose: csrClose$1,
54
+ csrBody: csrBody$1,
55
+ csrPanel: csrPanel$1,
56
+ csrPanelHeader: csrPanelHeader$1,
57
+ csrSearch: csrSearch$1,
58
+ csrSearchIcon: csrSearchIcon$1,
59
+ csrTree: csrTree$1,
60
+ csrTreeItem: csrTreeItem$1,
61
+ csrTreeItemText: csrTreeItemText$1,
62
+ csrMeta: csrMeta$1,
63
+ csrTreeItemActive: csrTreeItemActive$1,
64
+ csrTreeChildren: csrTreeChildren$1,
65
+ csrList: csrList$1,
66
+ csrListItem: csrListItem$1,
67
+ csrListItemDisabled: csrListItemDisabled$1,
68
+ csrOps: csrOps$1,
69
+ hasSelected: hasSelected$1,
70
+ clearBtn: clearBtn$1,
71
+ csrChipWrap: csrChipWrap$1,
72
+ csrChipList: csrChipList$1,
73
+ deleteIcon: deleteIcon$1,
74
+ deleteIconDisabled: deleteIconDisabled$1,
75
+ csrChip: csrChip$1,
76
+ csrFooter: csrFooter$1,
77
+ csrBtn: csrBtn$1,
78
+ csrBtnPrimary: csrBtnPrimary$1,
79
+ csrBtnCancel: csrBtnCancel$1,
80
+ csrEmpty: csrEmpty$1,
81
+ csrCheck: csrCheck$1,
82
+ csrCheckLabel: csrCheckLabel$1
69
83
  };
70
84
  var blankIcon = "";
71
85
  var jsxRuntime = { exports: {} };
@@ -104,8 +118,11 @@ function ClassStudentRoster({
104
118
  visible = false,
105
119
  onClose,
106
120
  onSave,
121
+ data,
107
122
  loadData,
108
- title = "\u9009\u62E9\u5B66\u751F"
123
+ title = "\u9009\u62E9\u5B66\u751F",
124
+ selectedIds: selectedIdsProp = [],
125
+ disableIds: disableIdsProp = []
109
126
  }) {
110
127
  const [grades, setGrades] = useState([]);
111
128
  const [students, setStudents] = useState([]);
@@ -115,6 +132,7 @@ function ClassStudentRoster({
115
132
  const [query, setQuery] = useState("");
116
133
  const [loading, setLoading] = useState(false);
117
134
  const [error, setError] = useState("");
135
+ const disabledIdSet = useMemo(() => new Set(disableIdsProp || []), [disableIdsProp]);
118
136
  const normalizeGrades = (res) => {
119
137
  if (Array.isArray(res == null ? void 0 : res.grades) && res.grades.length)
120
138
  return res.grades;
@@ -132,8 +150,19 @@ function ClassStudentRoster({
132
150
  return;
133
151
  let mounted = true;
134
152
  (async () => {
135
- var _a, _b;
153
+ var _a, _b, _c, _d;
136
154
  try {
155
+ if (data) {
156
+ setLoading(false);
157
+ setError("");
158
+ const normalizedGrades2 = normalizeGrades(data);
159
+ setGrades(normalizedGrades2);
160
+ setStudents(data.students || []);
161
+ const firstGrade2 = normalizedGrades2 == null ? void 0 : normalizedGrades2[0];
162
+ setActiveGradeId((firstGrade2 == null ? void 0 : firstGrade2.id) || null);
163
+ setActiveClassId(((_b = (_a = firstGrade2 == null ? void 0 : firstGrade2.classes) == null ? void 0 : _a[0]) == null ? void 0 : _b.id) || null);
164
+ return;
165
+ }
137
166
  setLoading(true);
138
167
  setError("");
139
168
  const res = loadData ? await loadData() : {
@@ -147,7 +176,7 @@ function ClassStudentRoster({
147
176
  setStudents(res.students || []);
148
177
  const firstGrade = normalizedGrades == null ? void 0 : normalizedGrades[0];
149
178
  setActiveGradeId((firstGrade == null ? void 0 : firstGrade.id) || null);
150
- setActiveClassId(((_b = (_a = firstGrade == null ? void 0 : firstGrade.classes) == null ? void 0 : _a[0]) == null ? void 0 : _b.id) || null);
179
+ setActiveClassId(((_d = (_c = firstGrade == null ? void 0 : firstGrade.classes) == null ? void 0 : _c[0]) == null ? void 0 : _d.id) || null);
151
180
  } catch (e) {
152
181
  if (!mounted)
153
182
  return;
@@ -160,7 +189,12 @@ function ClassStudentRoster({
160
189
  return () => {
161
190
  mounted = false;
162
191
  };
163
- }, [visible, loadData]);
192
+ }, [visible, loadData, data]);
193
+ useEffect(() => {
194
+ if (!visible)
195
+ return;
196
+ setSelectedIds(new Set(selectedIdsProp || []));
197
+ }, [visible, selectedIdsProp]);
164
198
  const studentMap = useMemo(() => {
165
199
  const map = /* @__PURE__ */ new Map();
166
200
  students.forEach((s) => map.set(s.id, s));
@@ -191,7 +225,19 @@ function ClassStudentRoster({
191
225
  return list;
192
226
  }, [activeGradeId, activeClassId, grades, studentMap, query]);
193
227
  const selectedList = useMemo(() => Array.from(selectedIds).map((id) => studentMap.get(id)).filter(Boolean), [selectedIds, studentMap]);
228
+ const activeSelectStatus = useMemo(() => {
229
+ const selectable = activeStudents.filter((s) => !disabledIdSet.has(s.id));
230
+ const total = selectable.length;
231
+ const selectedCount = selectable.filter((s) => selectedIds.has(s.id)).length;
232
+ return {
233
+ checked: total > 0 && selectedCount === total,
234
+ indeterminate: selectedCount > 0 && selectedCount < total,
235
+ disabled: total === 0
236
+ };
237
+ }, [activeStudents, selectedIds, disabledIdSet]);
194
238
  const toggleOne = (id) => {
239
+ if (disabledIdSet.has(id))
240
+ return;
195
241
  setSelectedIds((prev) => {
196
242
  const next = new Set(prev);
197
243
  if (next.has(id))
@@ -203,12 +249,15 @@ function ClassStudentRoster({
203
249
  };
204
250
  const toggleAll = (checked) => {
205
251
  if (checked) {
206
- const ids = activeStudents.map((s) => s.id);
252
+ const ids = activeStudents.filter((s) => !disabledIdSet.has(s.id)).map((s) => s.id);
207
253
  setSelectedIds((prev) => /* @__PURE__ */ new Set([...prev, ...ids]));
208
254
  } else {
209
255
  setSelectedIds((prev) => {
210
256
  const next = new Set(prev);
211
- activeStudents.forEach((s) => next.delete(s.id));
257
+ activeStudents.forEach((s) => {
258
+ if (!disabledIdSet.has(s.id))
259
+ next.delete(s.id);
260
+ });
212
261
  return next;
213
262
  });
214
263
  }
@@ -217,10 +266,17 @@ function ClassStudentRoster({
217
266
  const ids = (cls == null ? void 0 : cls.studentIds) || [];
218
267
  setSelectedIds((prev) => {
219
268
  const next = new Set(prev);
220
- if (checked)
221
- ids.forEach((id) => next.add(id));
222
- else
223
- ids.forEach((id) => next.delete(id));
269
+ if (checked) {
270
+ ids.forEach((id) => {
271
+ if (!disabledIdSet.has(id))
272
+ next.add(id);
273
+ });
274
+ } else {
275
+ ids.forEach((id) => {
276
+ if (!disabledIdSet.has(id))
277
+ next.delete(id);
278
+ });
279
+ }
224
280
  return next;
225
281
  });
226
282
  setActiveGradeId(gradeId);
@@ -235,10 +291,17 @@ function ClassStudentRoster({
235
291
  });
236
292
  setSelectedIds((prev) => {
237
293
  const next = new Set(prev);
238
- if (checked)
239
- ids.forEach((id) => next.add(id));
240
- else
241
- ids.forEach((id) => next.delete(id));
294
+ if (checked) {
295
+ ids.forEach((id) => {
296
+ if (!disabledIdSet.has(id))
297
+ next.add(id);
298
+ });
299
+ } else {
300
+ ids.forEach((id) => {
301
+ if (!disabledIdSet.has(id))
302
+ next.delete(id);
303
+ });
304
+ }
242
305
  return next;
243
306
  });
244
307
  setActiveGradeId(grade.id);
@@ -249,11 +312,13 @@ function ClassStudentRoster({
249
312
  const grade = grades.find((g) => g.id === gradeId);
250
313
  const cls = (_a = grade == null ? void 0 : grade.classes) == null ? void 0 : _a.find((c) => c.id === classId);
251
314
  const ids = (cls == null ? void 0 : cls.studentIds) || [];
252
- const total = ids.length;
253
- const selectedCount = ids.filter((id) => selectedIds.has(id)).length;
315
+ const selectableIds = ids.filter((id) => !disabledIdSet.has(id));
316
+ const total = selectableIds.length;
317
+ const selectedCount = selectableIds.filter((id) => selectedIds.has(id)).length;
254
318
  return {
255
319
  checked: total > 0 && selectedCount === total,
256
- indeterminate: selectedCount > 0 && selectedCount < total
320
+ indeterminate: selectedCount > 0 && selectedCount < total,
321
+ disabled: total === 0
257
322
  };
258
323
  };
259
324
  const getGradeStatus = (grade) => {
@@ -263,11 +328,13 @@ function ClassStudentRoster({
263
328
  var _a2;
264
329
  return (_a2 = c.studentIds) == null ? void 0 : _a2.forEach((id) => ids.push(id));
265
330
  });
266
- const total = ids.length;
267
- const selectedCount = ids.filter((id) => selectedIds.has(id)).length;
331
+ const selectableIds = ids.filter((id) => !disabledIdSet.has(id));
332
+ const total = selectableIds.length;
333
+ const selectedCount = selectableIds.filter((id) => selectedIds.has(id)).length;
268
334
  return {
269
335
  checked: total > 0 && selectedCount === total,
270
- indeterminate: selectedCount > 0 && selectedCount < total
336
+ indeterminate: selectedCount > 0 && selectedCount < total,
337
+ disabled: total === 0
271
338
  };
272
339
  };
273
340
  const getClassSelectedInfo = (gradeId, classId) => {
@@ -281,7 +348,18 @@ function ClassStudentRoster({
281
348
  total: ids.length
282
349
  };
283
350
  };
284
- const clearAll = () => setSelectedIds(/* @__PURE__ */ new Set());
351
+ const clearAll = () => setSelectedIds((prev) => {
352
+ const next = new Set(prev);
353
+ disabledIdSet.forEach((id) => {
354
+ if (prev.has(id))
355
+ next.add(id);
356
+ });
357
+ prev.forEach((id) => {
358
+ if (!disabledIdSet.has(id))
359
+ next.delete(id);
360
+ });
361
+ return next;
362
+ });
285
363
  const handleSave = () => {
286
364
  const payload = selectedList.map((s) => ({
287
365
  id: s.id,
@@ -339,7 +417,7 @@ function ClassStudentRoster({
339
417
  className: styles.csrModal,
340
418
  children: [/* @__PURE__ */ jsxs("div", {
341
419
  className: styles.csrHeader,
342
- children: [/* @__PURE__ */ jsx("h3", {
420
+ children: [/* @__PURE__ */ jsx("span", {
343
421
  className: styles.csrTitle,
344
422
  children: title
345
423
  }), /* @__PURE__ */ jsx("i", {
@@ -372,33 +450,41 @@ function ClassStudentRoster({
372
450
  }), !loading && !error && grades.map((g) => {
373
451
  var _a;
374
452
  return /* @__PURE__ */ jsxs("div", {
375
- children: [/* @__PURE__ */ jsxs("div", {
376
- className: `${styles.csrTreeItem} ${activeGradeId === g.id && !activeClassId ? styles.csrTreeItemActive : ""}`,
377
- children: [/* @__PURE__ */ jsx("input", {
378
- className: styles.csrCheck,
379
- type: "checkbox",
380
- name: "grade",
381
- checked: getGradeStatus(g).checked,
382
- ref: (el) => {
383
- if (el)
384
- el.indeterminate = getGradeStatus(g).indeterminate;
385
- },
386
- onClick: (e) => e.stopPropagation(),
387
- onChange: (e) => toggleGrade(g, e.target.checked)
388
- }), /* @__PURE__ */ jsx("span", {
389
- className: styles.csrTreeItemText,
453
+ children: [(() => {
454
+ const gradeStatus = getGradeStatus(g);
455
+ return /* @__PURE__ */ jsxs("div", {
390
456
  onClick: () => {
391
457
  setActiveGradeId(g.id);
392
458
  setActiveClassId(null);
393
459
  },
394
- children: g.name
395
- })]
396
- }), /* @__PURE__ */ jsx("div", {
460
+ className: `${styles.csrTreeItem} ${activeGradeId === g.id && !activeClassId ? styles.csrTreeItemActive : ""}`,
461
+ children: [/* @__PURE__ */ jsx("input", {
462
+ className: styles.csrCheck,
463
+ type: "checkbox",
464
+ name: "grade",
465
+ checked: gradeStatus.checked,
466
+ ref: (el) => {
467
+ if (el)
468
+ el.indeterminate = gradeStatus.indeterminate;
469
+ },
470
+ disabled: gradeStatus.disabled,
471
+ onClick: (e) => e.stopPropagation(),
472
+ onChange: (e) => toggleGrade(g, e.target.checked)
473
+ }), /* @__PURE__ */ jsx("span", {
474
+ className: styles.csrTreeItemText,
475
+ children: g.name
476
+ })]
477
+ });
478
+ })(), /* @__PURE__ */ jsx("div", {
397
479
  className: styles.csrTreeChildren,
398
480
  children: (_a = g.classes) == null ? void 0 : _a.map((c) => {
399
481
  const info = getClassSelectedInfo(g.id, c.id);
400
482
  const status = getClassStatus(g.id, c.id);
401
483
  return /* @__PURE__ */ jsxs("div", {
484
+ onClick: () => {
485
+ setActiveGradeId(g.id);
486
+ setActiveClassId(c.id);
487
+ },
402
488
  className: `${styles.csrTreeItem} ${activeClassId === c.id ? styles.csrTreeItemActive : ""}`,
403
489
  children: [/* @__PURE__ */ jsx("input", {
404
490
  className: styles.csrCheck,
@@ -409,14 +495,11 @@ function ClassStudentRoster({
409
495
  if (el)
410
496
  el.indeterminate = status.indeterminate;
411
497
  },
498
+ disabled: status.disabled,
412
499
  onClick: (e) => e.stopPropagation(),
413
500
  onChange: (e) => toggleClass(g.id, c, e.target.checked)
414
501
  }), /* @__PURE__ */ jsx("span", {
415
502
  className: styles.csrTreeItemText,
416
- onClick: () => {
417
- setActiveGradeId(g.id);
418
- setActiveClassId(c.id);
419
- },
420
503
  children: c.name
421
504
  }), /* @__PURE__ */ jsxs("span", {
422
505
  className: styles.csrMeta,
@@ -445,7 +528,12 @@ function ClassStudentRoster({
445
528
  children: [/* @__PURE__ */ jsx("input", {
446
529
  className: styles.csrCheck,
447
530
  type: "checkbox",
448
- checked: activeStudents.length > 0 && activeStudents.every((s) => selectedIds.has(s.id)),
531
+ checked: activeSelectStatus.checked,
532
+ ref: (el) => {
533
+ if (el)
534
+ el.indeterminate = activeSelectStatus.indeterminate;
535
+ },
536
+ disabled: activeSelectStatus.disabled,
449
537
  onChange: (e) => toggleAll(e.target.checked)
450
538
  }), "\u5168\u9009"]
451
539
  }), /* @__PURE__ */ jsxs("span", {
@@ -455,11 +543,12 @@ function ClassStudentRoster({
455
543
  }), /* @__PURE__ */ jsxs("ul", {
456
544
  className: styles.csrList,
457
545
  children: [activeStudents.map((s) => /* @__PURE__ */ jsxs("li", {
458
- className: styles.csrListItem,
546
+ className: `${styles.csrListItem} ${disabledIdSet.has(s.id) ? styles.csrListItemDisabled : ""}`,
459
547
  children: [/* @__PURE__ */ jsx("input", {
460
548
  className: styles.csrCheck,
461
549
  type: "checkbox",
462
550
  checked: selectedIds.has(s.id),
551
+ disabled: disabledIdSet.has(s.id),
463
552
  onChange: () => toggleOne(s.id)
464
553
  }), /* @__PURE__ */ jsx("div", {
465
554
  children: s.name
@@ -495,8 +584,12 @@ function ClassStudentRoster({
495
584
  children: [/* @__PURE__ */ jsx("span", {
496
585
  children: s.name
497
586
  }), /* @__PURE__ */ jsx("i", {
498
- className: `${styles.iconfont} ${styles.deleteIcon}`,
499
- onClick: () => toggleOne(s.id),
587
+ className: `${styles.iconfont} ${styles.deleteIcon} ${disabledIdSet.has(s.id) ? styles.deleteIconDisabled : ""}`,
588
+ onClick: () => {
589
+ if (disabledIdSet.has(s.id))
590
+ return;
591
+ toggleOne(s.id);
592
+ },
500
593
  children: "\uE6A9"
501
594
  })]
502
595
  }, s.id))
@@ -521,4 +614,76 @@ function ClassStudentRoster({
521
614
  })
522
615
  });
523
616
  }
617
+ const iconfont = "_iconfont_15jnl_7";
618
+ const csrMask = "_csrMask_15jnl_14";
619
+ const csrModal = "_csrModal_15jnl_24";
620
+ const csrHeader = "_csrHeader_15jnl_34";
621
+ const csrTitle = "_csrTitle_15jnl_44";
622
+ const csrClose = "_csrClose_15jnl_50";
623
+ const csrBody = "_csrBody_15jnl_62";
624
+ const csrPanel = "_csrPanel_15jnl_69";
625
+ const csrPanelHeader = "_csrPanelHeader_15jnl_81";
626
+ const csrSearch = "_csrSearch_15jnl_86";
627
+ const csrSearchIcon = "_csrSearchIcon_15jnl_102";
628
+ const csrTree = "_csrTree_15jnl_113";
629
+ const csrTreeItem = "_csrTreeItem_15jnl_118";
630
+ const csrTreeItemText = "_csrTreeItemText_15jnl_135";
631
+ const csrMeta = "_csrMeta_15jnl_138";
632
+ const csrTreeItemActive = "_csrTreeItemActive_15jnl_142";
633
+ const csrTreeChildren = "_csrTreeChildren_15jnl_151";
634
+ const csrList = "_csrList_15jnl_154";
635
+ const csrListItem = "_csrListItem_15jnl_161";
636
+ const csrListItemDisabled = "_csrListItemDisabled_15jnl_172";
637
+ const csrOps = "_csrOps_15jnl_194";
638
+ const hasSelected = "_hasSelected_15jnl_205";
639
+ const clearBtn = "_clearBtn_15jnl_210";
640
+ const csrChipWrap = "_csrChipWrap_15jnl_214";
641
+ const csrChipList = "_csrChipList_15jnl_219";
642
+ const deleteIcon = "_deleteIcon_15jnl_227";
643
+ const deleteIconDisabled = "_deleteIconDisabled_15jnl_232";
644
+ const csrChip = "_csrChip_15jnl_214";
645
+ const csrFooter = "_csrFooter_15jnl_251";
646
+ const csrBtn = "_csrBtn_15jnl_258";
647
+ const csrBtnPrimary = "_csrBtnPrimary_15jnl_267";
648
+ const csrBtnCancel = "_csrBtnCancel_15jnl_272";
649
+ const csrEmpty = "_csrEmpty_15jnl_277";
650
+ const csrCheck = "_csrCheck_15jnl_292";
651
+ const csrCheckLabel = "_csrCheckLabel_15jnl_306";
652
+ var index_module = {
653
+ iconfont,
654
+ csrMask,
655
+ csrModal,
656
+ csrHeader,
657
+ csrTitle,
658
+ csrClose,
659
+ csrBody,
660
+ csrPanel,
661
+ csrPanelHeader,
662
+ csrSearch,
663
+ csrSearchIcon,
664
+ csrTree,
665
+ csrTreeItem,
666
+ csrTreeItemText,
667
+ csrMeta,
668
+ csrTreeItemActive,
669
+ csrTreeChildren,
670
+ csrList,
671
+ csrListItem,
672
+ csrListItemDisabled,
673
+ csrOps,
674
+ hasSelected,
675
+ clearBtn,
676
+ csrChipWrap,
677
+ csrChipList,
678
+ deleteIcon,
679
+ deleteIconDisabled,
680
+ csrChip,
681
+ csrFooter,
682
+ csrBtn,
683
+ csrBtnPrimary,
684
+ csrBtnCancel,
685
+ csrEmpty,
686
+ csrCheck,
687
+ csrCheckLabel
688
+ };
524
689
  export { ClassStudentRoster as default };
package/dist/style.css CHANGED
@@ -1 +1 @@
1
- @font-face{font-family:iconfont;src:url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff2?t=1766568844647) format("woff2"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff?t=1766568844647) format("woff"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.ttf?t=1766568844647) format("truetype")}._iconfont_zvw5p_7{font-family:iconfont!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}._csrMask_zvw5p_14{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;font-family:PingFangSC-Regular}._csrModal_zvw5p_24{width:980px;background:#fff;border-radius:11px;box-shadow:0 12px 40px #00000029;display:flex;flex-direction:column;overflow:hidden;font-family:PingFangSC-Regular}._csrHeader_zvw5p_34{height:56px;min-height:56px;padding:0 12px;border-bottom:1px solid #E6E7EC;display:flex;align-items:center;justify-content:center;position:relative}._csrTitle_zvw5p_44{margin:0;font-size:16px;font-weight:600;color:#01113d}._csrClose_zvw5p_50{position:absolute;right:16px;top:50%;border:none;background:transparent;font-size:18px;cursor:pointer;color:#27355a;font-weight:600;margin-top:-9px}._csrBody_zvw5p_62{flex:1;overflow:hidden;display:flex;background:#f5f6f7;padding:12px}._csrPanel_zvw5p_69{background:#fff;border-radius:11px;display:flex;flex-direction:column;min-height:0;flex:1;height:450px}._csrPanel_zvw5p_69:nth-child(2){margin:0 10px}._csrPanelHeader_zvw5p_81{padding:12px 12px 8px;font-weight:600;color:#333}._csrSearch_zvw5p_86{padding:10px 12px;display:flex;align-items:center;position:relative;border-bottom:1px solid #E6E7EC}._csrSearch_zvw5p_86 input{padding:9px 30px 9px 10px;border-radius:7px;border:1px solid #E6E7EC;font-size:14px;width:100%;z-index:1;position:relative}._csrSearch_zvw5p_86 ._csrSearchIcon_zvw5p_102{position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:14px;color:#5a6481;font-weight:600;z-index:2;cursor:pointer}._csrTree_zvw5p_113{flex:1;overflow:auto;padding:10px 12px}._csrTreeItem_zvw5p_118{display:flex;align-items:center;padding:6px 8px 6px 2px;border-radius:4px;cursor:pointer;color:#01113d;font-size:14px;font-family:PingFangSC-Regular;position:relative;margin-bottom:8px;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}._csrTreeItem_zvw5p_118:hover{background:rgba(4,69,252,.06);transform:translate(2px)}._csrTreeItem_zvw5p_118 ._csrTreeItemText_zvw5p_135{padding-right:32px}._csrTreeItem_zvw5p_118 ._csrMeta_zvw5p_138{position:absolute;right:11px}._csrTreeItemActive_zvw5p_142{background:rgba(4,69,252,.05);border-radius:2px;transform:translate(4px)}._csrTreeItemActive_zvw5p_142 span{color:#0445fc;font-weight:500}._csrTreeChildren_zvw5p_151{padding-left:22px}._csrList_zvw5p_154{list-style:none;margin:0;padding:10px 12px 12px;flex:1;overflow:auto}._csrList_zvw5p_154 ._csrListItem_zvw5p_161{display:flex;align-items:center;font-size:14px;font-family:PingFangSC-Regular;padding:8px 4px;margin-bottom:4px;border-radius:4px;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}._csrList_zvw5p_154 ._csrListItem_zvw5p_161:hover{background:rgba(4,69,252,.05);transform:translate(2px)}._csrList_zvw5p_154 ._csrListItem_zvw5p_161:last-child{border-bottom:none}._csrMeta_zvw5p_138{display:flex;align-items:center;gap:6px;font-size:12px;color:#666}._csrOps_zvw5p_185{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:56px;font-size:14px;color:#01113d;font-family:PingFangSC-Regular;border-bottom:1px solid #E6E7EC}._csrOps_zvw5p_185 ._hasSelected_zvw5p_196{font-size:14px;font-weight:500;color:#01113d}._csrOps_zvw5p_185 ._clearBtn_zvw5p_201{color:#0445fc;cursor:pointer}._csrChipWrap_zvw5p_205{flex:1;overflow:auto;padding:10px 12px 12px}._csrChipList_zvw5p_210{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}._csrChipList_zvw5p_210 ._deleteIcon_zvw5p_218{margin-left:8px;cursor:pointer;font-size:14px}._csrChip_zvw5p_205{display:inline-flex;align-items:center;background:#F2F3F5;border-radius:4px;padding:4px 10px;font-size:12px;color:#01113dd9}._csrChip_zvw5p_205 button{border:none;background:transparent;cursor:pointer;color:#666}._csrFooter_zvw5p_238{border-top:1px solid #f0f0f0;padding:12px 16px;display:flex;justify-content:flex-end;gap:12px}._csrBtn_zvw5p_245{min-width:76px;height:32px;border-radius:7px;cursor:pointer;border:1px solid #d9d9d9;background:#fff;font-size:14px}._csrBtnPrimary_zvw5p_254{background:#0445FC;border-color:#0445fc;color:#fff}._csrBtnCancel_zvw5p_259{background:#EDEEF1;border-color:#edeef1;color:#01113d}._csrEmpty_zvw5p_264{color:#01113da6;padding:8px 12px;font-size:13px;display:flex;align-items:center;justify-content:center;flex-direction:column;height:80%}._csrEmpty_zvw5p_264 img{width:120px;height:120px;margin-bottom:12px}._csrCheck_zvw5p_279{margin-right:8px;width:14px;height:14px;accent-color:#0445FC;transition:transform .12s ease}._csrCheck_zvw5p_279:active{transform:scale(.9)}._csrCheckLabel_zvw5p_289{display:flex;align-items:center}
1
+ @font-face{font-family:iconfont;src:url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff2?t=1766568844647) format("woff2"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.woff?t=1766568844647) format("woff"),url(//at.alicdn.com/t/c/font_789461_6fumqpsw41m.ttf?t=1766568844647) format("truetype")}._iconfont_15jnl_7{font-family:iconfont!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}._csrMask_15jnl_14{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;font-family:PingFangSC-Regular}._csrModal_15jnl_24{width:980px;background:#fff;border-radius:11px;box-shadow:0 12px 40px #00000029;display:flex;flex-direction:column;overflow:hidden;font-family:PingFangSC-Regular}._csrHeader_15jnl_34{height:56px;min-height:56px;padding:0 12px;border-bottom:1px solid #E6E7EC;display:flex;align-items:center;justify-content:center;position:relative}._csrTitle_15jnl_44{margin:0;font-size:16px;font-weight:600;color:#01113d}._csrClose_15jnl_50{position:absolute;right:16px;top:50%;border:none;background:transparent;font-size:18px;cursor:pointer;color:#27355a;font-weight:600;margin-top:-9px}._csrBody_15jnl_62{flex:1;overflow:hidden;display:flex;background:#f5f6f7;padding:12px}._csrPanel_15jnl_69{background:#fff;border-radius:11px;display:flex;flex-direction:column;min-height:0;flex:1;height:450px}._csrPanel_15jnl_69:nth-child(2){margin:0 10px}._csrPanelHeader_15jnl_81{padding:12px 12px 8px;font-weight:600;color:#333}._csrSearch_15jnl_86{padding:10px 12px;display:flex;align-items:center;position:relative;border-bottom:1px solid #E6E7EC}._csrSearch_15jnl_86 input{padding:9px 30px 9px 10px;border-radius:7px;border:1px solid #E6E7EC;font-size:14px;width:100%;z-index:1;position:relative}._csrSearch_15jnl_86 ._csrSearchIcon_15jnl_102{position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:14px;color:#5a6481;font-weight:600;z-index:2;cursor:pointer}._csrTree_15jnl_113{flex:1;overflow:auto;padding:10px 12px}._csrTreeItem_15jnl_118{display:flex;align-items:center;padding:6px 8px 6px 2px;border-radius:4px;cursor:pointer;color:#01113d;font-size:14px;font-family:PingFangSC-Regular;position:relative;margin-bottom:8px;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}._csrTreeItem_15jnl_118:hover{background:rgba(4,69,252,.06);transform:translate(2px)}._csrTreeItem_15jnl_118 ._csrTreeItemText_15jnl_135{padding-right:32px}._csrTreeItem_15jnl_118 ._csrMeta_15jnl_138{position:absolute;right:11px}._csrTreeItemActive_15jnl_142{background:rgba(4,69,252,.05);border-radius:2px;transform:translate(4px)}._csrTreeItemActive_15jnl_142 span{color:#0445fc;font-weight:500}._csrTreeChildren_15jnl_151{padding-left:22px}._csrList_15jnl_154{list-style:none;margin:0;padding:10px 12px 12px;flex:1;overflow:auto}._csrList_15jnl_154 ._csrListItem_15jnl_161{display:flex;align-items:center;font-size:14px;font-family:PingFangSC-Regular;padding:8px 4px;margin-bottom:4px;border-radius:4px;color:#01113d;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}._csrList_15jnl_154 ._csrListItemDisabled_15jnl_172{opacity:.55;cursor:not-allowed}._csrList_15jnl_154 ._csrListItem_15jnl_161:hover{background:rgba(4,69,252,.05);transform:translate(2px)}._csrList_15jnl_154 ._csrListItemDisabled_15jnl_172:hover{background:transparent;transform:none}._csrList_15jnl_154 ._csrListItem_15jnl_161:last-child{border-bottom:none}._csrMeta_15jnl_138{display:flex;align-items:center;gap:6px;font-size:12px;color:#666}._csrOps_15jnl_194{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:56px;font-size:14px;color:#01113d;font-family:PingFangSC-Regular;border-bottom:1px solid #E6E7EC}._csrOps_15jnl_194 ._hasSelected_15jnl_205{font-size:14px;font-weight:500;color:#01113d}._csrOps_15jnl_194 ._clearBtn_15jnl_210{color:#0445fc;cursor:pointer}._csrChipWrap_15jnl_214{flex:1;overflow:auto;padding:10px 12px 12px}._csrChipList_15jnl_219{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}._csrChipList_15jnl_219 ._deleteIcon_15jnl_227{margin-left:8px;cursor:pointer;font-size:14px}._csrChipList_15jnl_219 ._deleteIconDisabled_15jnl_232{cursor:not-allowed;opacity:.45}._csrChip_15jnl_214{display:inline-flex;align-items:center;background:#F2F3F5;border-radius:4px;padding:4px 10px;font-size:12px;color:#01113d}._csrChip_15jnl_214 button{border:none;background:transparent;cursor:pointer;color:#666}._csrFooter_15jnl_251{border-top:1px solid #f0f0f0;padding:12px 16px;display:flex;justify-content:flex-end;gap:12px}._csrBtn_15jnl_258{min-width:76px;height:32px;border-radius:7px;cursor:pointer;border:1px solid #d9d9d9;background:#fff;font-size:14px}._csrBtnPrimary_15jnl_267{background:#0445FC;border-color:#0445fc;color:#fff}._csrBtnCancel_15jnl_272{background:#EDEEF1;border-color:#edeef1;color:#01113d}._csrEmpty_15jnl_277{color:#01113da6;padding:8px 12px;font-size:13px;display:flex;align-items:center;justify-content:center;flex-direction:column;height:80%}._csrEmpty_15jnl_277 img{width:120px;height:120px;margin-bottom:12px}._csrCheck_15jnl_292{margin-right:8px;width:14px;height:14px;accent-color:#0445FC;transition:transform .12s ease}._csrCheck_15jnl_292:active{transform:scale(.9)}._csrCheck_15jnl_292:disabled{cursor:not-allowed;opacity:.6}._csrCheckLabel_15jnl_306{display:flex;align-items:center}
package/package.json CHANGED
@@ -1,10 +1,14 @@
1
1
  {
2
2
  "name": "@yungu-fed/class-student-roster",
3
- "version": "0.0.2",
3
+ "version": "0.0.4",
4
4
  "description": "student list under a class or a grade",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "module": "./dist/index.es.js",
7
- "sideEffects": false,
7
+ "style": "./dist/style.css",
8
+ "sideEffects": [
9
+ "*.css",
10
+ "**/*.css"
11
+ ],
8
12
  "files": [
9
13
  "dist"
10
14
  ],
@@ -22,7 +26,7 @@
22
26
  },
23
27
  "devDependencies": {
24
28
  "@vitejs/plugin-react": "^1.3.2",
25
- "less": "^4.2.0",
29
+ "less": "4.2.0",
26
30
  "react": "^18.2.0",
27
31
  "react-dom": "^18.2.0",
28
32
  "vite": "^2.9.16"