@yungu-fed/class-student-roster 0.0.3 → 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 +3 -3
- package/dist/index.es.js +203 -116
- package/dist/style.css +1 -1
- package/package.json +1 -1
package/dist/index.cjs.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
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\")}.
|
|
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
2
|
if (typeof document !== 'undefined') {
|
|
3
3
|
const __id = 'class-student-roster__style';
|
|
4
4
|
if (!document.getElementById(__id)) {
|
|
@@ -8,7 +8,7 @@ if (typeof document !== 'undefined') {
|
|
|
8
8
|
document.head.appendChild(__style);
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var m=require("react");function _(l){return l&&typeof l=="object"&&"default"in l?l:{default:l}}var $=_(m);const ee="_iconfont_zvw5p_7",se="_csrMask_zvw5p_14",ce="_csrModal_zvw5p_24",te="_csrHeader_zvw5p_34",re="_csrTitle_zvw5p_44",ne="_csrClose_zvw5p_50",ae="_csrBody_zvw5p_62",de="_csrPanel_zvw5p_69",ie="_csrPanelHeader_zvw5p_81",oe="_csrSearch_zvw5p_86",Ae="_csrSearchIcon_zvw5p_102",le="_csrTree_zvw5p_113",me="_csrTreeItem_zvw5p_118",ue="_csrTreeItemText_zvw5p_135",he="_csrMeta_zvw5p_138",pe="_csrTreeItemActive_zvw5p_142",we="_csrTreeChildren_zvw5p_151",ve="_csrList_zvw5p_154",Ce="_csrListItem_zvw5p_161",Ie="_csrOps_zvw5p_185",fe="_hasSelected_zvw5p_196",Le="_clearBtn_zvw5p_201",ze="_csrChipWrap_zvw5p_205",ge="_csrChipList_zvw5p_210",Be="_deleteIcon_zvw5p_218",Ee="_csrChip_zvw5p_205",Ne="_csrFooter_zvw5p_238",Me="_csrBtn_zvw5p_245",Pe="_csrBtnPrimary_zvw5p_254",Fe="_csrBtnCancel_zvw5p_259",ye="_csrEmpty_zvw5p_264",be="_csrCheck_zvw5p_279",Ze="_csrCheckLabel_zvw5p_289";var c={iconfont:ee,csrMask:se,csrModal:ce,csrHeader:te,csrTitle:re,csrClose:ne,csrBody:ae,csrPanel:de,csrPanelHeader:ie,csrSearch:oe,csrSearchIcon:Ae,csrTree:le,csrTreeItem:me,csrTreeItemText:ue,csrMeta:he,csrTreeItemActive:pe,csrTreeChildren:we,csrList:ve,csrListItem:Ce,csrOps:Ie,hasSelected:fe,clearBtn:Le,csrChipWrap:ze,csrChipList:ge,deleteIcon:Be,csrChip:Ee,csrFooter:Ne,csrBtn:Me,csrBtnPrimary:Pe,csrBtnCancel:Fe,csrEmpty:ye,csrCheck:be,csrCheckLabel:Ze},H="",W={exports:{}},Z={};/**
|
|
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={};/**
|
|
12
12
|
* @license React
|
|
13
13
|
* react-jsx-runtime.production.min.js
|
|
14
14
|
*
|
|
@@ -16,4 +16,4 @@ if (typeof document !== 'undefined') {
|
|
|
16
16
|
*
|
|
17
17
|
* This source code is licensed under the MIT license found in the
|
|
18
18
|
* LICENSE file in the root directory of this source tree.
|
|
19
|
-
*/var
|
|
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,4 +1,4 @@
|
|
|
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\")}.
|
|
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
2
|
if (typeof document !== 'undefined') {
|
|
3
3
|
const __id = 'class-student-roster__style';
|
|
4
4
|
if (!document.getElementById(__id)) {
|
|
@@ -8,40 +8,42 @@ if (typeof document !== 'undefined') {
|
|
|
8
8
|
document.head.appendChild(__style);
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
import require$$0, { useState,
|
|
12
|
-
const iconfont$1 = "
|
|
13
|
-
const csrMask$1 = "
|
|
14
|
-
const csrModal$1 = "
|
|
15
|
-
const csrHeader$1 = "
|
|
16
|
-
const csrTitle$1 = "
|
|
17
|
-
const csrClose$1 = "
|
|
18
|
-
const csrBody$1 = "
|
|
19
|
-
const csrPanel$1 = "
|
|
20
|
-
const csrPanelHeader$1 = "
|
|
21
|
-
const csrSearch$1 = "
|
|
22
|
-
const csrSearchIcon$1 = "
|
|
23
|
-
const csrTree$1 = "
|
|
24
|
-
const csrTreeItem$1 = "
|
|
25
|
-
const csrTreeItemText$1 = "
|
|
26
|
-
const csrMeta$1 = "
|
|
27
|
-
const csrTreeItemActive$1 = "
|
|
28
|
-
const csrTreeChildren$1 = "
|
|
29
|
-
const csrList$1 = "
|
|
30
|
-
const csrListItem$1 = "
|
|
31
|
-
const
|
|
32
|
-
const
|
|
33
|
-
const
|
|
34
|
-
const
|
|
35
|
-
const
|
|
36
|
-
const
|
|
37
|
-
const
|
|
38
|
-
const
|
|
39
|
-
const
|
|
40
|
-
const
|
|
41
|
-
const
|
|
42
|
-
const
|
|
43
|
-
const
|
|
44
|
-
const
|
|
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";
|
|
45
47
|
var styles = {
|
|
46
48
|
iconfont: iconfont$1,
|
|
47
49
|
csrMask: csrMask$1,
|
|
@@ -62,12 +64,14 @@ var styles = {
|
|
|
62
64
|
csrTreeChildren: csrTreeChildren$1,
|
|
63
65
|
csrList: csrList$1,
|
|
64
66
|
csrListItem: csrListItem$1,
|
|
67
|
+
csrListItemDisabled: csrListItemDisabled$1,
|
|
65
68
|
csrOps: csrOps$1,
|
|
66
69
|
hasSelected: hasSelected$1,
|
|
67
70
|
clearBtn: clearBtn$1,
|
|
68
71
|
csrChipWrap: csrChipWrap$1,
|
|
69
72
|
csrChipList: csrChipList$1,
|
|
70
73
|
deleteIcon: deleteIcon$1,
|
|
74
|
+
deleteIconDisabled: deleteIconDisabled$1,
|
|
71
75
|
csrChip: csrChip$1,
|
|
72
76
|
csrFooter: csrFooter$1,
|
|
73
77
|
csrBtn: csrBtn$1,
|
|
@@ -114,8 +118,11 @@ function ClassStudentRoster({
|
|
|
114
118
|
visible = false,
|
|
115
119
|
onClose,
|
|
116
120
|
onSave,
|
|
121
|
+
data,
|
|
117
122
|
loadData,
|
|
118
|
-
title = "\u9009\u62E9\u5B66\u751F"
|
|
123
|
+
title = "\u9009\u62E9\u5B66\u751F",
|
|
124
|
+
selectedIds: selectedIdsProp = [],
|
|
125
|
+
disableIds: disableIdsProp = []
|
|
119
126
|
}) {
|
|
120
127
|
const [grades, setGrades] = useState([]);
|
|
121
128
|
const [students, setStudents] = useState([]);
|
|
@@ -125,6 +132,7 @@ function ClassStudentRoster({
|
|
|
125
132
|
const [query, setQuery] = useState("");
|
|
126
133
|
const [loading, setLoading] = useState(false);
|
|
127
134
|
const [error, setError] = useState("");
|
|
135
|
+
const disabledIdSet = useMemo(() => new Set(disableIdsProp || []), [disableIdsProp]);
|
|
128
136
|
const normalizeGrades = (res) => {
|
|
129
137
|
if (Array.isArray(res == null ? void 0 : res.grades) && res.grades.length)
|
|
130
138
|
return res.grades;
|
|
@@ -142,8 +150,19 @@ function ClassStudentRoster({
|
|
|
142
150
|
return;
|
|
143
151
|
let mounted = true;
|
|
144
152
|
(async () => {
|
|
145
|
-
var _a, _b;
|
|
153
|
+
var _a, _b, _c, _d;
|
|
146
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
|
+
}
|
|
147
166
|
setLoading(true);
|
|
148
167
|
setError("");
|
|
149
168
|
const res = loadData ? await loadData() : {
|
|
@@ -157,7 +176,7 @@ function ClassStudentRoster({
|
|
|
157
176
|
setStudents(res.students || []);
|
|
158
177
|
const firstGrade = normalizedGrades == null ? void 0 : normalizedGrades[0];
|
|
159
178
|
setActiveGradeId((firstGrade == null ? void 0 : firstGrade.id) || null);
|
|
160
|
-
setActiveClassId(((
|
|
179
|
+
setActiveClassId(((_d = (_c = firstGrade == null ? void 0 : firstGrade.classes) == null ? void 0 : _c[0]) == null ? void 0 : _d.id) || null);
|
|
161
180
|
} catch (e) {
|
|
162
181
|
if (!mounted)
|
|
163
182
|
return;
|
|
@@ -170,7 +189,12 @@ function ClassStudentRoster({
|
|
|
170
189
|
return () => {
|
|
171
190
|
mounted = false;
|
|
172
191
|
};
|
|
173
|
-
}, [visible, loadData]);
|
|
192
|
+
}, [visible, loadData, data]);
|
|
193
|
+
useEffect(() => {
|
|
194
|
+
if (!visible)
|
|
195
|
+
return;
|
|
196
|
+
setSelectedIds(new Set(selectedIdsProp || []));
|
|
197
|
+
}, [visible, selectedIdsProp]);
|
|
174
198
|
const studentMap = useMemo(() => {
|
|
175
199
|
const map = /* @__PURE__ */ new Map();
|
|
176
200
|
students.forEach((s) => map.set(s.id, s));
|
|
@@ -201,7 +225,19 @@ function ClassStudentRoster({
|
|
|
201
225
|
return list;
|
|
202
226
|
}, [activeGradeId, activeClassId, grades, studentMap, query]);
|
|
203
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]);
|
|
204
238
|
const toggleOne = (id) => {
|
|
239
|
+
if (disabledIdSet.has(id))
|
|
240
|
+
return;
|
|
205
241
|
setSelectedIds((prev) => {
|
|
206
242
|
const next = new Set(prev);
|
|
207
243
|
if (next.has(id))
|
|
@@ -213,12 +249,15 @@ function ClassStudentRoster({
|
|
|
213
249
|
};
|
|
214
250
|
const toggleAll = (checked) => {
|
|
215
251
|
if (checked) {
|
|
216
|
-
const ids = activeStudents.map((s) => s.id);
|
|
252
|
+
const ids = activeStudents.filter((s) => !disabledIdSet.has(s.id)).map((s) => s.id);
|
|
217
253
|
setSelectedIds((prev) => /* @__PURE__ */ new Set([...prev, ...ids]));
|
|
218
254
|
} else {
|
|
219
255
|
setSelectedIds((prev) => {
|
|
220
256
|
const next = new Set(prev);
|
|
221
|
-
activeStudents.forEach((s) =>
|
|
257
|
+
activeStudents.forEach((s) => {
|
|
258
|
+
if (!disabledIdSet.has(s.id))
|
|
259
|
+
next.delete(s.id);
|
|
260
|
+
});
|
|
222
261
|
return next;
|
|
223
262
|
});
|
|
224
263
|
}
|
|
@@ -227,10 +266,17 @@ function ClassStudentRoster({
|
|
|
227
266
|
const ids = (cls == null ? void 0 : cls.studentIds) || [];
|
|
228
267
|
setSelectedIds((prev) => {
|
|
229
268
|
const next = new Set(prev);
|
|
230
|
-
if (checked)
|
|
231
|
-
ids.forEach((id) =>
|
|
232
|
-
|
|
233
|
-
|
|
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
|
+
}
|
|
234
280
|
return next;
|
|
235
281
|
});
|
|
236
282
|
setActiveGradeId(gradeId);
|
|
@@ -245,10 +291,17 @@ function ClassStudentRoster({
|
|
|
245
291
|
});
|
|
246
292
|
setSelectedIds((prev) => {
|
|
247
293
|
const next = new Set(prev);
|
|
248
|
-
if (checked)
|
|
249
|
-
ids.forEach((id) =>
|
|
250
|
-
|
|
251
|
-
|
|
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
|
+
}
|
|
252
305
|
return next;
|
|
253
306
|
});
|
|
254
307
|
setActiveGradeId(grade.id);
|
|
@@ -259,11 +312,13 @@ function ClassStudentRoster({
|
|
|
259
312
|
const grade = grades.find((g) => g.id === gradeId);
|
|
260
313
|
const cls = (_a = grade == null ? void 0 : grade.classes) == null ? void 0 : _a.find((c) => c.id === classId);
|
|
261
314
|
const ids = (cls == null ? void 0 : cls.studentIds) || [];
|
|
262
|
-
const
|
|
263
|
-
const
|
|
315
|
+
const selectableIds = ids.filter((id) => !disabledIdSet.has(id));
|
|
316
|
+
const total = selectableIds.length;
|
|
317
|
+
const selectedCount = selectableIds.filter((id) => selectedIds.has(id)).length;
|
|
264
318
|
return {
|
|
265
319
|
checked: total > 0 && selectedCount === total,
|
|
266
|
-
indeterminate: selectedCount > 0 && selectedCount < total
|
|
320
|
+
indeterminate: selectedCount > 0 && selectedCount < total,
|
|
321
|
+
disabled: total === 0
|
|
267
322
|
};
|
|
268
323
|
};
|
|
269
324
|
const getGradeStatus = (grade) => {
|
|
@@ -273,11 +328,13 @@ function ClassStudentRoster({
|
|
|
273
328
|
var _a2;
|
|
274
329
|
return (_a2 = c.studentIds) == null ? void 0 : _a2.forEach((id) => ids.push(id));
|
|
275
330
|
});
|
|
276
|
-
const
|
|
277
|
-
const
|
|
331
|
+
const selectableIds = ids.filter((id) => !disabledIdSet.has(id));
|
|
332
|
+
const total = selectableIds.length;
|
|
333
|
+
const selectedCount = selectableIds.filter((id) => selectedIds.has(id)).length;
|
|
278
334
|
return {
|
|
279
335
|
checked: total > 0 && selectedCount === total,
|
|
280
|
-
indeterminate: selectedCount > 0 && selectedCount < total
|
|
336
|
+
indeterminate: selectedCount > 0 && selectedCount < total,
|
|
337
|
+
disabled: total === 0
|
|
281
338
|
};
|
|
282
339
|
};
|
|
283
340
|
const getClassSelectedInfo = (gradeId, classId) => {
|
|
@@ -291,7 +348,18 @@ function ClassStudentRoster({
|
|
|
291
348
|
total: ids.length
|
|
292
349
|
};
|
|
293
350
|
};
|
|
294
|
-
const clearAll = () => setSelectedIds(
|
|
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
|
+
});
|
|
295
363
|
const handleSave = () => {
|
|
296
364
|
const payload = selectedList.map((s) => ({
|
|
297
365
|
id: s.id,
|
|
@@ -349,7 +417,7 @@ function ClassStudentRoster({
|
|
|
349
417
|
className: styles.csrModal,
|
|
350
418
|
children: [/* @__PURE__ */ jsxs("div", {
|
|
351
419
|
className: styles.csrHeader,
|
|
352
|
-
children: [/* @__PURE__ */ jsx("
|
|
420
|
+
children: [/* @__PURE__ */ jsx("span", {
|
|
353
421
|
className: styles.csrTitle,
|
|
354
422
|
children: title
|
|
355
423
|
}), /* @__PURE__ */ jsx("i", {
|
|
@@ -382,33 +450,41 @@ function ClassStudentRoster({
|
|
|
382
450
|
}), !loading && !error && grades.map((g) => {
|
|
383
451
|
var _a;
|
|
384
452
|
return /* @__PURE__ */ jsxs("div", {
|
|
385
|
-
children: [
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
className: styles.csrCheck,
|
|
389
|
-
type: "checkbox",
|
|
390
|
-
name: "grade",
|
|
391
|
-
checked: getGradeStatus(g).checked,
|
|
392
|
-
ref: (el) => {
|
|
393
|
-
if (el)
|
|
394
|
-
el.indeterminate = getGradeStatus(g).indeterminate;
|
|
395
|
-
},
|
|
396
|
-
onClick: (e) => e.stopPropagation(),
|
|
397
|
-
onChange: (e) => toggleGrade(g, e.target.checked)
|
|
398
|
-
}), /* @__PURE__ */ jsx("span", {
|
|
399
|
-
className: styles.csrTreeItemText,
|
|
453
|
+
children: [(() => {
|
|
454
|
+
const gradeStatus = getGradeStatus(g);
|
|
455
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
400
456
|
onClick: () => {
|
|
401
457
|
setActiveGradeId(g.id);
|
|
402
458
|
setActiveClassId(null);
|
|
403
459
|
},
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
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", {
|
|
407
479
|
className: styles.csrTreeChildren,
|
|
408
480
|
children: (_a = g.classes) == null ? void 0 : _a.map((c) => {
|
|
409
481
|
const info = getClassSelectedInfo(g.id, c.id);
|
|
410
482
|
const status = getClassStatus(g.id, c.id);
|
|
411
483
|
return /* @__PURE__ */ jsxs("div", {
|
|
484
|
+
onClick: () => {
|
|
485
|
+
setActiveGradeId(g.id);
|
|
486
|
+
setActiveClassId(c.id);
|
|
487
|
+
},
|
|
412
488
|
className: `${styles.csrTreeItem} ${activeClassId === c.id ? styles.csrTreeItemActive : ""}`,
|
|
413
489
|
children: [/* @__PURE__ */ jsx("input", {
|
|
414
490
|
className: styles.csrCheck,
|
|
@@ -419,14 +495,11 @@ function ClassStudentRoster({
|
|
|
419
495
|
if (el)
|
|
420
496
|
el.indeterminate = status.indeterminate;
|
|
421
497
|
},
|
|
498
|
+
disabled: status.disabled,
|
|
422
499
|
onClick: (e) => e.stopPropagation(),
|
|
423
500
|
onChange: (e) => toggleClass(g.id, c, e.target.checked)
|
|
424
501
|
}), /* @__PURE__ */ jsx("span", {
|
|
425
502
|
className: styles.csrTreeItemText,
|
|
426
|
-
onClick: () => {
|
|
427
|
-
setActiveGradeId(g.id);
|
|
428
|
-
setActiveClassId(c.id);
|
|
429
|
-
},
|
|
430
503
|
children: c.name
|
|
431
504
|
}), /* @__PURE__ */ jsxs("span", {
|
|
432
505
|
className: styles.csrMeta,
|
|
@@ -455,7 +528,12 @@ function ClassStudentRoster({
|
|
|
455
528
|
children: [/* @__PURE__ */ jsx("input", {
|
|
456
529
|
className: styles.csrCheck,
|
|
457
530
|
type: "checkbox",
|
|
458
|
-
checked:
|
|
531
|
+
checked: activeSelectStatus.checked,
|
|
532
|
+
ref: (el) => {
|
|
533
|
+
if (el)
|
|
534
|
+
el.indeterminate = activeSelectStatus.indeterminate;
|
|
535
|
+
},
|
|
536
|
+
disabled: activeSelectStatus.disabled,
|
|
459
537
|
onChange: (e) => toggleAll(e.target.checked)
|
|
460
538
|
}), "\u5168\u9009"]
|
|
461
539
|
}), /* @__PURE__ */ jsxs("span", {
|
|
@@ -465,11 +543,12 @@ function ClassStudentRoster({
|
|
|
465
543
|
}), /* @__PURE__ */ jsxs("ul", {
|
|
466
544
|
className: styles.csrList,
|
|
467
545
|
children: [activeStudents.map((s) => /* @__PURE__ */ jsxs("li", {
|
|
468
|
-
className: styles.csrListItem
|
|
546
|
+
className: `${styles.csrListItem} ${disabledIdSet.has(s.id) ? styles.csrListItemDisabled : ""}`,
|
|
469
547
|
children: [/* @__PURE__ */ jsx("input", {
|
|
470
548
|
className: styles.csrCheck,
|
|
471
549
|
type: "checkbox",
|
|
472
550
|
checked: selectedIds.has(s.id),
|
|
551
|
+
disabled: disabledIdSet.has(s.id),
|
|
473
552
|
onChange: () => toggleOne(s.id)
|
|
474
553
|
}), /* @__PURE__ */ jsx("div", {
|
|
475
554
|
children: s.name
|
|
@@ -505,8 +584,12 @@ function ClassStudentRoster({
|
|
|
505
584
|
children: [/* @__PURE__ */ jsx("span", {
|
|
506
585
|
children: s.name
|
|
507
586
|
}), /* @__PURE__ */ jsx("i", {
|
|
508
|
-
className: `${styles.iconfont} ${styles.deleteIcon}`,
|
|
509
|
-
onClick: () =>
|
|
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
|
+
},
|
|
510
593
|
children: "\uE6A9"
|
|
511
594
|
})]
|
|
512
595
|
}, s.id))
|
|
@@ -531,39 +614,41 @@ function ClassStudentRoster({
|
|
|
531
614
|
})
|
|
532
615
|
});
|
|
533
616
|
}
|
|
534
|
-
const iconfont = "
|
|
535
|
-
const csrMask = "
|
|
536
|
-
const csrModal = "
|
|
537
|
-
const csrHeader = "
|
|
538
|
-
const csrTitle = "
|
|
539
|
-
const csrClose = "
|
|
540
|
-
const csrBody = "
|
|
541
|
-
const csrPanel = "
|
|
542
|
-
const csrPanelHeader = "
|
|
543
|
-
const csrSearch = "
|
|
544
|
-
const csrSearchIcon = "
|
|
545
|
-
const csrTree = "
|
|
546
|
-
const csrTreeItem = "
|
|
547
|
-
const csrTreeItemText = "
|
|
548
|
-
const csrMeta = "
|
|
549
|
-
const csrTreeItemActive = "
|
|
550
|
-
const csrTreeChildren = "
|
|
551
|
-
const csrList = "
|
|
552
|
-
const csrListItem = "
|
|
553
|
-
const
|
|
554
|
-
const
|
|
555
|
-
const
|
|
556
|
-
const
|
|
557
|
-
const
|
|
558
|
-
const
|
|
559
|
-
const
|
|
560
|
-
const
|
|
561
|
-
const
|
|
562
|
-
const
|
|
563
|
-
const
|
|
564
|
-
const
|
|
565
|
-
const
|
|
566
|
-
const
|
|
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";
|
|
567
652
|
var index_module = {
|
|
568
653
|
iconfont,
|
|
569
654
|
csrMask,
|
|
@@ -584,12 +669,14 @@ var index_module = {
|
|
|
584
669
|
csrTreeChildren,
|
|
585
670
|
csrList,
|
|
586
671
|
csrListItem,
|
|
672
|
+
csrListItemDisabled,
|
|
587
673
|
csrOps,
|
|
588
674
|
hasSelected,
|
|
589
675
|
clearBtn,
|
|
590
676
|
csrChipWrap,
|
|
591
677
|
csrChipList,
|
|
592
678
|
deleteIcon,
|
|
679
|
+
deleteIconDisabled,
|
|
593
680
|
csrChip,
|
|
594
681
|
csrFooter,
|
|
595
682
|
csrBtn,
|
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")}.
|
|
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}
|