@topthink/components 1.0.82 → 1.0.84

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.
@@ -1,4 +1,4 @@
1
- import{jsx as e,jsxs as t,Fragment as r}from"react/jsx-runtime";import n from"rc-table";import{unstable_batchedUpdates as o}from"react-dom";import{FormControl as a,Table as i}from"react-bootstrap";import{useUrlSearchParams as c}from"use-url-search-params";import{isEqual as l,omit as s}from"lodash";import*as d from"react";import{useState as p,useCallback as u,useRef as m,useEffect as h,useMemo as f,memo as g,forwardRef as v,useImperativeHandle as y}from"react";import{B as b,u as x,P as w,a as j,r as C,i as k,N as S,L as E,T as O,C as V,S as z}from"./index-5if674Am.js";import N from"styled-components";import H from"./index-mDUhFN2o.js";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"axios";import"query-string";import"retry-axios";import"rc-notification";import"path";import"classnames";import"copy-to-clipboard";import"react-async-hook";import"immer";import"react-intersection-observer";import"@topthink/json-form";const q=function(t){let{indeterminate:r=!1,...n}=t;const o=m(null);return h((()=>{o.current&&(o.current.indeterminate=r)}),[r]),e("input",{ref:o,...n,className:"form-check-input",type:"checkbox"})};var K;function M(){return M=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},M.apply(this,arguments)}const B=e=>d.createElement("svg",M({xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"currentColor",viewBox:"0 0 1024 1024"},e),K||(K=d.createElement("path",{d:"M252.069 906.496h520.283c89.582 0 134.144-44.562 134.144-132.846V250.331c0-88.283-44.562-132.845-134.144-132.845H252.069c-89.143 0-134.583 44.141-134.583 132.845V773.67c0 88.704 45.44 132.845 134.583 132.845zm1.28-68.992c-42.844 0-66.853-22.71-66.853-67.291V253.806c0-44.58 24.01-67.292 66.853-67.292h517.723c42.423 0 66.432 22.711 66.432 67.292v516.388c0 44.58-24.01 67.292-66.432 67.292zM511.78 714.496c22.71 0 36.425-15.854 36.425-40.704V547.365H682.35c24.009 0 40.722-12.874 40.722-35.584 0-23.132-15.854-36.426-40.722-36.426H548.206V340.773c0-24.85-13.715-40.704-36.425-40.704s-35.566 16.713-35.566 40.722v134.583H342.49c-24.85 0-41.142 13.275-41.142 36.407 0 22.71 17.152 35.584 41.142 35.584h133.724v126.427c0 23.99 12.855 40.704 35.566 40.704"})));var P;function F(){return F=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},F.apply(this,arguments)}const T=e=>d.createElement("svg",F({xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"currentColor",viewBox:"0 0 1024 1024"},e),P||(P=d.createElement("path",{d:"M252.069 906.496h520.283c89.582 0 134.144-44.562 134.144-132.846V250.331c0-88.283-44.562-132.845-134.144-132.845H252.069c-89.143 0-134.583 44.141-134.583 132.845V773.67c0 88.704 45.44 132.845 134.583 132.845zm1.28-68.992c-42.844 0-66.853-22.71-66.853-67.291V253.806c0-44.58 24.01-67.292 66.853-67.292h517.723c42.423 0 66.432 22.711 66.432 67.292v516.388c0 44.58-24.01 67.292-66.432 67.292zm86.582-289.719h344.576c23.991 0 40.704-12.855 40.704-35.566 0-23.15-15.433-36.425-40.704-36.425H339.931c-24.868 0-40.722 13.276-40.722 36.425 0 22.711 16.713 35.566 40.722 35.566"})));function D(r){let{data:n,options:o,columns:a,onSearch:i}=r;const[c,s]=p(0),[d,m]=p(n);h((()=>{l(n,d)||(m(n),s((e=>e+1)))}),[n]);const[g,v,y]=f((()=>{const e={"ui:col":10,"ui:order":o.order},t={},r={};o.fields.forEach((n=>{const i=a.find((e=>e.dataIndex===n));if(i){const a=i.title;if("string"==typeof a){if(e[n]={"ui:col":4,"ui:labelCol":3,"ui:placeholder":"请输入",...o.ui?.[n]},i.valueEnum){const t=i.valueEnum;return e[n]["ui:placeholder"]="请选择",r[n]={title:a,type:"string",enum:Object.keys(t).flatMap((e=>"string"==typeof t[e].text?[e]:[])),enumNames:Object.keys(t).flatMap((e=>{const r=t[e].text;return"string"==typeof r?[r]:[]}))}}t[n]=void 0,r[n]={title:a,type:"string"}}}})),o.extraFields&&Object.entries(o.extraFields).forEach((n=>{let[a,i]=n;e[a]={"ui:col":4,"ui:labelCol":3,"ui:placeholder":"请输入",...o.ui?.[a]},t[a]=void 0,r[a]={title:i,type:"string"}}));return[{type:"object",properties:r},e,t]}),[o.fields,o.extraFields]),x=u((e=>{let{formData:t}=e;m(t),i({...y,...t})}),[i,y]),w=u((()=>{i(y)}),[i,y]);return e(I,{children:e(H,{formContext:{layout:"horizontal"},schema:g,uiSchema:v,onSubmit:x,formData:d,children:e("div",{className:"col-2 ms-auto mt-auto",children:t("div",{className:"justify-content-end d-flex gap-2 ",children:[e(b,{className:"px-4",onClick:w,variant:"secondary",children:"重置"}),e(b,{className:"px-4",type:"submit",variant:"primary",children:"查询"})]})})})},c)}const I=N.div`
1
+ import{jsx as e,jsxs as t,Fragment as r}from"react/jsx-runtime";import n from"rc-table";import{unstable_batchedUpdates as o}from"react-dom";import{FormControl as a,Table as i}from"react-bootstrap";import{useUrlSearchParams as c}from"use-url-search-params";import{isEqual as l,omit as s}from"lodash";import*as d from"react";import{useState as p,useCallback as u,useRef as m,useEffect as h,useMemo as f,memo as g,forwardRef as v,useImperativeHandle as y}from"react";import{B as b,u as x,P as w,a as j,r as C,i as k,N as S,L as E,T as O,C as V,S as z}from"./index-d-ZBuSZk.js";import N from"styled-components";import H from"./index-XaJA29YW.js";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"axios";import"query-string";import"retry-axios";import"notistack";import"path";import"classnames";import"copy-to-clipboard";import"react-async-hook";import"immer";import"react-intersection-observer";import"@topthink/json-form";const q=function(t){let{indeterminate:r=!1,...n}=t;const o=m(null);return h((()=>{o.current&&(o.current.indeterminate=r)}),[r]),e("input",{ref:o,...n,className:"form-check-input",type:"checkbox"})};var K;function M(){return M=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},M.apply(this,arguments)}const B=e=>d.createElement("svg",M({xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"currentColor",viewBox:"0 0 1024 1024"},e),K||(K=d.createElement("path",{d:"M252.069 906.496h520.283c89.582 0 134.144-44.562 134.144-132.846V250.331c0-88.283-44.562-132.845-134.144-132.845H252.069c-89.143 0-134.583 44.141-134.583 132.845V773.67c0 88.704 45.44 132.845 134.583 132.845zm1.28-68.992c-42.844 0-66.853-22.71-66.853-67.291V253.806c0-44.58 24.01-67.292 66.853-67.292h517.723c42.423 0 66.432 22.711 66.432 67.292v516.388c0 44.58-24.01 67.292-66.432 67.292zM511.78 714.496c22.71 0 36.425-15.854 36.425-40.704V547.365H682.35c24.009 0 40.722-12.874 40.722-35.584 0-23.132-15.854-36.426-40.722-36.426H548.206V340.773c0-24.85-13.715-40.704-36.425-40.704s-35.566 16.713-35.566 40.722v134.583H342.49c-24.85 0-41.142 13.275-41.142 36.407 0 22.71 17.152 35.584 41.142 35.584h133.724v126.427c0 23.99 12.855 40.704 35.566 40.704"})));var P;function F(){return F=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},F.apply(this,arguments)}const T=e=>d.createElement("svg",F({xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"currentColor",viewBox:"0 0 1024 1024"},e),P||(P=d.createElement("path",{d:"M252.069 906.496h520.283c89.582 0 134.144-44.562 134.144-132.846V250.331c0-88.283-44.562-132.845-134.144-132.845H252.069c-89.143 0-134.583 44.141-134.583 132.845V773.67c0 88.704 45.44 132.845 134.583 132.845zm1.28-68.992c-42.844 0-66.853-22.71-66.853-67.291V253.806c0-44.58 24.01-67.292 66.853-67.292h517.723c42.423 0 66.432 22.711 66.432 67.292v516.388c0 44.58-24.01 67.292-66.432 67.292zm86.582-289.719h344.576c23.991 0 40.704-12.855 40.704-35.566 0-23.15-15.433-36.425-40.704-36.425H339.931c-24.868 0-40.722 13.276-40.722 36.425 0 22.711 16.713 35.566 40.722 35.566"})));function D(r){let{data:n,options:o,columns:a,onSearch:i}=r;const[c,s]=p(0),[d,m]=p(n);h((()=>{l(n,d)||(m(n),s((e=>e+1)))}),[n]);const[g,v,y]=f((()=>{const e={"ui:col":10,"ui:order":o.order},t={},r={};o.fields.forEach((n=>{const i=a.find((e=>e.dataIndex===n));if(i){const a=i.title;if("string"==typeof a){if(e[n]={"ui:col":4,"ui:labelCol":3,"ui:placeholder":"请输入",...o.ui?.[n]},i.valueEnum){const t=i.valueEnum;return e[n]["ui:placeholder"]="请选择",r[n]={title:a,type:"string",enum:Object.keys(t).flatMap((e=>"string"==typeof t[e].text?[e]:[])),enumNames:Object.keys(t).flatMap((e=>{const r=t[e].text;return"string"==typeof r?[r]:[]}))}}t[n]=void 0,r[n]={title:a,type:"string"}}}})),o.extraFields&&Object.entries(o.extraFields).forEach((n=>{let[a,i]=n;e[a]={"ui:col":4,"ui:labelCol":3,"ui:placeholder":"请输入",...o.ui?.[a]},t[a]=void 0,r[a]={title:i,type:"string"}}));return[{type:"object",properties:r},e,t]}),[o.fields,o.extraFields]),x=u((e=>{let{formData:t}=e;m(t),i({...y,...t})}),[i,y]),w=u((()=>{i(y)}),[i,y]);return e(I,{children:e(H,{formContext:{layout:"horizontal"},schema:g,uiSchema:v,onSubmit:x,formData:d,children:e("div",{className:"col-2 ms-auto mt-auto",children:t("div",{className:"justify-content-end d-flex gap-2 ",children:[e(b,{className:"px-4",onClick:w,variant:"secondary",children:"重置"}),e(b,{className:"px-4",type:"submit",variant:"primary",children:"查询"})]})})})},c)}const I=N.div`
2
2
  margin-bottom: 1rem;
3
3
  `;function R(t){let{keyword:r,onKeywordChange:n}=t;const[o,i]=p(r),c=x(n,500);h((()=>{i(r)}),[r]);const l=u((e=>{i(e.target.value),c(e.target.value)}),[c,i]);return e(a,{value:o,onChange:l,type:"search",placeholder:"Search..."})}const _=N.thead`
4
4
  th {
@@ -0,0 +1 @@
1
+ import{jsx as t}from"react/jsx-runtime";import o,{getRegistry as r}from"@topthink/json-form";import*as a from"react";import{forwardRef as e,useState as n,useCallback as i}from"react";import s from"axios";import{b as p,r as m,B as l}from"./index-d-ZBuSZk.js";import{mapValues as c}from"lodash";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"react-bootstrap";import"query-string";import"retry-axios";import"notistack";import"path";import"styled-components";import"classnames";import"use-url-search-params";import"copy-to-clipboard";import"react-async-hook";import"immer";import"react-intersection-observer";const d=require("ajv-i18n/localize/zh"),u=a.lazy((()=>import("./editor-widget-CQ3zv-Xu.js"))),f=o=>t(a.Suspense,{fallback:null,children:t(u,{...o})}),h={upload:function(o){let{options:a,...e}=o;const{widgets:n}=r();return a.endpoint&&(a.onUpload=async t=>{const o=new FormData;o.set("file",t);const{url:r,value:e}=await m({url:a.endpoint,method:"post",data:o});return{url:r,value:e}}),t(n.upload,{...e,options:a})},avatar:function(o){let{options:a,...e}=o;const{widgets:n}=r();return a.endpoint&&(a.onUpload=async t=>{const o=new FormData;o.set("file",t);const{url:r}=await m({url:a.endpoint,method:"post",data:o});return r}),t(n.avatar,{...e,options:a})},editor:function(o){let{options:r,...a}=o;return r.endpoint&&(r.onUpload=async t=>{const o=new FormData;o.set("file",t);const{url:a}=await m({url:r.endpoint,method:"post",data:o});return a}),t(f,{...a,options:r})},typeahead:function(o){let{options:a,...e}=o;const{widgets:n}=r();return a.endpoint&&(a.onSearch=async t=>{let{value:o,query:r}=t;return await m({url:a.endpoint,params:{value:o,query:r}})}),t(n.typeahead,{...e,options:a})}},y=e(((r,a)=>{let{action:e,method:u="post",onSuccess:f,formData:y,onSubmitting:w,onSubmit:g,onChange:b,submitText:v="提交",transformData:x,children:D,...j}=r;const[S,k]=n(),[q,_]=p(!1),[z,E]=n(y),F=i((async(t,o)=>{if(!q)try{if(_(!0),w&&w(!0),e){let{formData:o}=t;x&&(o=x(o));try{const t=await m({url:e,method:u,data:o});return k(void 0),f&&await f(t),t}catch(t){if(!s.isAxiosError(t))throw t;k((t=>{const o=t.errors;return"string"==typeof o?{__errors:[o]}:c(o,(t=>({__errors:[t]})))})(t))}}else if(g)return await g(t,o)}finally{_(!1),w&&w(!1)}}),[e,u,g]),U=i((t=>{const{formData:o}=t;E(o),b&&b(t)}),[E,b]),C=i((t=>(t=t.map((t=>({keyword:t.name,dataPath:t.property,...t}))),d(t),t)),[]),N=t(l,{className:"px-4",loading:q,type:"submit",variant:"primary",children:v});return"function"==typeof D&&(D=D({submit:N,loading:q})),t(o,{ref:a,extraErrors:S,onSubmit:F,transformErrors:C,noHtml5Validate:!0,noValidate:!0,...j,formData:z,onChange:U,widgets:h,children:D||t("div",{className:"col-12",children:N})})}));export{y as default};
@@ -0,0 +1,72 @@
1
+ import e from"sweetalert2/dist/sweetalert2.js";import t from"sweetalert2-react-content";import{jsx as n,jsxs as r,Fragment as o}from"react/jsx-runtime";import{useRef as i,useState as a,useEffect as s,createContext as c,Fragment as l,useContext as d,useCallback as u,useMemo as f,forwardRef as m,Children as h,lazy as p,Suspense as g,createElement as y,useImperativeHandle as b,memo as v}from"react";import{OverlayTrigger as x,Tooltip as w,Spinner as k,Button as C,Modal as N,Card as S,Alert as j,Pagination as z,Offcanvas as T,Row as P,Col as B}from"react-bootstrap";import{uniqueId as H,values as $,debounce as E}from"lodash";import D from"axios";import F from"query-string";import*as A from"retry-axios";import{enqueueSnackbar as M}from"notistack";import L from"path";import O,{css as _}from"styled-components";import I from"classnames";import{useUrlSearchParams as R}from"use-url-search-params";import U from"copy-to-clipboard";import{useAsyncCallback as q}from"react-async-hook";import{freeze as G,produce as V}from"immer";import"react-intersection-observer";const K=t(e),J={confirmButtonText:"确定",cancelButtonText:"取消"},Y={confirm:async e=>{const{isConfirmed:t}=await K.fire({...J,icon:"warning",showCancelButton:!0,...e,async preConfirm(t){if(e.preConfirm)try{return await e.preConfirm(t)}catch(e){return e instanceof Error&&K.showValidationMessage(e.message),!1}return!0}});return t},success:e=>{K.fire({...J,toast:!0,position:"top",icon:"success",timer:2e3,showConfirmButton:!1,...e})},error:e=>{K.fire({...J,toast:!0,position:"top",icon:"error",timer:5e3,showConfirmButton:!1,...e})},close:e=>{K.close(e)},defaults:J};const Q=c({});function W(e){return t=>{let{resolve:r,destroy:o,message:c}=t;const[l,m]=function(e){const t=i(null),[n,r]=a(e);return s((()=>{t.current&&(t.current(),t.current=null)}),[n]),[n,(e,n)=>{t.current="function"==typeof n?n:null,r(e)}]}(!0),h=d(Q),p=u((e=>{m(!1,(()=>{r(e)}))}),[m,r]),g=f((()=>({show:l,onHide:()=>p(),onExited:()=>o(),container:h.container})),[l,p,o]);return n(e,{resolve:p,state:g,message:c})}}function X(e){return t=>new Promise((r=>{const o=n(e,{resolve:r,destroy:()=>{ne(o)},message:t});te(o)}))}let Z=()=>{},ee=new Set;const te=e=>{ee=new Set(ee),ee.add(e),Z(ee)},ne=e=>{ee=new Set(ee),ee.delete(e),Z(ee)};function re(e,t){return X(W(e))(t)}function oe(e){let{tooltip:t,children:r,placement:o="bottom"}=e;return n(x,{placement:o,overlay:n(w,{id:H(),children:t}),children:r})}const ie=c(!1),ae=m(((e,t)=>{let{loading:i,percent:a,disabled:s,children:c,tooltip:l,variant:u,...f}=e;d(ie)&&!u&&(u="link"),i&&(s=!0,c=r(o,{children:[n(k,{ref:t,as:"span",size:"sm",role:"status","aria-hidden":"true",animation:"border"}),a?r("span",{className:"ms-2",children:[a,"%"]}):null]}));const m=n(C,{ref:t,...f,variant:u,disabled:s,children:c});return l?n(oe,{tooltip:l,children:n("span",{className:"d-inline-block",children:m})}):m})),se=function(e){let{state:t,message:{title:o,message:i,okText:a,cancelText:s},resolve:c}=e;return r(N,{...t,children:[n(N.Header,{children:n(N.Title,{as:"h5",children:o||"确认"})}),n(N.Body,{children:i}),r(N.Footer,{children:[n(ae,{variant:"secondary",onClick:()=>c(),children:s||"取消"}),n(ae,{onClick:()=>c(!0),children:a||"确定"})]})]})};const ce=e=>{let{header:t,children:i,footer:s,closable:c=!0,show:l,cancelText:d="取消",okText:u="确定",onOk:m,onCancel:h,onHide:p,okButtonProps:g,bodyAs:y,headerAs:b="h5",confirmLoading:v=!1,...x}=e;const[w,k]=a(!1),C=f((()=>n(ae,{loading:w||v,variant:"primary",onClick:async e=>{k(!0);try{await(m?.(e)),e.defaultPrevented||p?.()}finally{k(!1)}},...g,children:u})),[g,u,m,p,w,v]),S=f((()=>n(ae,{variant:"secondary",onClick:e=>{h?.(e),e.defaultPrevented||p?.()},children:d})),[h,p,d]);switch(typeof s){case"undefined":s=r(o,{children:[S,C]});break;case"function":s=s({okButton:C,cancelButton:S})}return r(N,{...x,onHide:p,show:l,children:[t&&n(N.Header,{closeButton:c,children:n(N.Title,{as:b,children:t})}),n(N.Body,{as:y,children:i}),s&&n(N.Footer,{children:s})]})};ce.Message=function(e){const[t,r]=a(ee);return s((()=>{Z=r}),[]),n(Q.Provider,{value:e,children:Array.from(t).map(((e,t)=>n(l,{children:e},`message-${t}`)))})},ce.confirm=function(e){return X(W(se))(e)},ce.show=re;const le=["default","error","warning","success","info"].reduce(((e,t)=>(e[t]=(e,n)=>M(e,{variant:t,autoHideDuration:3e3,anchorOrigin:{vertical:"top",horizontal:"center"},...n}),e)),{});function de(e){return e&&"object"==typeof e}A.attach(),D.defaults.raxConfig={retryDelay:2e3,backoffType:"static",shouldRetry:e=>{let{config:t,response:n}=e;return!(t.raxConfig?.retryDecider&&!t.raxConfig.retryDecider())&&("GET"===t.method?.toUpperCase()&&449===n?.status)}},D.defaults.maxContentLength=1/0,D.defaults.maxBodyLength=1/0,D.defaults.baseURL="/api",D.defaults.authTokenName="authorization",D.interceptors.request.use((e=>{const t=e.authTokenName;if(t){const n=localStorage.getItem(t);n&&(e.headers={Authorization:`Bearer ${n}`,...e.headers})}return e}),(e=>Promise.reject(e))),D.interceptors.response.use((e=>(201===e.status&&e.data.location&&(window.location.href=e.data.location,e.data=void 0),e)),(e=>{if(D.isAxiosError(e)&&e.response){const{data:t,status:n}=e.response;401===n?e.errors="Unauthorized":de(t)?422===n?e.errors=t:"message"in t&&(e.errors=t.message):e.errors=t,"string"!=typeof e.errors?e.message=Object.values(e.errors).join("<br />"):e.message=e.errors}return Promise.reject(e)}));const ue=D.isAxiosError,fe=e=>{if(!D.isAxiosError(e))throw e;le.error(e.message)},me=async function(e){if(e="string"==typeof e?{url:e}:e,(e={paramsSerializer:function(e){return F.stringify(e,{sort:!1,skipNull:!0,skipEmptyString:!0,arrayFormat:"bracket"})},...e}).onMessage){let t=0,n="",r=null;const o=e.onMessage;e.onDownloadProgress=e=>{const i=e.target,{responseText:a}=i;for(;t<e.loaded;){const e=a.substring(t,++t);if(n+=e,"\n"===e){if(r||(r={id:"",event:"",data:""}),"\n"===n)o(r),r=null;else{const e=n.match(/^data:(?<data>.*)/);e&&(r.data=e.groups.data.trim())}n=""}}}}const{data:t}=await D.request(e);return t};me.defaults=D.defaults,me.interceptors=D.interceptors;function he(e){const t=(()=>{const e=i(!1);return s((()=>(e.current=!1,()=>{e.current=!0})),[]),e})(),[n,r]=a(e);return[n,u((e=>{t.current||r(e)}),[])]}const pe=function(e){let{state:t,message:r,resolve:o}=e;const a=i(!0),{result:c,checkUrl:l,onComplete:d}=r,[u,f]=he(!1);return s((()=>{me({url:l,method:"post",data:{order_no:c.order_no},raxConfig:{shouldRetry:e=>a.current&&449===e.response?.status}}).then((()=>{d?.(),o()})).catch((()=>null))}),[]),n(ce,{...t,centered:!0,onHide:()=>{a.current=!1,t.onHide()},backdrop:"static",header:"支付结果",okText:"已完成支付",okButtonProps:{loading:u},onOk:async e=>{e.preventDefault();try{f(!0),await me({url:l,method:"post",data:{order_no:c.order_no},raxConfig:{shouldRetry:()=>!1}}),d?.(),o()}catch{}finally{f(!1)}},cancelText:"取消",children:"请在新打开的页面上进行支付,支付完成后再关闭此窗口"})};function ge(e){const{result:t}=e;window.open(t.pay_url),re(pe,e)}function ye(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:2;return e>=1024**3?(e/1024**3).toFixed(t)+"G":e>=1048576?(e/1048576).toFixed(t)+"M":(e/1024).toFixed(t)+"K"}function be(e){const t=L.extname(e);return!(!/^data:image\//.test(e)&&!/(webp|svg|png|gif|jpg|jpeg|jfif|bmp|dpg|ico)$/i.test(t))||!/^data:/.test(e)&&!t}function ve(e){const t=document.createElement("a");return t.href=e,t.href}const xe=O.div`
2
+ padding: 48px 32px;
3
+ `,we=O.div`
4
+ margin-bottom: 24px;
5
+ text-align: center;
6
+ font-size: 72px;
7
+ `,ke=O.div`
8
+ color: rgba(0, 0, 0, .85);
9
+ font-size: 24px;
10
+ line-height: 1.8;
11
+ text-align: center;
12
+ `,Ce=O.div`
13
+ margin-top: 32px;
14
+ text-align: center;
15
+ `,Ne={success:n("i",{className:"bi bi-check-circle-fill text-success"}),error:n("i",{className:"bi bi-exclamation-circle-fill text-danger"}),info:n("i",{className:"bi bi-info-circle-fill text-info"}),warning:n("i",{className:"bi bi-exclamation-triangle-fill text-warning"})};function Se(e){let{status:t,title:o,icon:i,extra:a}=e;return!i&&t&&(i=Ne[t]),r(xe,{children:[i&&n(we,{children:i}),o&&n(ke,{children:o}),a&&n(Ce,{children:a})]})}O.div`
16
+ position: relative;
17
+ `;const je=O.div`
18
+ display: ${e=>e.active?"flex":"none"};
19
+ position: absolute;
20
+ top: 0 !important;
21
+ left: 0 !important;
22
+ width: 100%;
23
+ height: 100%;
24
+ text-align: center;
25
+ vertical-align: middle;
26
+ padding: 1em;
27
+ background-color: ${e=>e.inverted?"rgba(255, 255, 255, .85)":"rgba(0, 0, 0, .85)"};
28
+ opacity: ${e=>e.active?1:0};
29
+ line-height: 1;
30
+ animation-fill-mode: both;
31
+ animation-duration: .5s;
32
+ transition: background-color .5s linear;
33
+ flex-direction: column;
34
+ align-items: center;
35
+ justify-content: center;
36
+ user-select: none;
37
+ will-change: opacity;
38
+ z-index: 990;
39
+ `;function ze(e){let{loading:t=!0,children:o,variant:i="primary",animation:a="border",wrap:s,...c}=e;return t?(o&&(o=n("p",{className:"mt-3 text-secondary",children:o})),o=r(je,{inverted:!0,active:!0,children:[n(k,{animation:a,variant:i,...c}),o]}),s?n(Te,{$height:"number"==typeof s?s:150,children:o}):o):null}const Te=O.div`
40
+ position: relative;
41
+ height: ${e=>`${e.$height}px`};
42
+ `;function Pe(e){let{children:t,title:i,className:a,...s}=e;return n(S,{className:I("border-0 shadow-sm mb-3",a),...s,children:r("div",{className:"card-body",children:[i&&r(o,{children:[n("h5",{children:i}),n("hr",{})]}),t]})})}function Be(e){let{errors:t}=e;return t?n(j,{variant:"danger",children:n("ul",{className:"mb-0",children:"string"==typeof t?n("li",{children:t}):Object.entries(t).map((e=>{let[t,r]=e;return n("li",{children:r},t)}))})}):null}function He(e){let{children:t,className:r,size:o="small",direction:i="horizontal"}=e;"string"==typeof o&&(o={small:8,middle:16,large:24}[o]);const a=h.map(t,(e=>{if(e)return n(Ee,{children:e})}));return n($e,{className:r,$direction:i,$size:o,children:a})}const $e=O.div`
43
+ display: inline-flex;
44
+ align-items: center;
45
+ gap: ${e=>e.$size}px;
46
+
47
+ ${e=>"vertical"===e.$direction&&_`
48
+ display: flex;
49
+ flex-direction: column;
50
+ align-items: inherit;
51
+ `}
52
+ `,Ee=O.div`
53
+
54
+ `,De=p((()=>import("./steps-b_BcYIwk.js"))),Fe=p((()=>import("./steps-b_BcYIwk.js").then((e=>{let{Step:t}=e;return{default:t}}))));function Ae(e){return n(g,{fallback:null,children:n(De,{...e})})}const Me=function(e){return n(g,{fallback:null,children:n(Fe,{...e})})};function Le(e){let{title:t,content:o,footer:i}=e;return r(Pe,{children:[n(Ie,{children:t}),n(_e,{children:o}),i&&n(Oe,{children:i})]})}Ae.Step=Me;const Oe=O.div`
55
+ margin-top: 9px;
56
+ padding-top: 10px;
57
+ border-top: 1px solid #f0f0f0;
58
+ color: rgba(0, 0, 0, .65);
59
+ `,_e=O.div`
60
+ color: rgba(0, 0, 0, .85);
61
+ font-size: 24px;
62
+ `,Ie=O.div`
63
+ margin-bottom: 4px;
64
+ color: rgba(0, 0, 0, .45);
65
+ font-size: 1.1rem;
66
+ `;function Re(){}function Ue(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e}function qe(e){return"current_page"in e}function Ge(e){let{total:t=0,onChange:r=Re,defaultCurrent:o=1,defaultPageSize:i=10,className:c,...l}=e;const[d,m]=a(o),[h,p]=a(i);s((()=>{Ue(l.current)&&m(l.current)}),[l.current]),s((()=>{Ue(l.pageSize)&&p(l.pageSize)}),[l.pageSize]);const g=f((()=>Math.floor((t-1)/h)+1),[t,h]),y=u((e=>()=>{e!==d&&(m(e),r(e,h))}),[r,d,h]),b=d-1>0?d-1:0,v=d+1<g?d+1:g,x=[];let w=null,k=null,C=null,N=null;if(g<=7)for(let e=1;e<=g;e+=1){const t=d===e;x.push(n(z.Item,{active:t,onClick:y(e),children:e},e))}else{N=n(z.Last,{onClick:y(g)},"last"),C=n(z.First,{onClick:y(1)},"first"),w=n(z.Prev,{onClick:y(b)},"prev"),k=n(z.Next,{onClick:y(v)},"next");let e=Math.max(1,d-2),t=Math.min(d+2,g);d-1<=2&&(t=5),g-d<=2&&(e=g-4);for(let r=e;r<=t;r+=1){const e=d===r;x.push(n(z.Item,{active:e,onClick:y(r),children:r},r))}d-1>=4&&3!==d&&x.unshift(w),g-d>=4&&d!==g-2&&x.push(k),1!==e&&x.unshift(C),t!==g&&x.push(N)}return n(z,{className:c,children:x})}function Ve(e){let{className:t,value:r,locale:i="zh-CN",currency:a=!0,options:s={}}=e;const c=f((()=>{let e;return e=a?{style:"currency",currency:"CNY"}:{minimumFractionDigits:2},new Intl.NumberFormat(i,{...e,...s})}),[a,i,s]);return t?n("span",{className:t,children:c.format(r)}):n(o,{children:c.format(r)})}function Ke(e){let{loading:t,disabled:r,children:o,...i}=e;return n(C,{...i,disabled:t||r,children:t?"Loading…":o})}const Je=p((()=>import("./image-zoom-OrIPGqh0.js")));function Ye(e){return n(g,{fallback:null,children:n(Je,{...e})})}const Qe=m(((e,t)=>{let{url:n,method:r,confirm:o,onSuccess:i,children:a,disabled:s,as:c=ae,onError:l,...d}=e;const[f,m]=he(!1),h=u((async e=>{e.preventDefault();try{if(m(!0),o&&!await ce.confirm({message:o}))return;const e="string"==typeof n?{url:n,method:r}:{method:r,...n},t=await me(e);i&&i(t)}catch(e){if(!(e instanceof Error))throw e;l?l(e):le.error(e.message,{preventDuplicate:!0})}finally{m(!1)}}),[n,r,m]);return y(c,{...d,disabled:s||f,onClick:h,ref:t},a)})),We=p((()=>import("./index-XaJA29YW.js"))),Xe=m(((e,t)=>n(g,{fallback:null,children:n(We,{...e,ref:t})}))),Ze=p((()=>import("./index-GuEnWNPt.js"))),et=m(((e,t)=>n(g,{fallback:null,children:n(Ze,{...e,ref:t})})));let tt=0;function nt(){let{onHide:e,onShow:t}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const[n,r]=a(!1),[o,i]=a(`visible-${tt}`),s=u((()=>{r(!1),e&&e()}),[r,e]),c=u((()=>{i("visible-"+ ++tt)}),[i,tt]);return{visible:n,show:u((()=>{r(!0),t&&t()}),[r,t]),hide:s,state:{show:n,onHide:s,onExited:c,key:o}}}const rt=m(((e,t)=>{let{text:i,onOk:a,modalProps:s,children:c,onShow:l,onHide:d,confirmLoading:u,as:f=ae,...m}=e;const{state:h,show:p,hide:g}=nt({onShow:l,onHide:d});b(t,(()=>({close:g})));const v=y(f,{...m,onClick:p},i);return r(o,{children:[v,n(ce,{header:i,...s,...h,confirmLoading:u,onOk:async e=>{if(a){!1===await a()&&e.preventDefault()}},children:c})]})})),ot=m(((e,t)=>{let{text:o,onSuccess:s,onSubmit:c,buttonProps:l,modalProps:d,children:f,...m}=e;const[h,p]=a(!1),g=i(null),y=i(null);b(t,(()=>({close:()=>{g.current?.close()}})));const v=u((()=>(y.current?.submit(),!1)),[]),x=u((e=>{s&&s(e),g.current?.close()}),[s]),w=u((async(e,t)=>{c&&await c(e,t)&&g.current?.close()}),[c]);return n(rt,{ref:g,text:o,...l,modalProps:d,onOk:v,confirmLoading:h,children:r(Xe,{...m,onSubmitting:p,ref:y,onSuccess:x,onSubmit:w,children:[f,n("input",{type:"submit",hidden:!0})]})})}));function it(e){let{header:t,children:o,closable:i=!0,show:a,onHide:s,bodyAs:c,headerAs:l="h5",...d}=e;return r(T,{...d,onHide:s,show:a,children:[t&&n(T.Header,{closeButton:i,children:n(T.Title,{as:l,children:t})}),n(T.Body,{as:c,children:o})]})}const at=m(((e,t)=>{let{text:i,offcanvasProps:a,children:s,onShow:c,onHide:l,as:d=ae,...u}=e;const{state:f,show:m,hide:h}=nt({onShow:c,onHide:l});b(t,(()=>({close:h})));const p=y(d,{...u,onClick:m},i);return r(o,{children:[p,n(it,{header:i,...a,...f,children:s})]})}));function st(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];const n=i(e);return s((()=>{n.current=e})),u((function(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return n.current?.(...t)}),t)}function ct(e){const{value:t,defaultValue:n,onChange:r,shouldUpdate:o=((e,t)=>e!==t)}=e,i=st(r),s=st(o),[c,l]=a(n),d=void 0!==t,u=d?t:c,f=st((e=>{const t="function"==typeof e?e(u):e;s(u,t)&&(d||l(t),i(t))}),[d,i,u,s]);return[u,f]}const lt=m(((e,t)=>{let{className:o,rowClassName:c,paginate:l=!0,sync:d=!1,columns:f=3,source:m,renderItem:h,renderEmpty:p}=e;const[g,y]=a([]),[v,x]=a(l?{total:0,current:1,pageSize:10}:null),[w,k]=a(!0),[C,N]=R({}),[S,j]=ct({value:d?C.page||1:void 0,defaultValue:1,onChange:e=>{d&&N({page:e||void 0})}}),z=u((async function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0]||k(!0);try{let e;const t={page:S>1?S:void 0};e="string"==typeof m?await me({url:m,params:t}):await m(t),l&&qe(e)&&(e.last_page>1&&x({total:e.total,current:e.current_page,pageSize:e.per_page}),e=e.data),y(e)}catch(e){}finally{k(!1)}}),[m,y,S]);s((()=>{z()}),[S]),s((()=>{T.current={reload:z}}),[z]);const T=i({reload:z});return b(t,(()=>T.current)),r(dt,{className:o,children:[n(ze,{wrap:!0,loading:w}),0===g.length&&!w&&p?.(),n(P,{className:c,children:g.map(((e,t)=>n(B,{className:"d-flex",md:12/f,children:h(e)},`card-${t}`)))}),v&&n(ut,{...v,onChange:j})]})})),dt=O.div`
67
+
68
+ `,ut=O(Ge)`
69
+ margin-bottom: 0;
70
+ justify-content: flex-end;
71
+ margin-top: 1rem;
72
+ `;var ft=v(lt);function mt(e){let{as:t="div",className:r,content:o,tooltip:c=!0,placement:l}=e;const[d,u]=a(!1),f=i();s((()=>()=>{f.current&&clearTimeout(f.current)}),[]);const m=c?n("i",d?{className:"bi bi-clipboard-check"}:{className:"bi bi-clipboard"}):d?"已复制":"复制",h=y(t,{role:"button",className:r,onClick:()=>{"function"==typeof o&&(o=o()),U(o),u(!0),f.current&&clearTimeout(f.current),f.current=setTimeout((()=>{u(!1),f.current=void 0}),3e3)}},m);return c?n(oe,{tooltip:d?"已复制":"复制",placement:l,children:h}):h}const ht=p((()=>import("./index-G1E7EOIF.js"))),pt=p((()=>import("./image-dGVTfSpy.js")));function gt(e){return n(g,{fallback:null,children:n(ht,{...e})})}gt.Image=function(e){return n(g,{fallback:null,children:n(pt,{...e})})};const yt=p((()=>import("./infinite-scroller-MwtYG2-c.js"))),bt=m(((e,t)=>n(g,{fallback:null,children:n(yt,{...e,ref:t})}))),vt=p((()=>import("./slider-KuqHu6UH.js")));function xt(e){return n(g,{fallback:null,children:n(vt,{...e})})}function wt(e){let{manual:t,refreshDeps:n,...r}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},{execute:o,currentParams:i,error:a,...c}=q((async t=>(e="string"==typeof e?{url:e}:e,await me({...e,...t}))),r);s((()=>{if(!t&&!n)try{o()}catch{}}),[]),s((()=>{n&&l()}),n);const l=u((async()=>{try{i?await o(...i):await o()}catch{}}),[o,i]);if(a&&ue(a)){const e=a.errors;a=new Error("string"==typeof e?e:$(e).join(""))}return{refresh:l,execute:o,error:a,...c}}function kt(e,t,n){const r=i(e),o=i(E(e,t,n));return s((()=>{r.current=e})),s((()=>{o.current=E((function(){r.current(...arguments)}),t,n)}),[t,n]),o.current}function Ct(e){const[t,n]=a((()=>G("function"==typeof e?e():e,!0)));return[t,u((e=>{n("function"==typeof e?V(e):G(e))}),[])]}export{bt as A,ae as B,Pe as C,xt as D,Be as E,Xe as F,wt as G,nt as H,Ye as I,ue as J,fe as K,ze as L,Y as M,Ve as N,at as O,Ge as P,Se as R,He as S,ie as T,ct as a,he as b,Ct as c,le as d,de as e,ye as f,be as g,ve as h,qe as i,Ae as j,Me as k,Le as l,Ke as m,Qe as n,et as o,ot as p,rt as q,me as r,ce as s,it as t,kt as u,oe as v,ge as w,ft as x,mt as y,gt as z};
package/es/index.js CHANGED
@@ -1 +1 @@
1
- export{B as Button,C as Card,x as CardList,y as Clipboard,E as Error,F as Form,I as ImageZoom,A as InfiniteScroller,z as Lightbox,L as Loader,m as LoadingButton,M as Message,s as Modal,q as ModalButton,p as ModalForm,N as NumberFormat,t as Offcanvas,O as OffcanvasButton,P as Pagination,n as RequestButton,R as Result,D as Slider,S as Space,l as Statistic,k as Step,j as Steps,o as Table,d as Toast,v as Tooltip,f as formatSize,h as getAbsoluteUrl,g as isImageUrl,e as isRecord,J as isRequestError,r as request,K as showRequestError,a as useControllableState,u as useDebounce,c as useImmer,H as useOverlayState,G as useRequest,b as useSafeState,w as waitPayComplete}from"./index-5if674Am.js";export{StyleSheetManager,ThemeProvider,createGlobalStyle,css,keyframes,default as styled}from"styled-components";export{useAsync,useAsyncCallback}from"react-async-hook";export{useInView}from"react-intersection-observer";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"react/jsx-runtime";import"react";import"react-bootstrap";import"lodash";import"axios";import"query-string";import"retry-axios";import"rc-notification";import"path";import"classnames";import"use-url-search-params";import"copy-to-clipboard";import"immer";
1
+ export{B as Button,C as Card,x as CardList,y as Clipboard,E as Error,F as Form,I as ImageZoom,A as InfiniteScroller,z as Lightbox,L as Loader,m as LoadingButton,M as Message,s as Modal,q as ModalButton,p as ModalForm,N as NumberFormat,t as Offcanvas,O as OffcanvasButton,P as Pagination,n as RequestButton,R as Result,D as Slider,S as Space,l as Statistic,k as Step,j as Steps,o as Table,d as Toast,v as Tooltip,f as formatSize,h as getAbsoluteUrl,g as isImageUrl,e as isRecord,J as isRequestError,r as request,K as showRequestError,a as useControllableState,u as useDebounce,c as useImmer,H as useOverlayState,G as useRequest,b as useSafeState,w as waitPayComplete}from"./index-d-ZBuSZk.js";export{StyleSheetManager,ThemeProvider,createGlobalStyle,css,keyframes,default as styled}from"styled-components";export{useAsync,useAsyncCallback}from"react-async-hook";export{useInView}from"react-intersection-observer";export{SnackbarProvider as ToastProvider}from"notistack";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"react/jsx-runtime";import"react";import"react-bootstrap";import"lodash";import"axios";import"query-string";import"retry-axios";import"path";import"classnames";import"use-url-search-params";import"copy-to-clipboard";import"immer";
@@ -0,0 +1 @@
1
+ import{jsx as r}from"react/jsx-runtime";import{memo as t,forwardRef as e,useState as a,useRef as o,useCallback as i,useImperativeHandle as s}from"react";import m from"react-infinite-scroller";import{c as p,r as n,i as c}from"./index-d-ZBuSZk.js";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"react-bootstrap";import"lodash";import"axios";import"query-string";import"retry-axios";import"notistack";import"path";import"styled-components";import"classnames";import"use-url-search-params";import"copy-to-clipboard";import"react-async-hook";import"immer";import"react-intersection-observer";var l=t(e(((t,e)=>{let{source:l,render:d,as:u,useWindow:f,className:y}=t;const[g,w]=a(!1),[h,x]=a(!1),[b,j]=p([]),v=o(0),k=i((async r=>{if(!g){w(!0),v.current=r;try{let t;const e={page:r>1?r:void 0};t="string"==typeof l?await n({url:l,params:e}):await l(e),c(t)?(x(t.current_page>=t.last_page),t=t.data):x(!0),j(1==r?t:[...b,...t])}finally{w(!1)}}}),[l,b,v,g]),M=i((()=>{k(1)}),[k]);return s(e,(()=>({reload:M})),[M]),r(m,{className:y,hasMore:!h,pageStart:0,loadMore:()=>{k(v.current+1)},useWindow:f,element:u,children:d({data:b,setData:j,end:h,loading:g,action:{reload:M}})})})));export{l as default};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@topthink/components",
3
- "version": "1.0.82",
3
+ "version": "1.0.84",
4
4
  "scripts": {
5
5
  "prebuild": "rimraf es types",
6
6
  "build": "rollup -c --environment NODE_ENV:production",
@@ -28,8 +28,8 @@
28
28
  "classnames": "^2.3.1",
29
29
  "copy-to-clipboard": "^3.3.3",
30
30
  "immer": "^9.0.6",
31
+ "notistack": "^3.0.1",
31
32
  "query-string": "^8.1.0",
32
- "rc-notification": "^4.5.2",
33
33
  "rc-slider": "^10.6.2",
34
34
  "rc-steps": "^4.1.4",
35
35
  "rc-table": "^7.31.1",
@@ -71,5 +71,5 @@
71
71
  },
72
72
  "author": "yunwuxin <tzzhangyajun@qq.com> (https://github.com/yunwuxin)",
73
73
  "license": "MIT",
74
- "gitHead": "7a8e0fec1fc3f71f9cc2a2286b915fd5cffea89c"
74
+ "gitHead": "9e6daa51466ee6ca54aaa6032c90fb0e08f1d598"
75
75
  }
package/scss/app.scss CHANGED
@@ -1,7 +1,5 @@
1
1
  @import "~@topthink/bootstrap/scss/bootstrap";
2
- @import "notification";
3
2
 
4
3
  .btn-link {
5
4
  padding: 0;
6
5
  }
7
-
@@ -1,6 +1,5 @@
1
1
  import { ImgHTMLAttributes } from 'react';
2
- interface Props extends ImgHTMLAttributes<HTMLImageElement> {
2
+ export interface Props extends ImgHTMLAttributes<HTMLImageElement> {
3
3
  lazy?: boolean;
4
4
  }
5
5
  export default function Image({ lazy, ...props }: Props): JSX.Element;
6
- export {};
@@ -0,0 +1,10 @@
1
+ import { ComponentProps } from 'react';
2
+ declare const LazyLightbox: import("react").LazyExoticComponent<typeof import("./lazy/lightbox").default>;
3
+ declare const LazyImage: import("react").LazyExoticComponent<typeof import("./lazy/lightbox/image").default>;
4
+ declare function Lightbox(props: ComponentProps<typeof LazyLightbox>): JSX.Element;
5
+ declare namespace Lightbox {
6
+ var Image: (props: import("./lazy/lightbox/image").Props) => JSX.Element;
7
+ }
8
+ export default Lightbox;
9
+ declare const Image: (props: ComponentProps<typeof LazyImage>) => JSX.Element;
10
+ export { Image };
@@ -2,11 +2,12 @@ import { RequestConfig } from '../request';
2
2
  import { ElementType } from 'react';
3
3
  import { AxiosRequestConfig } from 'axios';
4
4
  import { ButtonProps } from './button';
5
- interface Props extends Omit<ButtonProps, 'as'> {
5
+ interface Props extends Omit<ButtonProps, 'as' | 'onError'> {
6
6
  url: RequestConfig;
7
7
  method?: AxiosRequestConfig['method'];
8
8
  confirm?: string;
9
9
  onSuccess?: (result: any) => void;
10
+ onError?: (e: Error) => void;
10
11
  as?: ElementType | ButtonProps['as'];
11
12
  }
12
13
  declare const RequestButton: import("react").ForwardRefExoticComponent<Props & import("react").RefAttributes<any>>;
package/types/index.d.ts CHANGED
@@ -43,3 +43,4 @@ export type { UiSchema as FormUiSchema, Schema as FormSchema, WidgetProps as For
43
43
  export { default as styled, css, keyframes, createGlobalStyle, StyleSheetManager, ThemeProvider } from 'styled-components';
44
44
  export { useAsync, useAsyncCallback } from 'react-async-hook';
45
45
  export { useInView } from 'react-intersection-observer';
46
+ export { SnackbarProvider as ToastProvider } from 'notistack';
@@ -12,9 +12,20 @@ declare module 'axios' {
12
12
  interface AxiosError {
13
13
  errors: Errors;
14
14
  }
15
+ interface EventSourceMessage {
16
+ /** The event ID to set the EventSource object's last event ID value. */
17
+ id: string;
18
+ /** A string identifying the type of event described. */
19
+ event: string;
20
+ /** The event data */
21
+ data: string;
22
+ /** The reconnection interval (in milliseconds) to wait before retrying the connection */
23
+ retry?: number;
24
+ }
15
25
  interface AxiosRequestConfig {
16
26
  raxConfig?: RetryConfig;
17
27
  authTokenName?: string;
28
+ onMessage?: (message: EventSourceMessage) => void;
18
29
  }
19
30
  }
20
31
  export type RequestConfig = AxiosRequestConfig | string;
@@ -1,11 +1,6 @@
1
- import { NoticeContent } from 'rc-notification/lib/Notification';
2
- import { NotificationProps } from 'rc-notification/es/Notification';
3
- declare const defaultOptions: NotificationProps & {
4
- getContainer?: () => HTMLElement;
5
- };
6
- declare const types: readonly ["error", "success", "info"];
7
- type ToastType = Record<typeof types[number], (content: string, options?: NoticeContent) => void> & {
8
- defaults: typeof defaultOptions;
9
- };
10
- declare const _default: ToastType;
11
- export default _default;
1
+ import { OptionsWithExtraProps, SnackbarKey, SnackbarMessage, VariantType } from 'notistack';
2
+ type EnqueueSnackbar = <V extends VariantType>(message: SnackbarMessage, options?: OptionsWithExtraProps<V>) => SnackbarKey;
3
+ declare const types: VariantType[];
4
+ type ToastType = Record<typeof types[number], EnqueueSnackbar>;
5
+ declare const Toast: ToastType;
6
+ export default Toast;
@@ -1,72 +0,0 @@
1
- import e from"sweetalert2/dist/sweetalert2.js";import t from"sweetalert2-react-content";import{jsx as n,jsxs as r,Fragment as o}from"react/jsx-runtime";import{useRef as i,useState as a,useEffect as c,createContext as s,Fragment as l,useContext as d,useCallback as u,useMemo as f,forwardRef as m,Children as h,lazy as p,Suspense as g,createElement as y,useImperativeHandle as b,memo as x}from"react";import{OverlayTrigger as v,Tooltip as w,Spinner as k,Button as C,Modal as N,Alert as S,Card as j,Pagination as z,Offcanvas as T,Row as B,Col as P}from"react-bootstrap";import{uniqueId as $,values as H,debounce as E}from"lodash";import F from"axios";import A from"query-string";import*as L from"retry-axios";import D from"rc-notification";import M from"path";import O,{css as _}from"styled-components";import I from"classnames";import{useUrlSearchParams as U}from"use-url-search-params";import R from"copy-to-clipboard";import{useAsyncCallback as q}from"react-async-hook";import{freeze as G,produce as V}from"immer";import"react-intersection-observer";const K=t(e),J={confirmButtonText:"确定",cancelButtonText:"取消"},Y={confirm:async e=>{const{isConfirmed:t}=await K.fire({...J,icon:"warning",showCancelButton:!0,...e,async preConfirm(t){if(e.preConfirm)try{return await e.preConfirm(t)}catch(e){return e instanceof Error&&K.showValidationMessage(e.message),!1}return!0}});return t},success:e=>{K.fire({...J,toast:!0,position:"top",icon:"success",timer:2e3,showConfirmButton:!1,...e})},error:e=>{K.fire({...J,toast:!0,position:"top",icon:"error",timer:5e3,showConfirmButton:!1,...e})},close:e=>{K.close(e)},defaults:J};const Q=s({});function W(e){return t=>{let{resolve:r,destroy:o,message:s}=t;const[l,m]=function(e){const t=i(null),[n,r]=a(e);return c((()=>{t.current&&(t.current(),t.current=null)}),[n]),[n,(e,n)=>{t.current="function"==typeof n?n:null,r(e)}]}(!0),h=d(Q),p=u((e=>{m(!1,(()=>{r(e)}))}),[m,r]),g=f((()=>({show:l,onHide:()=>p(),onExited:()=>o(),container:h.container})),[l,p,o]);return n(e,{resolve:p,state:g,message:s})}}function X(e){return t=>new Promise((r=>{const o=n(e,{resolve:r,destroy:()=>{ne(o)},message:t});te(o)}))}let Z=()=>{},ee=new Set;const te=e=>{ee=new Set(ee),ee.add(e),Z(ee)},ne=e=>{ee=new Set(ee),ee.delete(e),Z(ee)};function re(e,t){return X(W(e))(t)}function oe(e){let{tooltip:t,children:r,placement:o="bottom"}=e;return n(v,{placement:o,overlay:n(w,{id:$(),children:t}),children:r})}const ie=s(!1),ae=m(((e,t)=>{let{loading:i,percent:a,disabled:c,children:s,tooltip:l,variant:u,...f}=e;d(ie)&&!u&&(u="link"),i&&(c=!0,s=r(o,{children:[n(k,{ref:t,as:"span",size:"sm",role:"status","aria-hidden":"true",animation:"border"}),a?r("span",{className:"ms-2",children:[a,"%"]}):null]}));const m=n(C,{ref:t,...f,variant:u,disabled:c,children:s});return l?n(oe,{tooltip:l,children:n("span",{className:"d-inline-block",children:m})}):m})),ce=function(e){let{state:t,message:{title:o,message:i,okText:a,cancelText:c},resolve:s}=e;return r(N,{...t,children:[n(N.Header,{children:n(N.Title,{as:"h5",children:o||"确认"})}),n(N.Body,{children:i}),r(N.Footer,{children:[n(ae,{variant:"secondary",onClick:()=>s(),children:c||"取消"}),n(ae,{onClick:()=>s(!0),children:a||"确定"})]})]})};const se=e=>{let{header:t,children:i,footer:c,closable:s=!0,show:l,cancelText:d="取消",okText:u="确定",onOk:m,onCancel:h,onHide:p,okButtonProps:g,bodyAs:y,headerAs:b="h5",confirmLoading:x=!1,...v}=e;const[w,k]=a(!1),C=f((()=>n(ae,{loading:w||x,variant:"primary",onClick:async e=>{k(!0);try{await(m?.(e)),e.defaultPrevented||p?.()}finally{k(!1)}},...g,children:u})),[g,u,m,p,w,x]),S=f((()=>n(ae,{variant:"secondary",onClick:e=>{h?.(e),e.defaultPrevented||p?.()},children:d})),[h,p,d]);switch(typeof c){case"undefined":c=r(o,{children:[S,C]});break;case"function":c=c({okButton:C,cancelButton:S})}return r(N,{...v,onHide:p,show:l,children:[t&&n(N.Header,{closeButton:s,children:n(N.Title,{as:b,children:t})}),n(N.Body,{as:y,children:i}),c&&n(N.Footer,{children:c})]})};let le;se.Message=function(e){const[t,r]=a(ee);return c((()=>{Z=r}),[]),n(Q.Provider,{value:e,children:Array.from(t).map(((e,t)=>n(l,{children:e},`message-${t}`)))})},se.confirm=function(e){return X(W(ce))(e)},se.show=re;const de={};const ue=e=>{let{type:t,...r}=e;!function(e){if(le)return e(le);D.newInstance({...de,prefixCls:"notification",maxCount:5,style:{top:20,right:20}},(t=>{le?e(le):(le=t,e(t))}))}((e=>{r.duration=3;let o=t;if("error"===t)o="danger",r.duration=r.closable?0:5;r.content=n(S,{variant:o,children:r.content}),e.notice(r)}))},fe=["error","success","info"].reduce(((e,t)=>(e[t]=(e,n)=>{ue({...n,type:t,content:e})},e)),{});function me(e){return e&&"object"==typeof e}fe.defaults=de,L.attach(),F.defaults.raxConfig={retryDelay:2e3,backoffType:"static",shouldRetry:e=>{let{config:t,response:n}=e;return!(t.raxConfig?.retryDecider&&!t.raxConfig.retryDecider())&&("GET"===t.method?.toUpperCase()&&449===n?.status)}},F.defaults.maxContentLength=1/0,F.defaults.maxBodyLength=1/0,F.defaults.baseURL="/api",F.defaults.authTokenName="authorization",F.interceptors.request.use((e=>{const t=e.authTokenName;if(t){const n=localStorage.getItem(t);n&&(e.headers={Authorization:`Bearer ${n}`,...e.headers})}return e}),(e=>Promise.reject(e))),F.interceptors.response.use((e=>(201===e.status&&e.data.location&&(window.location.href=e.data.location,e.data=void 0),e)),(e=>{if(F.isAxiosError(e)&&e.response){const{data:t,status:n}=e.response;401===n?(e.errors="Unauthorized",fe.error("Unauthorized")):me(t)?422===n?e.errors=t:"message"in t&&(e.errors=t.message):e.errors=t}return Promise.reject(e)}));const he=F.isAxiosError,pe=e=>{if(!F.isAxiosError(e))throw e;{let t=e.errors;"string"!=typeof e.errors&&(t=Object.values(e.errors).join("<br />")),fe.error(t)}},ge=async function(e){e="string"==typeof e?{url:e}:e;const{data:t}=await F.request({paramsSerializer:function(e){return A.stringify(e,{sort:!1,skipNull:!0,skipEmptyString:!0,arrayFormat:"bracket"})},...e});return t};ge.defaults=F.defaults,ge.interceptors=F.interceptors;function ye(e){const t=(()=>{const e=i(!1);return c((()=>(e.current=!1,()=>{e.current=!0})),[]),e})(),[n,r]=a(e);return[n,u((e=>{t.current||r(e)}),[])]}const be=function(e){let{state:t,message:r,resolve:o}=e;const a=i(!0),{result:s,checkUrl:l,onComplete:d}=r,[u,f]=ye(!1);return c((()=>{ge({url:l,method:"post",data:{order_no:s.order_no},raxConfig:{shouldRetry:e=>a.current&&449===e.response?.status}}).then((()=>{d?.(),o()})).catch((()=>null))}),[]),n(se,{...t,centered:!0,onHide:()=>{a.current=!1,t.onHide()},backdrop:"static",header:"支付结果",okText:"已完成支付",okButtonProps:{loading:u},onOk:async e=>{e.preventDefault();try{f(!0),await ge({url:l,method:"post",data:{order_no:s.order_no},raxConfig:{shouldRetry:()=>!1}}),d?.(),o()}catch{}finally{f(!1)}},cancelText:"取消",children:"请在新打开的页面上进行支付,支付完成后再关闭此窗口"})};function xe(e){const{result:t}=e;window.open(t.pay_url),re(be,e)}function ve(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:2;return e>=1024**3?(e/1024**3).toFixed(t)+"G":e>=1048576?(e/1048576).toFixed(t)+"M":(e/1024).toFixed(t)+"K"}function we(e){const t=M.extname(e);return!(!/^data:image\//.test(e)&&!/(webp|svg|png|gif|jpg|jpeg|jfif|bmp|dpg|ico)$/i.test(t))||!/^data:/.test(e)&&!t}function ke(e){const t=document.createElement("a");return t.href=e,t.href}const Ce=O.div`
2
- padding: 48px 32px;
3
- `,Ne=O.div`
4
- margin-bottom: 24px;
5
- text-align: center;
6
- font-size: 72px;
7
- `,Se=O.div`
8
- color: rgba(0, 0, 0, .85);
9
- font-size: 24px;
10
- line-height: 1.8;
11
- text-align: center;
12
- `,je=O.div`
13
- margin-top: 32px;
14
- text-align: center;
15
- `,ze={success:n("i",{className:"bi bi-check-circle-fill text-success"}),error:n("i",{className:"bi bi-exclamation-circle-fill text-danger"}),info:n("i",{className:"bi bi-info-circle-fill text-info"}),warning:n("i",{className:"bi bi-exclamation-triangle-fill text-warning"})};function Te(e){let{status:t,title:o,icon:i,extra:a}=e;return!i&&t&&(i=ze[t]),r(Ce,{children:[i&&n(Ne,{children:i}),o&&n(Se,{children:o}),a&&n(je,{children:a})]})}O.div`
16
- position: relative;
17
- `;const Be=O.div`
18
- display: ${e=>e.active?"flex":"none"};
19
- position: absolute;
20
- top: 0 !important;
21
- left: 0 !important;
22
- width: 100%;
23
- height: 100%;
24
- text-align: center;
25
- vertical-align: middle;
26
- padding: 1em;
27
- background-color: ${e=>e.inverted?"rgba(255, 255, 255, .85)":"rgba(0, 0, 0, .85)"};
28
- opacity: ${e=>e.active?1:0};
29
- line-height: 1;
30
- animation-fill-mode: both;
31
- animation-duration: .5s;
32
- transition: background-color .5s linear;
33
- flex-direction: column;
34
- align-items: center;
35
- justify-content: center;
36
- user-select: none;
37
- will-change: opacity;
38
- z-index: 990;
39
- `;function Pe(e){let{loading:t=!0,children:o,variant:i="primary",animation:a="border",wrap:c,...s}=e;return t?(o&&(o=n("p",{className:"mt-3 text-secondary",children:o})),o=r(Be,{inverted:!0,active:!0,children:[n(k,{animation:a,variant:i,...s}),o]}),c?n($e,{$height:"number"==typeof c?c:150,children:o}):o):null}const $e=O.div`
40
- position: relative;
41
- height: ${e=>`${e.$height}px`};
42
- `;function He(e){let{children:t,title:i,className:a,...c}=e;return n(j,{className:I("border-0 shadow-sm mb-3",a),...c,children:r("div",{className:"card-body",children:[i&&r(o,{children:[n("h5",{children:i}),n("hr",{})]}),t]})})}function Ee(e){let{errors:t}=e;return t?n(S,{variant:"danger",children:n("ul",{className:"mb-0",children:"string"==typeof t?n("li",{children:t}):Object.entries(t).map((e=>{let[t,r]=e;return n("li",{children:r},t)}))})}):null}function Fe(e){let{children:t,className:r,size:o="small",direction:i="horizontal"}=e;"string"==typeof o&&(o={small:8,middle:16,large:24}[o]);const a=h.map(t,(e=>{if(e)return n(Le,{children:e})}));return n(Ae,{className:r,$direction:i,$size:o,children:a})}const Ae=O.div`
43
- display: inline-flex;
44
- align-items: center;
45
- gap: ${e=>e.$size}px;
46
-
47
- ${e=>"vertical"===e.$direction&&_`
48
- display: flex;
49
- flex-direction: column;
50
- align-items: inherit;
51
- `}
52
- `,Le=O.div`
53
-
54
- `,De=p((()=>import("./steps-b_BcYIwk.js"))),Me=p((()=>import("./steps-b_BcYIwk.js").then((e=>{let{Step:t}=e;return{default:t}}))));function Oe(e){return n(g,{fallback:null,children:n(De,{...e})})}const _e=function(e){return n(g,{fallback:null,children:n(Me,{...e})})};function Ie(e){let{title:t,content:o,footer:i}=e;return r(He,{children:[n(qe,{children:t}),n(Re,{children:o}),i&&n(Ue,{children:i})]})}Oe.Step=_e;const Ue=O.div`
55
- margin-top: 9px;
56
- padding-top: 10px;
57
- border-top: 1px solid #f0f0f0;
58
- color: rgba(0, 0, 0, .65);
59
- `,Re=O.div`
60
- color: rgba(0, 0, 0, .85);
61
- font-size: 24px;
62
- `,qe=O.div`
63
- margin-bottom: 4px;
64
- color: rgba(0, 0, 0, .45);
65
- font-size: 1.1rem;
66
- `;function Ge(){}function Ve(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e}function Ke(e){return"current_page"in e}function Je(e){let{total:t=0,onChange:r=Ge,defaultCurrent:o=1,defaultPageSize:i=10,className:s,...l}=e;const[d,m]=a(o),[h,p]=a(i);c((()=>{Ve(l.current)&&m(l.current)}),[l.current]),c((()=>{Ve(l.pageSize)&&p(l.pageSize)}),[l.pageSize]);const g=f((()=>Math.floor((t-1)/h)+1),[t,h]),y=u((e=>()=>{e!==d&&(m(e),r(e,h))}),[r,d,h]),b=d-1>0?d-1:0,x=d+1<g?d+1:g,v=[];let w=null,k=null,C=null,N=null;if(g<=7)for(let e=1;e<=g;e+=1){const t=d===e;v.push(n(z.Item,{active:t,onClick:y(e),children:e},e))}else{N=n(z.Last,{onClick:y(g)},"last"),C=n(z.First,{onClick:y(1)},"first"),w=n(z.Prev,{onClick:y(b)},"prev"),k=n(z.Next,{onClick:y(x)},"next");let e=Math.max(1,d-2),t=Math.min(d+2,g);d-1<=2&&(t=5),g-d<=2&&(e=g-4);for(let r=e;r<=t;r+=1){const e=d===r;v.push(n(z.Item,{active:e,onClick:y(r),children:r},r))}d-1>=4&&3!==d&&v.unshift(w),g-d>=4&&d!==g-2&&v.push(k),1!==e&&v.unshift(C),t!==g&&v.push(N)}return n(z,{className:s,children:v})}function Ye(e){let{className:t,value:r,locale:i="zh-CN",currency:a=!0,options:c={}}=e;const s=f((()=>{let e;return e=a?{style:"currency",currency:"CNY"}:{minimumFractionDigits:2},new Intl.NumberFormat(i,{...e,...c})}),[a,i,c]);return t?n("span",{className:t,children:s.format(r)}):n(o,{children:s.format(r)})}function Qe(e){let{loading:t,disabled:r,children:o,...i}=e;return n(C,{...i,disabled:t||r,children:t?"Loading…":o})}const We=p((()=>import("./image-zoom-OrIPGqh0.js")));function Xe(e){return n(g,{fallback:null,children:n(We,{...e})})}const Ze=m(((e,t)=>{let{url:n,method:r,confirm:o,onSuccess:i,children:a,disabled:c,as:s=ae,...l}=e;const[d,f]=ye(!1),m=u((async e=>{e.preventDefault();try{if(f(!0),o&&!await se.confirm({message:o}))return;const e="string"==typeof n?{url:n,method:r}:{method:r,...n},t=await ge(e);i&&i(t)}catch(e){pe(e)}finally{f(!1)}}),[n,r,f]);return y(s,{...l,disabled:c||d,onClick:m,ref:t},a)})),et=p((()=>import("./index-mDUhFN2o.js"))),tt=m(((e,t)=>n(g,{fallback:null,children:n(et,{...e,ref:t})}))),nt=p((()=>import("./index-iNklwZKy.js"))),rt=m(((e,t)=>n(g,{fallback:null,children:n(nt,{...e,ref:t})})));let ot=0;function it(){let{onHide:e,onShow:t}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const[n,r]=a(!1),[o,i]=a(`visible-${ot}`),c=u((()=>{r(!1),e&&e()}),[r,e]),s=u((()=>{i("visible-"+ ++ot)}),[i,ot]);return{visible:n,show:u((()=>{r(!0),t&&t()}),[r,t]),hide:c,state:{show:n,onHide:c,onExited:s,key:o}}}const at=m(((e,t)=>{let{text:i,onOk:a,modalProps:c,children:s,onShow:l,onHide:d,confirmLoading:u,as:f=ae,...m}=e;const{state:h,show:p,hide:g}=it({onShow:l,onHide:d});b(t,(()=>({close:g})));const x=y(f,{...m,onClick:p},i);return r(o,{children:[x,n(se,{header:i,...c,...h,confirmLoading:u,onOk:async e=>{if(a){!1===await a()&&e.preventDefault()}},children:s})]})})),ct=m(((e,t)=>{let{text:o,onSuccess:c,onSubmit:s,buttonProps:l,modalProps:d,children:f,...m}=e;const[h,p]=a(!1),g=i(null),y=i(null);b(t,(()=>({close:()=>{g.current?.close()}})));const x=u((()=>(y.current?.submit(),!1)),[]),v=u((e=>{c&&c(e),g.current?.close()}),[c]),w=u((async(e,t)=>{s&&await s(e,t)&&g.current?.close()}),[s]);return n(at,{ref:g,text:o,...l,modalProps:d,onOk:x,confirmLoading:h,children:r(tt,{...m,onSubmitting:p,ref:y,onSuccess:v,onSubmit:w,children:[f,n("input",{type:"submit",hidden:!0})]})})}));function st(e){let{header:t,children:o,closable:i=!0,show:a,onHide:c,bodyAs:s,headerAs:l="h5",...d}=e;return r(T,{...d,onHide:c,show:a,children:[t&&n(T.Header,{closeButton:i,children:n(T.Title,{as:l,children:t})}),n(T.Body,{as:s,children:o})]})}const lt=m(((e,t)=>{let{text:i,offcanvasProps:a,children:c,onShow:s,onHide:l,as:d=ae,...u}=e;const{state:f,show:m,hide:h}=it({onShow:s,onHide:l});b(t,(()=>({close:h})));const p=y(d,{...u,onClick:m},i);return r(o,{children:[p,n(st,{header:i,...a,...f,children:c})]})}));function dt(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];const n=i(e);return c((()=>{n.current=e})),u((function(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return n.current?.(...t)}),t)}function ut(e){const{value:t,defaultValue:n,onChange:r,shouldUpdate:o=((e,t)=>e!==t)}=e,i=dt(r),c=dt(o),[s,l]=a(n),d=void 0!==t,u=d?t:s,f=dt((e=>{const t="function"==typeof e?e(u):e;c(u,t)&&(d||l(t),i(t))}),[d,i,u,c]);return[u,f]}const ft=m(((e,t)=>{let{className:o,rowClassName:s,paginate:l=!0,sync:d=!1,columns:f=3,source:m,renderItem:h,renderEmpty:p}=e;const[g,y]=a([]),[x,v]=a(l?{total:0,current:1,pageSize:10}:null),[w,k]=a(!0),[C,N]=U({}),[S,j]=ut({value:d?C.page||1:void 0,defaultValue:1,onChange:e=>{d&&N({page:e||void 0})}}),z=u((async function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0]||k(!0);try{let e;const t={page:S>1?S:void 0};e="string"==typeof m?await ge({url:m,params:t}):await m(t),l&&Ke(e)&&(e.last_page>1&&v({total:e.total,current:e.current_page,pageSize:e.per_page}),e=e.data),y(e)}catch(e){}finally{k(!1)}}),[m,y,S]);c((()=>{z()}),[S]),c((()=>{T.current={reload:z}}),[z]);const T=i({reload:z});return b(t,(()=>T.current)),r(mt,{className:o,children:[n(Pe,{wrap:!0,loading:w}),0===g.length&&!w&&p?.(),n(B,{className:s,children:g.map(((e,t)=>n(P,{className:"d-flex",md:12/f,children:h(e)},`card-${t}`)))}),x&&n(ht,{...x,onChange:j})]})})),mt=O.div`
67
-
68
- `,ht=O(Je)`
69
- margin-bottom: 0;
70
- justify-content: flex-end;
71
- margin-top: 1rem;
72
- `;var pt=x(ft);function gt(e){let{as:t="div",className:r,content:o,tooltip:s=!0,placement:l}=e;const[d,u]=a(!1),f=i();c((()=>()=>{f.current&&clearTimeout(f.current)}),[]);const m=s?n("i",d?{className:"bi bi-clipboard-check"}:{className:"bi bi-clipboard"}):d?"已复制":"复制",h=y(t,{role:"button",className:r,onClick:()=>{"function"==typeof o&&(o=o()),R(o),u(!0),f.current&&clearTimeout(f.current),f.current=setTimeout((()=>{u(!1),f.current=void 0}),3e3)}},m);return s?n(oe,{tooltip:d?"已复制":"复制",placement:l,children:h}):h}const yt=p((()=>import("./index-G1E7EOIF.js"))),bt=p((()=>import("./image-dGVTfSpy.js")));function xt(e){return n(g,{fallback:null,children:n(yt,{...e})})}xt.Image=function(e){return n(g,{fallback:null,children:n(bt,{...e})})};const vt=p((()=>import("./infinite-scroller-LLpQVUWb.js"))),wt=m(((e,t)=>n(g,{fallback:null,children:n(vt,{...e,ref:t})}))),kt=p((()=>import("./slider-KuqHu6UH.js")));function Ct(e){return n(g,{fallback:null,children:n(kt,{...e})})}function Nt(e){let{manual:t,refreshDeps:n,...r}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},{execute:o,currentParams:i,error:a,...s}=q((async t=>(e="string"==typeof e?{url:e}:e,await ge({...e,...t}))),r);c((()=>{if(!t&&!n)try{o()}catch{}}),[]),c((()=>{n&&l()}),n);const l=u((async()=>{try{i?await o(...i):await o()}catch{}}),[o,i]);if(a&&he(a)){const e=a.errors;a=new Error("string"==typeof e?e:H(e).join(""))}return{refresh:l,execute:o,error:a,...s}}function St(e,t,n){const r=i(e),o=i(E(e,t,n));return c((()=>{r.current=e})),c((()=>{o.current=E((function(){r.current(...arguments)}),t,n)}),[t,n]),o.current}function jt(e){const[t,n]=a((()=>G("function"==typeof e?e():e,!0)));return[t,u((e=>{n("function"==typeof e?V(e):G(e))}),[])]}export{wt as A,ae as B,He as C,Ct as D,Ee as E,tt as F,Nt as G,it as H,Xe as I,he as J,pe as K,Pe as L,Y as M,Ye as N,lt as O,Je as P,Te as R,Fe as S,ie as T,ut as a,ye as b,jt as c,fe as d,me as e,ve as f,we as g,ke as h,Ke as i,Oe as j,_e as k,Ie as l,Qe as m,Ze as n,rt as o,ct as p,at as q,ge as r,se as s,st as t,St as u,oe as v,xe as w,pt as x,gt as y,xt as z};
@@ -1 +0,0 @@
1
- import{jsx as t}from"react/jsx-runtime";import o,{getRegistry as r}from"@topthink/json-form";import*as a from"react";import{forwardRef as e,useState as n,useCallback as i}from"react";import s from"axios";import{b as p,r as m,B as l}from"./index-5if674Am.js";import{mapValues as c}from"lodash";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"react-bootstrap";import"query-string";import"retry-axios";import"rc-notification";import"path";import"styled-components";import"classnames";import"use-url-search-params";import"copy-to-clipboard";import"react-async-hook";import"immer";import"react-intersection-observer";const d=require("ajv-i18n/localize/zh"),u=a.lazy((()=>import("./editor-widget-CQ3zv-Xu.js"))),f=o=>t(a.Suspense,{fallback:null,children:t(u,{...o})}),h={upload:function(o){let{options:a,...e}=o;const{widgets:n}=r();return a.endpoint&&(a.onUpload=async t=>{const o=new FormData;o.set("file",t);const{url:r,value:e}=await m({url:a.endpoint,method:"post",data:o});return{url:r,value:e}}),t(n.upload,{...e,options:a})},avatar:function(o){let{options:a,...e}=o;const{widgets:n}=r();return a.endpoint&&(a.onUpload=async t=>{const o=new FormData;o.set("file",t);const{url:r}=await m({url:a.endpoint,method:"post",data:o});return r}),t(n.avatar,{...e,options:a})},editor:function(o){let{options:r,...a}=o;return r.endpoint&&(r.onUpload=async t=>{const o=new FormData;o.set("file",t);const{url:a}=await m({url:r.endpoint,method:"post",data:o});return a}),t(f,{...a,options:r})},typeahead:function(o){let{options:a,...e}=o;const{widgets:n}=r();return a.endpoint&&(a.onSearch=async t=>{let{value:o,query:r}=t;return await m({url:a.endpoint,params:{value:o,query:r}})}),t(n.typeahead,{...e,options:a})}},y=e(((r,a)=>{let{action:e,method:u="post",onSuccess:f,formData:y,onSubmitting:w,onSubmit:g,onChange:b,submitText:v="提交",transformData:x,children:D,...j}=r;const[S,k]=n(),[q,_]=p(!1),[z,E]=n(y),F=i((async(t,o)=>{if(!q)try{if(_(!0),w&&w(!0),e){let{formData:o}=t;x&&(o=x(o));try{const t=await m({url:e,method:u,data:o});return k(void 0),f&&await f(t),t}catch(t){if(!s.isAxiosError(t))throw t;k((t=>{const o=t.errors;return"string"==typeof o?{__errors:[o]}:c(o,(t=>({__errors:[t]})))})(t))}}else if(g)return await g(t,o)}finally{_(!1),w&&w(!1)}}),[e,u,g]),U=i((t=>{const{formData:o}=t;E(o),b&&b(t)}),[E,b]),C=i((t=>(t=t.map((t=>({keyword:t.name,dataPath:t.property,...t}))),d(t),t)),[]),N=t(l,{className:"px-4",loading:q,type:"submit",variant:"primary",children:v});return"function"==typeof D&&(D=D({submit:N,loading:q})),t(o,{ref:a,extraErrors:S,onSubmit:F,transformErrors:C,noHtml5Validate:!0,noValidate:!0,...j,formData:z,onChange:U,widgets:h,children:D||t("div",{className:"col-12",children:N})})}));export{y as default};
@@ -1 +0,0 @@
1
- import{jsx as r}from"react/jsx-runtime";import{memo as t,forwardRef as e,useState as a,useRef as o,useCallback as i,useImperativeHandle as s}from"react";import m from"react-infinite-scroller";import{c as p,r as n,i as c}from"./index-5if674Am.js";import"sweetalert2/dist/sweetalert2.js";import"sweetalert2-react-content";import"react-bootstrap";import"lodash";import"axios";import"query-string";import"retry-axios";import"rc-notification";import"path";import"styled-components";import"classnames";import"use-url-search-params";import"copy-to-clipboard";import"react-async-hook";import"immer";import"react-intersection-observer";var l=t(e(((t,e)=>{let{source:l,render:d,as:u,useWindow:f,className:y}=t;const[g,w]=a(!1),[h,x]=a(!1),[b,j]=p([]),v=o(0),M=i((async r=>{if(!g){w(!0),v.current=r;try{let t;const e={page:r>1?r:void 0};t="string"==typeof l?await n({url:l,params:e}):await l(e),c(t)?(x(t.current_page>=t.last_page),t=t.data):x(!0),j(1==r?t:[...b,...t])}finally{w(!1)}}}),[l,b,v,g]),N=i((()=>{M(1)}),[M]);return s(e,(()=>({reload:N})),[N]),r(m,{className:y,hasMore:!h,pageStart:0,loadMore:()=>{M(v.current+1)},useWindow:f,element:u,children:d({data:b,setData:j,end:h,loading:g,action:{reload:N}})})})));export{l as default};
@@ -1,92 +0,0 @@
1
- .notification {
2
- position: fixed;
3
- z-index: 1100;
4
-
5
- &-notice {
6
- border-radius: 3px 3px;
7
- box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
8
- border: 0 solid rgba(0, 0, 0, 0);;
9
- background: #fff;
10
- display: block;
11
- width: auto;
12
- line-height: 1.5;
13
- position: relative;
14
- margin: 10px 0;
15
- max-width: 300px;
16
- white-space: pre-wrap;
17
-
18
- &-close {
19
- position: absolute;
20
- right: 5px;
21
- top: 3px;
22
- color: #000;
23
- cursor: pointer;
24
- outline: none;
25
- font-size: 16px;
26
- font-weight: 700;
27
- line-height: 1;
28
- text-shadow: 0 1px 0 #fff;
29
- filter: alpha(opacity=20);
30
- opacity: .2;
31
- text-decoration: none;
32
-
33
- &-x:after {
34
- content: '×';
35
- }
36
-
37
- &:hover {
38
- opacity: 1;
39
- filter: alpha(opacity=100);
40
- text-decoration: none;
41
- }
42
- }
43
- }
44
-
45
- @mixin fade-effect {
46
- animation-duration: 0.3s;
47
- animation-fill-mode: both;
48
- animation-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2);
49
- }
50
-
51
- &-fade-appear,
52
- &-fade-enter {
53
- opacity: 0;
54
-
55
- @include fade-effect;
56
- animation-play-state: paused;
57
- }
58
-
59
- &-fade-leave {
60
- @include fade-effect;
61
- animation-play-state: paused;
62
- }
63
-
64
- &-fade-appear#{&}-fade-appear-active,
65
- &-fade-enter#{&}-fade-enter-active {
66
- animation-name: rcNotificationFadeIn;
67
- animation-play-state: running;
68
- }
69
-
70
- &-fade-leave#{&}-fade-leave-active {
71
- animation-name: rcDialogFadeOut;
72
- animation-play-state: running;
73
- }
74
-
75
- @keyframes rcNotificationFadeIn {
76
- 0% {
77
- opacity: 0;
78
- }
79
- 100% {
80
- opacity: 1;
81
- }
82
- }
83
-
84
- @keyframes rcDialogFadeOut {
85
- 0% {
86
- opacity: 1;
87
- }
88
- 100% {
89
- opacity: 0;
90
- }
91
- }
92
- }