@labelbee/lb-components 1.13.0-alpha.2 → 1.13.0-alpha.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.
@@ -1 +1 @@
1
- "use strict";var React=require("react"),index$3=require("../../../constant/index.js"),antd=require("antd"),index$2=require("./components/answerSort/index.js"),reactRedux=require("react-redux"),_=require("lodash"),index$1=require("./components/answerList/index.js"),ctx=require("../../../store/ctx.js"),index=require("../../../utils/index.js"),reducer=require("../../../store/annotation/reducer.js"),annotation=require("../../../hooks/annotation.js"),actionCreators=require("../../../store/annotation/actionCreators.js"),lbAnnotation=require("@labelbee/lb-annotation"),reactI18next=require("react-i18next"),data=require("../utils/data.js");function _interopDefaultLegacy(t){return t&&typeof t=="object"&&"default"in t?t:{default:t}}var React__default=_interopDefaultLegacy(React),__defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(t,n,a)=>n in t?__defProp(t,n,{enumerable:!0,configurable:!0,writable:!0,value:a}):t[n]=a,__spreadValues=(t,n)=>{for(var a in n||(n={}))__hasOwnProp.call(n,a)&&__defNormalProp(t,a,n[a]);if(__getOwnPropSymbols)for(var a of __getOwnPropSymbols(n))__propIsEnum.call(n,a)&&__defNormalProp(t,a,n[a]);return t},__spreadProps=(t,n)=>__defProps(t,__getOwnPropDescs(n));const{TextArea}=antd.Input,sidebarCls=`${index$3.prefix}-sidebar`,contentBoxCls=`${index$3.prefix}-LLMSidebar-contentBox`,Sidebar=t=>{var n;const{annotation:a,dispatch:j,checkMode:m}=t,{imgIndex:b,imgList:S,stepList:w,step:h,skipBeforePageTurning:E}=a,{t:q}=reactI18next.useTranslation(),o=(n=S[b])!=null?n:{},R=index.jsonParser(o==null?void 0:o.result),{toolInstanceRef:C}=annotation.useCustomToolInstance({basicInfo:R}),[c,$]=React.useState(),[u,y]=React.useState([]),[x,O]=React.useState(void 0),[g,P]=React.useState([]),[A,D]=React.useState([]);React.useEffect(()=>{var e;if(w&&h){const r=(e=reducer.getStepConfig(w,h))==null?void 0:e.config;$(index.jsonParser(r))}},[w,h]),React.useEffect(()=>{if(!o)return;const e=data.getCurrentResultFromResultList(o==null?void 0:o.result);let r=(e==null?void 0:e.answerList)?e:o==null?void 0:o.questionList;(r==null?void 0:r.answerList)&&(I(r.answerList),y(r.answerList||[])),O(e==null?void 0:e.textAttribute)},[b,o]),React.useEffect(()=>{C.current.exportData=()=>{const i=data.formatSort(g);return[[{answerList:u,sort:i,textAttribute:x,id:o==null?void 0:o.id}],{}]};const e=data.formatSort(g),r={answerList:u,sort:e,textAttribute:x,id:o==null?void 0:o.id,toolName:lbAnnotation.EToolName.LLM};C.current.currentPageResult=r},[u,g,x]);const I=e=>{var r;if(P([]),(e==null?void 0:e.length)>0){let i=[],f=[];const s=data.getCurrentResultFromResultList(o==null?void 0:o.result),v=(s==null?void 0:s.length)>0?s[0]:s;((r=v==null?void 0:v.sort)==null?void 0:r.length)>0&&(f=v.sort.reduce((l,d)=>{let p=[{title:d[0],id:d[0]}];return d.length>1&&(p=d.map(L=>({title:L,id:L}))),[...l,p]},[]),P(f)),e.forEach(l=>{f.some(p=>p.length>1?p.some(L=>L.id===l.order):p[0].id===l.order)||i.push({title:l.order,id:l.order})}),D(i)}},M=({order:e,value:r,key:i})=>{const f=u==null?void 0:u.map(s=>{var v;if((s==null?void 0:s.order)===e){if(_.isNumber(r))return __spreadProps(__spreadValues({},s),{score:r});if(_.isObject(r)&&i){const l={[r==null?void 0:r.key]:r.value},d=(v=s[i])!=null?v:{};return __spreadProps(__spreadValues({},s),{[i]:__spreadValues(__spreadValues({},d),l)})}}return s});y(f)};return React__default.default.createElement("div",{className:`${sidebarCls}`},React__default.default.createElement("div",{className:`${sidebarCls}__content`},React__default.default.createElement("div",{style:{padding:"0px 16px"}},u.length>0&&c&&React__default.default.createElement(index$1,{list:u,LLMConfig:c,updateValue:M,checkMode:m}),(c==null?void 0:c.enableSort)&&React__default.default.createElement(index$2,{waitSortList:A,sortList:g,setSortList:P,checkMode:m}),(c==null?void 0:c.text)&&React__default.default.createElement("div",{style:{padding:"0px 16px",marginBottom:"16px"}},React__default.default.createElement("div",{className:`${contentBoxCls}__title`},q("AdditionalContent")),React__default.default.createElement("div",{style:{display:"flex",alignItems:"center"}},React__default.default.createElement(TextArea,{value:x,onChange:e=>{O(e.target.value)},maxLength:1e3,disabled:m,showCount:!0,style:{width:"100%"}}))),React__default.default.createElement("div",{style:{margin:"24px 16px",display:"flex"}},(S==null?void 0:S.length)-1!==b&&React__default.default.createElement(antd.Button,{type:"primary",style:{marginLeft:"auto"},onClick:()=>{if(E){E(()=>j(actionCreators.PageForward()));return}j(actionCreators.PageForward())},disabled:m},q("Submit"))))))},mapStateToProps=t=>({annotation:t.annotation});var LLMSidebar=reactRedux.connect(mapStateToProps,null,null,{context:ctx.LabelBeeContext})(Sidebar);module.exports=LLMSidebar;
1
+ "use strict";var React=require("react"),index$3=require("../../../constant/index.js"),antd=require("antd"),index$2=require("./components/answerSort/index.js"),reactRedux=require("react-redux"),_=require("lodash"),index$1=require("./components/answerList/index.js"),ctx=require("../../../store/ctx.js"),index=require("../../../utils/index.js"),reducer=require("../../../store/annotation/reducer.js"),annotation=require("../../../hooks/annotation.js"),actionCreators=require("../../../store/annotation/actionCreators.js"),lbAnnotation=require("@labelbee/lb-annotation"),reactI18next=require("react-i18next"),data=require("../utils/data.js");function _interopDefaultLegacy(t){return t&&typeof t=="object"&&"default"in t?t:{default:t}}var React__default=_interopDefaultLegacy(React),__defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(t,n,a)=>n in t?__defProp(t,n,{enumerable:!0,configurable:!0,writable:!0,value:a}):t[n]=a,__spreadValues=(t,n)=>{for(var a in n||(n={}))__hasOwnProp.call(n,a)&&__defNormalProp(t,a,n[a]);if(__getOwnPropSymbols)for(var a of __getOwnPropSymbols(n))__propIsEnum.call(n,a)&&__defNormalProp(t,a,n[a]);return t},__spreadProps=(t,n)=>__defProps(t,__getOwnPropDescs(n));const{TextArea}=antd.Input,sidebarCls=`${index$3.prefix}-sidebar`,contentBoxCls=`${index$3.prefix}-LLMSidebar-contentBox`,Sidebar=t=>{var n;const{annotation:a,dispatch:P,checkMode:m}=t,{imgIndex:b,imgList:S,stepList:w,step:h,skipBeforePageTurning:j}=a,{t:E}=reactI18next.useTranslation(),o=(n=S[b])!=null?n:{},R=index.jsonParser(o==null?void 0:o.result),{toolInstanceRef:q}=annotation.useCustomToolInstance({basicInfo:R}),[c,$]=React.useState(),[u,C]=React.useState([]),[x,y]=React.useState(void 0),[g,O]=React.useState([]),[A,D]=React.useState([]);React.useEffect(()=>{var e;if(w&&h){const r=(e=reducer.getStepConfig(w,h))==null?void 0:e.config;$(index.jsonParser(r))}},[w,h]),React.useEffect(()=>{if(!o)return;const e=data.getCurrentResultFromResultList(o==null?void 0:o.result);let r=(e==null?void 0:e.answerList)?e:o==null?void 0:o.questionList;(r==null?void 0:r.answerList)&&(I(r.answerList),C(r.answerList||[])),y(e==null?void 0:e.textAttribute)},[b,o]),React.useEffect(()=>{q.current.exportData=()=>{const i=data.formatSort(g);return[[{answerList:u,sort:i,textAttribute:x,id:o==null?void 0:o.id}],{}]};const e=data.formatSort(g),r={answerList:u,sort:e,textAttribute:x,id:o==null?void 0:o.id,toolName:lbAnnotation.EToolName.LLM};q.current.currentPageResult=r},[u,g,x]);const I=e=>{var r;let i=[],f=[];if((e==null?void 0:e.length)>0){const s=data.getCurrentResultFromResultList(o==null?void 0:o.result),v=(s==null?void 0:s.length)>0?s[0]:s;((r=v==null?void 0:v.sort)==null?void 0:r.length)>0&&(f=v.sort.reduce((l,d)=>{let p=[{title:d[0],id:d[0]}];return d.length>1&&(p=d.map(L=>({title:L,id:L}))),[...l,p]},[])),e.forEach(l=>{f.some(p=>p.length>1?p.some(L=>L.id===l.order):p[0].id===l.order)||i.push({title:l.order,id:l.order})})}O(f),D(i)},M=({order:e,value:r,key:i})=>{const f=u==null?void 0:u.map(s=>{var v;if((s==null?void 0:s.order)===e){if(_.isNumber(r))return __spreadProps(__spreadValues({},s),{score:r});if(_.isObject(r)&&i){const l={[r==null?void 0:r.key]:r.value},d=(v=s[i])!=null?v:{};return __spreadProps(__spreadValues({},s),{[i]:__spreadValues(__spreadValues({},d),l)})}}return s});C(f)};return React__default.default.createElement("div",{className:`${sidebarCls}`},React__default.default.createElement("div",{className:`${sidebarCls}__content`},React__default.default.createElement("div",{style:{padding:"0px 16px"}},u.length>0&&c&&React__default.default.createElement(index$1,{list:u,LLMConfig:c,updateValue:M,checkMode:m}),(c==null?void 0:c.enableSort)&&React__default.default.createElement(index$2,{waitSortList:A,sortList:g,setSortList:O,checkMode:m}),(c==null?void 0:c.text)&&React__default.default.createElement("div",{style:{padding:"0px 16px",marginBottom:"16px"}},React__default.default.createElement("div",{className:`${contentBoxCls}__title`},E("AdditionalContent")),React__default.default.createElement("div",{style:{display:"flex",alignItems:"center"}},React__default.default.createElement(TextArea,{value:x,onChange:e=>{y(e.target.value)},maxLength:1e3,disabled:m,showCount:!0,style:{width:"100%"}}))),React__default.default.createElement("div",{style:{margin:"24px 16px",display:"flex"}},(S==null?void 0:S.length)-1!==b&&React__default.default.createElement(antd.Button,{type:"primary",style:{marginLeft:"auto"},onClick:()=>{if(j){j(()=>P(actionCreators.PageForward()));return}P(actionCreators.PageForward())},disabled:m},E("Submit"))))))},mapStateToProps=t=>({annotation:t.annotation});var LLMSidebar=reactRedux.connect(mapStateToProps,null,null,{context:ctx.LabelBeeContext})(Sidebar);module.exports=LLMSidebar;
@@ -1 +1 @@
1
- "use strict";var PointCloudContext=require("./PointCloudContext.js"),useRotate=require("./hooks/useRotate.js"),useBoxes=require("./hooks/useBoxes.js"),useSingleBox=require("./hooks/useSingleBox.js"),useSphere=require("./hooks/useSphere.js"),React=require("react"),lbAnnotation=require("@labelbee/lb-annotation"),antd=require("antd"),reactRedux=require("react-redux"),map=require("../../store/annotation/map.js"),useStatus=require("./hooks/useStatus.js"),usePointCloudViews=require("./hooks/usePointCloudViews.js"),ctx=require("../../store/ctx.js"),useHistory=require("./hooks/useHistory.js"),useAttribute=require("./hooks/useAttribute.js"),useConfig=require("./hooks/useConfig.js"),usePolygon=require("./hooks/usePolygon.js"),reactI18next=require("react-i18next"),__defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(u,o,i)=>o in u?__defProp(u,o,{enumerable:!0,configurable:!0,writable:!0,value:i}):u[o]=i,__spreadValues=(u,o)=>{for(var i in o||(o={}))__hasOwnProp.call(o,i)&&__defNormalProp(u,i,o[i]);if(__getOwnPropSymbols)for(var i of __getOwnPropSymbols(o))__propIsEnum.call(o,i)&&__defNormalProp(u,i,o[i]);return u},__spreadProps=(u,o)=>__defProps(u,__getOwnPropDescs(o));const{EPolygonPattern}=lbAnnotation.cTool,PointCloudListener=({currentData:u,config:o,checkMode:i,configString:B,imgIndex:C,toolInstanceRef:a})=>{const r=React.useContext(PointCloudContext.PointCloudContext),{changeSelectedBoxValid:V,selectNextBox:E,selectPrevBox:A,updateSelectedBox:g,deleteSelectedPointCloudBoxAndPolygon:O}=useSingleBox.useSingleBox(),{selectedSphere:b,updatePointCloudSphere:L}=useSphere.useSphere(),{clearAllResult:P,updatePointCloudPattern:q}=useStatus.useStatus(),{copySelectedBoxes:j,pasteSelectedBoxes:T,copiedBoxes:I}=useBoxes.useBoxes({config:o}),{updateRotate:y}=useRotate.useRotate({currentData:u}),{updatePointCloudData:p,topViewSelectedChanged:m}=usePointCloudViews.usePointCloudViews(),{redo:S,undo:x,pushHistoryWithList:D,pushHistoryUnderUpdatePolygon:N}=useHistory.useHistory(),{syncThreeViewsAttribute:h}=useAttribute.useAttribute(),{syncAllViewsConfig:H,reRenderTopViewRange:K}=useConfig.useConfig(),{selectedPolygon:k}=usePolygon.usePolygon(),{t:w}=reactI18next.useTranslation(),v=e=>{var t;const{topViewInstance:s}=r;!s||(t=s.pointCloud2dOperation)==null||t.updateSelectedPolygonsPoints(e)},z=(e,t)=>{var s,n;const{topViewInstance:c,mainViewInstance:l}=r;if(!c)return;const{pointCloud2dOperation:f}=c;switch(e){case"q":{y(2);break}case"e":y(-2);break;case"g":y(180);break;case"u":{const d=f.pattern===EPolygonPattern.Normal?lbAnnotation.EToolName.Rect:lbAnnotation.EToolName.Polygon;q(d);const F={[lbAnnotation.EToolName.Polygon]:w("PolygonPattern"),[lbAnnotation.EToolName.Rect]:w("RectPattern")};antd.message.success(w("ChangePatternMsg",{pattern:F[d]})),f.clearActiveStatus(),f.clearDrawingStatus()}break;case"+":l==null||l.updatePointSize({zoomIn:!0});break;case"-":l==null||l.updatePointSize({zoomIn:!1});break;case"v":r.setPointCloudValid(!r.valid);break;case"tab":if(t.shiftKey){A();break}E(),t.preventDefault();break;case"f":V();break;case"arrowup":v({y:-1});break;case"arrowdown":v({y:1});break;case"arrowleft":v({x:-1});break;case"arrowright":v({x:1});break;case"delete":O();break;default:{if(((s=o.attributeList)==null?void 0:s.length)>0){const d=lbAnnotation.AttributeUtils.getAttributeByKeycode(t.keyCode,o.attributeList);d!==void 0&&((n=a.current)==null||n.setDefaultAttribute(d))}return}}},U=(e,t)=>{switch(e){case"c":j();break;case"v":T();break;case"a":t.preventDefault(),r.selectedAllBoxes();break;case"z":{t.shiftKey?S():x();break}}},_=e=>{if(!lbAnnotation.CommonToolUtils.hotkeyFilter(e)||i===!0)return;const t=e.key.toLocaleLowerCase();if(e.ctrlKey){U(t,e);return}z(t,e)};return React.useEffect(()=>{const{topViewInstance:e}=r;if(!!e)return window.addEventListener("keydown",_),()=>{window.removeEventListener("keydown",_)}},[r,I,o,r.pointCloudBoxList,r.polygonList]),React.useEffect(()=>{H(o)},[B]),React.useEffect(()=>{(o==null?void 0:o.radius)&&K(o==null?void 0:o.radius)},[o==null?void 0:o.radius]),React.useEffect(()=>{p==null||p()},[C,r.mainViewInstance]),React.useEffect(()=>{r.setHideAttributes([])},[C]),React.useEffect(()=>{a.current.setDefaultAttribute=e=>{var t;h(e);const s=r.selectedPointCloudBox;if(s){s.attribute=e;const n=g(s);r.mainViewInstance&&m({newSelectedBox:s,newPointCloudList:n})}if(k&&N(__spreadProps(__spreadValues({},k),{attribute:e})),b){const n=L(__spreadProps(__spreadValues({},b),{attribute:e}));r.mainViewInstance&&((t=r.mainViewInstance)==null||t.generateSpheres(n),m({newSelectedSphere:b,newSphereList:n}))}},a.current.setSubAttribute=(e,t)=>{var s;const n=r.selectedPointCloudBox;if(n){const c=(s=n==null?void 0:n.subAttribute)!=null?s:{};n.subAttribute=__spreadProps(__spreadValues({},c),{[e]:t}),g(n)}},a.current.clearResult=()=>{P==null||P()},a.current.redo=()=>{S()},a.current.undo=()=>{x()},a.current.setValid=e=>{a.current.valid=e,setTimeout(()=>{r.setPointCloudValid(e),e===!1&&P()})},a.current.setForbidOperation=e=>{var t,s;(s=(t=r.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||s.setForbidOperation(e),e===!0&&r.setSelectedIDs(void 0)},a.current.setShowDefaultCursor=e=>{var t,s;(s=(t=r.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||s.setShowDefaultCursor(e)},a.current.asyncData=e=>{setTimeout(()=>{p==null||p(e)})}},[r.pointCloudBoxList,r.pointCloudSphereList,r.selectedID,r.valid,r.polygonList,r.lineList,r.mainViewInstance,r.ptSegmentInstance]),React.useEffect(()=>{a.current.updateSegmentTool=e=>{var t;(t=r.ptSegmentInstance)==null||t.emit(e)},a.current.segmentInstance=r.ptSegmentInstance},[r.ptSegmentInstance]),React.useEffect(()=>{a.current.history={pushHistory:e=>{D({pointCloudBoxList:e})},initRecord:()=>{}}},[]),React.useEffect(()=>{var e;const t=(e=r.topViewInstance)==null?void 0:e.toolInstance;if(!t||i)return;const s=l=>{h(l)},n=l=>{antd.message.error(l)},c=l=>{antd.message.info(l)};return t.on("syncAttribute",s),t.on("messageError",n),t.on("messageInfo",c),()=>{t.unbind("syncAttribute",s),t.unbind("messageError",n),t.unbind("messageInfo",c)}},[r.topViewInstance]),null};var PointCloudListener$1=reactRedux.connect(map.a2MapStateToProps,null,null,{context:ctx.LabelBeeContext})(PointCloudListener);module.exports=PointCloudListener$1;
1
+ "use strict";var PointCloudContext=require("./PointCloudContext.js"),useRotate=require("./hooks/useRotate.js"),useBoxes=require("./hooks/useBoxes.js"),useSingleBox=require("./hooks/useSingleBox.js"),useSphere=require("./hooks/useSphere.js"),React=require("react"),lbAnnotation=require("@labelbee/lb-annotation"),antd=require("antd"),reactRedux=require("react-redux"),map=require("../../store/annotation/map.js"),useStatus=require("./hooks/useStatus.js"),usePointCloudViews=require("./hooks/usePointCloudViews.js"),ctx=require("../../store/ctx.js"),useHistory=require("./hooks/useHistory.js"),useAttribute=require("./hooks/useAttribute.js"),useConfig=require("./hooks/useConfig.js"),usePolygon=require("./hooks/usePolygon.js"),useLine=require("./hooks/useLine.js"),reactI18next=require("react-i18next"),__defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(u,o,i)=>o in u?__defProp(u,o,{enumerable:!0,configurable:!0,writable:!0,value:i}):u[o]=i,__spreadValues=(u,o)=>{for(var i in o||(o={}))__hasOwnProp.call(o,i)&&__defNormalProp(u,i,o[i]);if(__getOwnPropSymbols)for(var i of __getOwnPropSymbols(o))__propIsEnum.call(o,i)&&__defNormalProp(u,i,o[i]);return u},__spreadProps=(u,o)=>__defProps(u,__getOwnPropDescs(o));const{EPolygonPattern}=lbAnnotation.cTool,PointCloudListener=({currentData:u,config:o,checkMode:i,configString:L,imgIndex:C,toolInstanceRef:a})=>{const r=React.useContext(PointCloudContext.PointCloudContext),{changeSelectedBoxValid:V,selectNextBox:E,selectPrevBox:O,updateSelectedBox:g,deleteSelectedPointCloudBoxAndPolygon:q}=useSingleBox.useSingleBox(),{selectedSphere:b,updatePointCloudSphere:A}=useSphere.useSphere(),{clearAllResult:P,updatePointCloudPattern:j}=useStatus.useStatus(),{copySelectedBoxes:T,pasteSelectedBoxes:I,copiedBoxes:D}=useBoxes.useBoxes({config:o}),{updateRotate:y}=useRotate.useRotate({currentData:u}),{updatePointCloudData:p,topViewSelectedChanged:m}=usePointCloudViews.usePointCloudViews(),{redo:S,undo:h,pushHistoryWithList:N,pushHistoryUnderUpdatePolygon:H,pushHistoryUnderUpdateLine:K}=useHistory.useHistory(),{syncThreeViewsAttribute:x}=useAttribute.useAttribute(),{syncAllViewsConfig:U,reRenderTopViewRange:z}=useConfig.useConfig(),{selectedPolygon:k}=usePolygon.usePolygon(),{selectedLine:_}=useLine.useLine(),{t:f}=reactI18next.useTranslation(),v=e=>{var t;const{topViewInstance:s}=r;!s||(t=s.pointCloud2dOperation)==null||t.updateSelectedPolygonsPoints(e)},F=(e,t)=>{var s,n;const{topViewInstance:c,mainViewInstance:l}=r;if(!c)return;const{pointCloud2dOperation:w}=c;switch(e){case"q":{y(2);break}case"e":y(-2);break;case"g":y(180);break;case"u":{const d=w.pattern===EPolygonPattern.Normal?lbAnnotation.EToolName.Rect:lbAnnotation.EToolName.Polygon;j(d);const G={[lbAnnotation.EToolName.Polygon]:f("PolygonPattern"),[lbAnnotation.EToolName.Rect]:f("RectPattern")};antd.message.success(f("ChangePatternMsg",{pattern:G[d]})),w.clearActiveStatus(),w.clearDrawingStatus()}break;case"+":l==null||l.updatePointSize({zoomIn:!0});break;case"-":l==null||l.updatePointSize({zoomIn:!1});break;case"v":r.setPointCloudValid(!r.valid);break;case"tab":if(t.shiftKey){O();break}E(),t.preventDefault();break;case"f":V();break;case"arrowup":v({y:-1});break;case"arrowdown":v({y:1});break;case"arrowleft":v({x:-1});break;case"arrowright":v({x:1});break;case"delete":q();break;default:{if(((s=o.attributeList)==null?void 0:s.length)>0){const d=lbAnnotation.AttributeUtils.getAttributeByKeycode(t.keyCode,o.attributeList);d!==void 0&&((n=a.current)==null||n.setDefaultAttribute(d))}return}}},R=(e,t)=>{switch(e){case"c":T();break;case"v":I();break;case"a":t.preventDefault(),r.selectedAllBoxes();break;case"z":{t.shiftKey?S():h();break}}},B=e=>{if(!lbAnnotation.CommonToolUtils.hotkeyFilter(e)||i===!0)return;const t=e.key.toLocaleLowerCase();if(e.ctrlKey){R(t,e);return}F(t,e)};return React.useEffect(()=>{const{topViewInstance:e}=r;if(!!e)return window.addEventListener("keydown",B),()=>{window.removeEventListener("keydown",B)}},[r,D,o,r.pointCloudBoxList,r.polygonList]),React.useEffect(()=>{U(o)},[L]),React.useEffect(()=>{(o==null?void 0:o.radius)&&z(o==null?void 0:o.radius)},[o==null?void 0:o.radius]),React.useEffect(()=>{p==null||p()},[C,r.mainViewInstance]),React.useEffect(()=>{r.setHideAttributes([])},[C]),React.useEffect(()=>{a.current.setDefaultAttribute=e=>{var t;x(e);const s=r.selectedPointCloudBox;if(s){s.attribute=e;const n=g(s);r.mainViewInstance&&m({newSelectedBox:s,newPointCloudList:n})}if(k&&H(__spreadProps(__spreadValues({},k),{attribute:e})),_&&K(__spreadProps(__spreadValues({},_),{attribute:e})),b){const n=A(__spreadProps(__spreadValues({},b),{attribute:e}));r.mainViewInstance&&((t=r.mainViewInstance)==null||t.generateSpheres(n),m({newSelectedSphere:b,newSphereList:n}))}},a.current.setSubAttribute=(e,t)=>{var s;const n=r.selectedPointCloudBox;if(n){const c=(s=n==null?void 0:n.subAttribute)!=null?s:{};n.subAttribute=__spreadProps(__spreadValues({},c),{[e]:t}),g(n)}},a.current.clearResult=()=>{P==null||P()},a.current.redo=()=>{S()},a.current.undo=()=>{h()},a.current.setValid=e=>{a.current.valid=e,setTimeout(()=>{r.setPointCloudValid(e),e===!1&&P()})},a.current.setForbidOperation=e=>{var t,s;(s=(t=r.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||s.setForbidOperation(e),e===!0&&r.setSelectedIDs(void 0)},a.current.setShowDefaultCursor=e=>{var t,s;(s=(t=r.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||s.setShowDefaultCursor(e)},a.current.asyncData=e=>{setTimeout(()=>{p==null||p(e)})}},[r.pointCloudBoxList,r.pointCloudSphereList,r.selectedID,r.valid,r.polygonList,r.lineList,r.mainViewInstance,r.ptSegmentInstance]),React.useEffect(()=>{a.current.updateSegmentTool=e=>{var t;(t=r.ptSegmentInstance)==null||t.emit(e)},a.current.segmentInstance=r.ptSegmentInstance},[r.ptSegmentInstance]),React.useEffect(()=>{a.current.history={pushHistory:e=>{N({pointCloudBoxList:e})},initRecord:()=>{}}},[]),React.useEffect(()=>{var e;const t=(e=r.topViewInstance)==null?void 0:e.toolInstance;if(!t||i)return;const s=l=>{x(l)},n=l=>{antd.message.error(l)},c=l=>{antd.message.info(l)};return t.on("syncAttribute",s),t.on("messageError",n),t.on("messageInfo",c),()=>{t.unbind("syncAttribute",s),t.unbind("messageError",n),t.unbind("messageInfo",c)}},[r.topViewInstance]),null};var PointCloudListener$1=reactRedux.connect(map.a2MapStateToProps,null,null,{context:ctx.LabelBeeContext})(PointCloudListener);module.exports=PointCloudListener$1;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var React=require("react"),PointCloudContext=require("../PointCloudContext.js"),useHistory=require("./useHistory.js"),__defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(t,e,r)=>e in t?__defProp(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,__spreadValues=(t,e)=>{for(var r in e||(e={}))__hasOwnProp.call(e,r)&&__defNormalProp(t,r,e[r]);if(__getOwnPropSymbols)for(var r of __getOwnPropSymbols(e))__propIsEnum.call(e,r)&&__defNormalProp(t,r,e[r]);return t},__spreadProps=(t,e)=>__defProps(t,__getOwnPropDescs(e));const useLine=()=>{const{lineList:t,setLineList:e,selectedID:r}=React.useContext(PointCloudContext.PointCloudContext),{addHistory:a,pushHistoryWithList:d}=useHistory.useHistory(),s=t.find(i=>i.id===r);return{addLine:i=>{e(t.concat(i)),a({newLine:i})},deleteLine:i=>{const o=t.filter(n=>n.id!==i).map(n=>__spreadValues({},n));e(o),d({lineList:o})},selectedLine:s,updateSelectedLine:i=>{s&&e(t.map(o=>o.id===r?i:o))},updateLineValidByID:i=>{t.find(n=>n.id===i)&&e(t.map(n=>n.id===i?__spreadProps(__spreadValues({},n),{valid:!n.valid}):n))}}};exports.useLine=useLine;
@@ -0,0 +1,12 @@
1
+ import { ILine } from '@labelbee/lb-utils';
2
+ /**
3
+ * PointCloud line Hook
4
+ * @returns
5
+ */
6
+ export declare const useLine: () => {
7
+ addLine: (line: ILine) => void;
8
+ deleteLine: (id: string) => void;
9
+ selectedLine: ILine | undefined;
10
+ updateSelectedLine: (line: ILine) => void;
11
+ updateLineValidByID: (id: string) => void;
12
+ };
@@ -1 +1 @@
1
- import a,{useState as g,useEffect as C}from"react";import{prefix as B}from"../../../constant/index.js";import{Button as U,Input as X}from"antd";import Y from"./components/answerSort/index.js";import{connect as Z}from"react-redux";import{isNumber as k,isObject as tt}from"lodash";import et from"./components/answerList/index.js";import{LabelBeeContext as rt}from"../../../store/ctx.js";import{jsonParser as D}from"../../../utils/index.js";import{getStepConfig as ot}from"../../../store/annotation/reducer.js";import{useCustomToolInstance as nt}from"../../../hooks/annotation.js";import{PageForward as I}from"../../../store/annotation/actionCreators.js";import{EToolName as st}from"@labelbee/lb-annotation";import{useTranslation as it}from"react-i18next";import{getCurrentResultFromResultList as R,formatSort as $}from"../utils/data.js";var at=Object.defineProperty,lt=Object.defineProperties,ct=Object.getOwnPropertyDescriptors,q=Object.getOwnPropertySymbols,ut=Object.prototype.hasOwnProperty,dt=Object.prototype.propertyIsEnumerable,F=(n,r,s)=>r in n?at(n,r,{enumerable:!0,configurable:!0,writable:!0,value:s}):n[r]=s,w=(n,r)=>{for(var s in r||(r={}))ut.call(r,s)&&F(n,s,r[s]);if(q)for(var s of q(r))dt.call(r,s)&&F(n,s,r[s]);return n},V=(n,r)=>lt(n,ct(r));const{TextArea:mt}=X,W=`${B}-sidebar`,pt=`${B}-LLMSidebar-contentBox`,ft=n=>{var r;const{annotation:s,dispatch:y,checkMode:x}=n,{imgIndex:S,imgList:h,stepList:P,step:j,skipBeforePageTurning:O}=s,{t:A}=it(),o=(r=h[S])!=null?r:{},z=D(o==null?void 0:o.result),{toolInstanceRef:M}=nt({basicInfo:z}),[m,G]=g(),[u,N]=g([]),[L,T]=g(void 0),[_,E]=g([]),[H,J]=g([]);C(()=>{var t;if(P&&j){const e=(t=ot(P,j))==null?void 0:t.config;G(D(e))}},[P,j]),C(()=>{if(!o)return;const t=R(o==null?void 0:o.result);let e=(t==null?void 0:t.answerList)?t:o==null?void 0:o.questionList;(e==null?void 0:e.answerList)&&(K(e.answerList),N(e.answerList||[])),T(t==null?void 0:t.textAttribute)},[S,o]),C(()=>{M.current.exportData=()=>{const l=$(_);return[[{answerList:u,sort:l,textAttribute:L,id:o==null?void 0:o.id}],{}]};const t=$(_),e={answerList:u,sort:t,textAttribute:L,id:o==null?void 0:o.id,toolName:st.LLM};M.current.currentPageResult=e},[u,_,L]);const K=t=>{var e;if(E([]),(t==null?void 0:t.length)>0){let l=[],p=[];const i=R(o==null?void 0:o.result),f=(i==null?void 0:i.length)>0?i[0]:i;((e=f==null?void 0:f.sort)==null?void 0:e.length)>0&&(p=f.sort.reduce((c,d)=>{let v=[{title:d[0],id:d[0]}];return d.length>1&&(v=d.map(b=>({title:b,id:b}))),[...c,v]},[]),E(p)),t.forEach(c=>{p.some(v=>v.length>1?v.some(b=>b.id===c.order):v[0].id===c.order)||l.push({title:c.order,id:c.order})}),J(l)}},Q=({order:t,value:e,key:l})=>{const p=u==null?void 0:u.map(i=>{var f;if((i==null?void 0:i.order)===t){if(k(e))return V(w({},i),{score:e});if(tt(e)&&l){const c={[e==null?void 0:e.key]:e.value},d=(f=i[l])!=null?f:{};return V(w({},i),{[l]:w(w({},d),c)})}}return i});N(p)};return a.createElement("div",{className:`${W}`},a.createElement("div",{className:`${W}__content`},a.createElement("div",{style:{padding:"0px 16px"}},u.length>0&&m&&a.createElement(et,{list:u,LLMConfig:m,updateValue:Q,checkMode:x}),(m==null?void 0:m.enableSort)&&a.createElement(Y,{waitSortList:H,sortList:_,setSortList:E,checkMode:x}),(m==null?void 0:m.text)&&a.createElement("div",{style:{padding:"0px 16px",marginBottom:"16px"}},a.createElement("div",{className:`${pt}__title`},A("AdditionalContent")),a.createElement("div",{style:{display:"flex",alignItems:"center"}},a.createElement(mt,{value:L,onChange:t=>{T(t.target.value)},maxLength:1e3,disabled:x,showCount:!0,style:{width:"100%"}}))),a.createElement("div",{style:{margin:"24px 16px",display:"flex"}},(h==null?void 0:h.length)-1!==S&&a.createElement(U,{type:"primary",style:{marginLeft:"auto"},onClick:()=>{if(O){O(()=>y(I()));return}y(I())},disabled:x},A("Submit"))))))},vt=n=>({annotation:n.annotation});var gt=Z(vt,null,null,{context:rt})(ft);export{gt as default};
1
+ import a,{useState as g,useEffect as E}from"react";import{prefix as B}from"../../../constant/index.js";import{Button as U,Input as X}from"antd";import Y from"./components/answerSort/index.js";import{connect as Z}from"react-redux";import{isNumber as k,isObject as tt}from"lodash";import et from"./components/answerList/index.js";import{LabelBeeContext as rt}from"../../../store/ctx.js";import{jsonParser as D}from"../../../utils/index.js";import{getStepConfig as ot}from"../../../store/annotation/reducer.js";import{useCustomToolInstance as nt}from"../../../hooks/annotation.js";import{PageForward as I}from"../../../store/annotation/actionCreators.js";import{EToolName as st}from"@labelbee/lb-annotation";import{useTranslation as it}from"react-i18next";import{getCurrentResultFromResultList as R,formatSort as $}from"../utils/data.js";var at=Object.defineProperty,lt=Object.defineProperties,ct=Object.getOwnPropertyDescriptors,q=Object.getOwnPropertySymbols,ut=Object.prototype.hasOwnProperty,dt=Object.prototype.propertyIsEnumerable,F=(n,r,s)=>r in n?at(n,r,{enumerable:!0,configurable:!0,writable:!0,value:s}):n[r]=s,w=(n,r)=>{for(var s in r||(r={}))ut.call(r,s)&&F(n,s,r[s]);if(q)for(var s of q(r))dt.call(r,s)&&F(n,s,r[s]);return n},V=(n,r)=>lt(n,ct(r));const{TextArea:mt}=X,W=`${B}-sidebar`,pt=`${B}-LLMSidebar-contentBox`,ft=n=>{var r;const{annotation:s,dispatch:C,checkMode:x}=n,{imgIndex:S,imgList:h,stepList:P,step:j,skipBeforePageTurning:y}=s,{t:O}=it(),o=(r=h[S])!=null?r:{},z=D(o==null?void 0:o.result),{toolInstanceRef:A}=nt({basicInfo:z}),[m,G]=g(),[u,M]=g([]),[L,N]=g(void 0),[_,T]=g([]),[H,J]=g([]);E(()=>{var t;if(P&&j){const e=(t=ot(P,j))==null?void 0:t.config;G(D(e))}},[P,j]),E(()=>{if(!o)return;const t=R(o==null?void 0:o.result);let e=(t==null?void 0:t.answerList)?t:o==null?void 0:o.questionList;(e==null?void 0:e.answerList)&&(K(e.answerList),M(e.answerList||[])),N(t==null?void 0:t.textAttribute)},[S,o]),E(()=>{A.current.exportData=()=>{const l=$(_);return[[{answerList:u,sort:l,textAttribute:L,id:o==null?void 0:o.id}],{}]};const t=$(_),e={answerList:u,sort:t,textAttribute:L,id:o==null?void 0:o.id,toolName:st.LLM};A.current.currentPageResult=e},[u,_,L]);const K=t=>{var e;let l=[],p=[];if((t==null?void 0:t.length)>0){const i=R(o==null?void 0:o.result),f=(i==null?void 0:i.length)>0?i[0]:i;((e=f==null?void 0:f.sort)==null?void 0:e.length)>0&&(p=f.sort.reduce((c,d)=>{let v=[{title:d[0],id:d[0]}];return d.length>1&&(v=d.map(b=>({title:b,id:b}))),[...c,v]},[])),t.forEach(c=>{p.some(v=>v.length>1?v.some(b=>b.id===c.order):v[0].id===c.order)||l.push({title:c.order,id:c.order})})}T(p),J(l)},Q=({order:t,value:e,key:l})=>{const p=u==null?void 0:u.map(i=>{var f;if((i==null?void 0:i.order)===t){if(k(e))return V(w({},i),{score:e});if(tt(e)&&l){const c={[e==null?void 0:e.key]:e.value},d=(f=i[l])!=null?f:{};return V(w({},i),{[l]:w(w({},d),c)})}}return i});M(p)};return a.createElement("div",{className:`${W}`},a.createElement("div",{className:`${W}__content`},a.createElement("div",{style:{padding:"0px 16px"}},u.length>0&&m&&a.createElement(et,{list:u,LLMConfig:m,updateValue:Q,checkMode:x}),(m==null?void 0:m.enableSort)&&a.createElement(Y,{waitSortList:H,sortList:_,setSortList:T,checkMode:x}),(m==null?void 0:m.text)&&a.createElement("div",{style:{padding:"0px 16px",marginBottom:"16px"}},a.createElement("div",{className:`${pt}__title`},O("AdditionalContent")),a.createElement("div",{style:{display:"flex",alignItems:"center"}},a.createElement(mt,{value:L,onChange:t=>{N(t.target.value)},maxLength:1e3,disabled:x,showCount:!0,style:{width:"100%"}}))),a.createElement("div",{style:{margin:"24px 16px",display:"flex"}},(h==null?void 0:h.length)-1!==S&&a.createElement(U,{type:"primary",style:{marginLeft:"auto"},onClick:()=>{if(y){y(()=>C(I()));return}C(I())},disabled:x},O("Submit"))))))},vt=n=>({annotation:n.annotation});var gt=Z(vt,null,null,{context:rt})(ft);export{gt as default};
@@ -1 +1 @@
1
- import{PointCloudContext as X}from"./PointCloudContext.js";import{useRotate as Z}from"./hooks/useRotate.js";import{useBoxes as R}from"./hooks/useBoxes.js";import{useSingleBox as ee}from"./hooks/useSingleBox.js";import{useSphere as te}from"./hooks/useSphere.js";import{useContext as oe,useEffect as c}from"react";import{CommonToolUtils as re,AttributeUtils as ne,EToolName as v,cTool as se}from"@labelbee/lb-annotation";import{message as g}from"antd";import{connect as ie}from"react-redux";import{a2MapStateToProps as ae}from"../../store/annotation/map.js";import{useStatus as ue}from"./hooks/useStatus.js";import{usePointCloudViews as le}from"./hooks/usePointCloudViews.js";import{LabelBeeContext as ce}from"../../store/ctx.js";import{useHistory as de}from"./hooks/useHistory.js";import{useAttribute as pe}from"./hooks/useAttribute.js";import{useConfig as me}from"./hooks/useConfig.js";import{usePolygon as be}from"./hooks/usePolygon.js";import{useTranslation as ve}from"react-i18next";var Pe=Object.defineProperty,ye=Object.defineProperties,fe=Object.getOwnPropertyDescriptors,j=Object.getOwnPropertySymbols,we=Object.prototype.hasOwnProperty,Ce=Object.prototype.propertyIsEnumerable,I=(u,r,a)=>r in u?Pe(u,r,{enumerable:!0,configurable:!0,writable:!0,value:a}):u[r]=a,S=(u,r)=>{for(var a in r||(r={}))we.call(r,a)&&I(u,a,r[a]);if(j)for(var a of j(r))Ce.call(r,a)&&I(u,a,r[a]);return u},h=(u,r)=>ye(u,fe(r));const{EPolygonPattern:ge}=se,Se=({currentData:u,config:r,checkMode:a,configString:D,imgIndex:k,toolInstanceRef:i})=>{const o=oe(X),{changeSelectedBoxValid:T,selectNextBox:E,selectPrevBox:K,updateSelectedBox:x,deleteSelectedPointCloudBoxAndPolygon:N}=ee(),{selectedSphere:P,updatePointCloudSphere:H}=te(),{clearAllResult:y,updatePointCloudPattern:z}=ue(),{copySelectedBoxes:U,pasteSelectedBoxes:F,copiedBoxes:q}=R({config:r}),{updateRotate:f}=Z({currentData:u}),{updatePointCloudData:m,topViewSelectedChanged:_}=le(),{redo:V,undo:B,pushHistoryWithList:G,pushHistoryUnderUpdatePolygon:M}=de(),{syncThreeViewsAttribute:O}=pe(),{syncAllViewsConfig:W,reRenderTopViewRange:Y}=me(),{selectedPolygon:L}=be(),{t:w}=ve(),b=e=>{var t;const{topViewInstance:n}=o;!n||(t=n.pointCloud2dOperation)==null||t.updateSelectedPolygonsPoints(e)},$=(e,t)=>{var n,s;const{topViewInstance:d,mainViewInstance:l}=o;if(!d)return;const{pointCloud2dOperation:C}=d;switch(e){case"q":{f(2);break}case"e":f(-2);break;case"g":f(180);break;case"u":{const p=C.pattern===ge.Normal?v.Rect:v.Polygon;z(p);const Q={[v.Polygon]:w("PolygonPattern"),[v.Rect]:w("RectPattern")};g.success(w("ChangePatternMsg",{pattern:Q[p]})),C.clearActiveStatus(),C.clearDrawingStatus()}break;case"+":l==null||l.updatePointSize({zoomIn:!0});break;case"-":l==null||l.updatePointSize({zoomIn:!1});break;case"v":o.setPointCloudValid(!o.valid);break;case"tab":if(t.shiftKey){K();break}E(),t.preventDefault();break;case"f":T();break;case"arrowup":b({y:-1});break;case"arrowdown":b({y:1});break;case"arrowleft":b({x:-1});break;case"arrowright":b({x:1});break;case"delete":N();break;default:{if(((n=r.attributeList)==null?void 0:n.length)>0){const p=ne.getAttributeByKeycode(t.keyCode,r.attributeList);p!==void 0&&((s=i.current)==null||s.setDefaultAttribute(p))}return}}},J=(e,t)=>{switch(e){case"c":U();break;case"v":F();break;case"a":t.preventDefault(),o.selectedAllBoxes();break;case"z":{t.shiftKey?V():B();break}}},A=e=>{if(!re.hotkeyFilter(e)||a===!0)return;const t=e.key.toLocaleLowerCase();if(e.ctrlKey){J(t,e);return}$(t,e)};return c(()=>{const{topViewInstance:e}=o;if(!!e)return window.addEventListener("keydown",A),()=>{window.removeEventListener("keydown",A)}},[o,q,r,o.pointCloudBoxList,o.polygonList]),c(()=>{W(r)},[D]),c(()=>{(r==null?void 0:r.radius)&&Y(r==null?void 0:r.radius)},[r==null?void 0:r.radius]),c(()=>{m==null||m()},[k,o.mainViewInstance]),c(()=>{o.setHideAttributes([])},[k]),c(()=>{i.current.setDefaultAttribute=e=>{var t;O(e);const n=o.selectedPointCloudBox;if(n){n.attribute=e;const s=x(n);o.mainViewInstance&&_({newSelectedBox:n,newPointCloudList:s})}if(L&&M(h(S({},L),{attribute:e})),P){const s=H(h(S({},P),{attribute:e}));o.mainViewInstance&&((t=o.mainViewInstance)==null||t.generateSpheres(s),_({newSelectedSphere:P,newSphereList:s}))}},i.current.setSubAttribute=(e,t)=>{var n;const s=o.selectedPointCloudBox;if(s){const d=(n=s==null?void 0:s.subAttribute)!=null?n:{};s.subAttribute=h(S({},d),{[e]:t}),x(s)}},i.current.clearResult=()=>{y==null||y()},i.current.redo=()=>{V()},i.current.undo=()=>{B()},i.current.setValid=e=>{i.current.valid=e,setTimeout(()=>{o.setPointCloudValid(e),e===!1&&y()})},i.current.setForbidOperation=e=>{var t,n;(n=(t=o.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||n.setForbidOperation(e),e===!0&&o.setSelectedIDs(void 0)},i.current.setShowDefaultCursor=e=>{var t,n;(n=(t=o.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||n.setShowDefaultCursor(e)},i.current.asyncData=e=>{setTimeout(()=>{m==null||m(e)})}},[o.pointCloudBoxList,o.pointCloudSphereList,o.selectedID,o.valid,o.polygonList,o.lineList,o.mainViewInstance,o.ptSegmentInstance]),c(()=>{i.current.updateSegmentTool=e=>{var t;(t=o.ptSegmentInstance)==null||t.emit(e)},i.current.segmentInstance=o.ptSegmentInstance},[o.ptSegmentInstance]),c(()=>{i.current.history={pushHistory:e=>{G({pointCloudBoxList:e})},initRecord:()=>{}}},[]),c(()=>{var e;const t=(e=o.topViewInstance)==null?void 0:e.toolInstance;if(!t||a)return;const n=l=>{O(l)},s=l=>{g.error(l)},d=l=>{g.info(l)};return t.on("syncAttribute",n),t.on("messageError",s),t.on("messageInfo",d),()=>{t.unbind("syncAttribute",n),t.unbind("messageError",s),t.unbind("messageInfo",d)}},[o.topViewInstance]),null};var he=ie(ae,null,null,{context:ce})(Se);export{he as default};
1
+ import{PointCloudContext as R}from"./PointCloudContext.js";import{useRotate as ee}from"./hooks/useRotate.js";import{useBoxes as te}from"./hooks/useBoxes.js";import{useSingleBox as oe}from"./hooks/useSingleBox.js";import{useSphere as re}from"./hooks/useSphere.js";import{useContext as se,useEffect as c}from"react";import{CommonToolUtils as ne,AttributeUtils as ie,EToolName as f,cTool as ae}from"@labelbee/lb-annotation";import{message as S}from"antd";import{connect as ue}from"react-redux";import{a2MapStateToProps as le}from"../../store/annotation/map.js";import{useStatus as ce}from"./hooks/useStatus.js";import{usePointCloudViews as de}from"./hooks/usePointCloudViews.js";import{LabelBeeContext as pe}from"../../store/ctx.js";import{useHistory as me}from"./hooks/useHistory.js";import{useAttribute as be}from"./hooks/useAttribute.js";import{useConfig as fe}from"./hooks/useConfig.js";import{usePolygon as ve}from"./hooks/usePolygon.js";import{useLine as ye}from"./hooks/useLine.js";import{useTranslation as Pe}from"react-i18next";var we=Object.defineProperty,Ce=Object.defineProperties,he=Object.getOwnPropertyDescriptors,I=Object.getOwnPropertySymbols,ge=Object.prototype.hasOwnProperty,Se=Object.prototype.propertyIsEnumerable,D=(u,r,a)=>r in u?we(u,r,{enumerable:!0,configurable:!0,writable:!0,value:a}):u[r]=a,v=(u,r)=>{for(var a in r||(r={}))ge.call(r,a)&&D(u,a,r[a]);if(I)for(var a of I(r))Se.call(r,a)&&D(u,a,r[a]);return u},y=(u,r)=>Ce(u,he(r));const{EPolygonPattern:ke}=ae,xe=({currentData:u,config:r,checkMode:a,configString:T,imgIndex:k,toolInstanceRef:i})=>{const o=se(R),{changeSelectedBoxValid:E,selectNextBox:H,selectPrevBox:K,updateSelectedBox:x,deleteSelectedPointCloudBoxAndPolygon:N}=oe(),{selectedSphere:P,updatePointCloudSphere:U}=re(),{clearAllResult:w,updatePointCloudPattern:z}=ce(),{copySelectedBoxes:F,pasteSelectedBoxes:q,copiedBoxes:G}=te({config:r}),{updateRotate:C}=ee({currentData:u}),{updatePointCloudData:m,topViewSelectedChanged:_}=de(),{redo:L,undo:V,pushHistoryWithList:M,pushHistoryUnderUpdatePolygon:W,pushHistoryUnderUpdateLine:Y}=me(),{syncThreeViewsAttribute:B}=be(),{syncAllViewsConfig:$,reRenderTopViewRange:J}=fe(),{selectedPolygon:O}=ve(),{selectedLine:j}=ye(),{t:h}=Pe(),b=e=>{var t;const{topViewInstance:s}=o;!s||(t=s.pointCloud2dOperation)==null||t.updateSelectedPolygonsPoints(e)},Q=(e,t)=>{var s,n;const{topViewInstance:d,mainViewInstance:l}=o;if(!d)return;const{pointCloud2dOperation:g}=d;switch(e){case"q":{C(2);break}case"e":C(-2);break;case"g":C(180);break;case"u":{const p=g.pattern===ke.Normal?f.Rect:f.Polygon;z(p);const Z={[f.Polygon]:h("PolygonPattern"),[f.Rect]:h("RectPattern")};S.success(h("ChangePatternMsg",{pattern:Z[p]})),g.clearActiveStatus(),g.clearDrawingStatus()}break;case"+":l==null||l.updatePointSize({zoomIn:!0});break;case"-":l==null||l.updatePointSize({zoomIn:!1});break;case"v":o.setPointCloudValid(!o.valid);break;case"tab":if(t.shiftKey){K();break}H(),t.preventDefault();break;case"f":E();break;case"arrowup":b({y:-1});break;case"arrowdown":b({y:1});break;case"arrowleft":b({x:-1});break;case"arrowright":b({x:1});break;case"delete":N();break;default:{if(((s=r.attributeList)==null?void 0:s.length)>0){const p=ie.getAttributeByKeycode(t.keyCode,r.attributeList);p!==void 0&&((n=i.current)==null||n.setDefaultAttribute(p))}return}}},X=(e,t)=>{switch(e){case"c":F();break;case"v":q();break;case"a":t.preventDefault(),o.selectedAllBoxes();break;case"z":{t.shiftKey?L():V();break}}},A=e=>{if(!ne.hotkeyFilter(e)||a===!0)return;const t=e.key.toLocaleLowerCase();if(e.ctrlKey){X(t,e);return}Q(t,e)};return c(()=>{const{topViewInstance:e}=o;if(!!e)return window.addEventListener("keydown",A),()=>{window.removeEventListener("keydown",A)}},[o,G,r,o.pointCloudBoxList,o.polygonList]),c(()=>{$(r)},[T]),c(()=>{(r==null?void 0:r.radius)&&J(r==null?void 0:r.radius)},[r==null?void 0:r.radius]),c(()=>{m==null||m()},[k,o.mainViewInstance]),c(()=>{o.setHideAttributes([])},[k]),c(()=>{i.current.setDefaultAttribute=e=>{var t;B(e);const s=o.selectedPointCloudBox;if(s){s.attribute=e;const n=x(s);o.mainViewInstance&&_({newSelectedBox:s,newPointCloudList:n})}if(O&&W(y(v({},O),{attribute:e})),j&&Y(y(v({},j),{attribute:e})),P){const n=U(y(v({},P),{attribute:e}));o.mainViewInstance&&((t=o.mainViewInstance)==null||t.generateSpheres(n),_({newSelectedSphere:P,newSphereList:n}))}},i.current.setSubAttribute=(e,t)=>{var s;const n=o.selectedPointCloudBox;if(n){const d=(s=n==null?void 0:n.subAttribute)!=null?s:{};n.subAttribute=y(v({},d),{[e]:t}),x(n)}},i.current.clearResult=()=>{w==null||w()},i.current.redo=()=>{L()},i.current.undo=()=>{V()},i.current.setValid=e=>{i.current.valid=e,setTimeout(()=>{o.setPointCloudValid(e),e===!1&&w()})},i.current.setForbidOperation=e=>{var t,s;(s=(t=o.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||s.setForbidOperation(e),e===!0&&o.setSelectedIDs(void 0)},i.current.setShowDefaultCursor=e=>{var t,s;(s=(t=o.topViewInstance)==null?void 0:t.pointCloud2dOperation)==null||s.setShowDefaultCursor(e)},i.current.asyncData=e=>{setTimeout(()=>{m==null||m(e)})}},[o.pointCloudBoxList,o.pointCloudSphereList,o.selectedID,o.valid,o.polygonList,o.lineList,o.mainViewInstance,o.ptSegmentInstance]),c(()=>{i.current.updateSegmentTool=e=>{var t;(t=o.ptSegmentInstance)==null||t.emit(e)},i.current.segmentInstance=o.ptSegmentInstance},[o.ptSegmentInstance]),c(()=>{i.current.history={pushHistory:e=>{M({pointCloudBoxList:e})},initRecord:()=>{}}},[]),c(()=>{var e;const t=(e=o.topViewInstance)==null?void 0:e.toolInstance;if(!t||a)return;const s=l=>{B(l)},n=l=>{S.error(l)},d=l=>{S.info(l)};return t.on("syncAttribute",s),t.on("messageError",n),t.on("messageInfo",d),()=>{t.unbind("syncAttribute",s),t.unbind("messageError",n),t.unbind("messageInfo",d)}},[o.topViewInstance]),null};var _e=ue(le,null,null,{context:pe})(xe);export{_e as default};
@@ -0,0 +1 @@
1
+ import{useContext as u}from"react";import{PointCloudContext as f}from"../PointCloudContext.js";import{useHistory as L}from"./useHistory.js";var _=Object.defineProperty,m=Object.defineProperties,P=Object.getOwnPropertyDescriptors,a=Object.getOwnPropertySymbols,y=Object.prototype.hasOwnProperty,O=Object.prototype.propertyIsEnumerable,d=(t,e,r)=>e in t?_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,p=(t,e)=>{for(var r in e||(e={}))y.call(e,r)&&d(t,r,e[r]);if(a)for(var r of a(e))O.call(e,r)&&d(t,r,e[r]);return t},w=(t,e)=>m(t,P(e));const v=()=>{const{lineList:t,setLineList:e,selectedID:r}=u(f),{addHistory:c,pushHistoryWithList:l}=L(),s=t.find(i=>i.id===r);return{addLine:i=>{e(t.concat(i)),c({newLine:i})},deleteLine:i=>{const o=t.filter(n=>n.id!==i).map(n=>p({},n));e(o),l({lineList:o})},selectedLine:s,updateSelectedLine:i=>{s&&e(t.map(o=>o.id===r?i:o))},updateLineValidByID:i=>{t.find(n=>n.id===i)&&e(t.map(n=>n.id===i?w(p({},n),{valid:!n.valid}):n))}}};export{v as useLine};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@labelbee/lb-components",
3
- "version": "1.13.0-alpha.2",
3
+ "version": "1.13.0-alpha.4",
4
4
  "description": "Provide a complete library of annotation components",
5
5
  "main": "./dist/index.js",
6
6
  "es": "./es/index.js",
@@ -43,7 +43,7 @@
43
43
  },
44
44
  "dependencies": {
45
45
  "@ant-design/icons": "^4.6.2",
46
- "@labelbee/lb-annotation": "1.17.0-alpha.1",
46
+ "@labelbee/lb-annotation": "1.17.0-alpha.2",
47
47
  "@labelbee/lb-utils": "1.9.0-alpha.1",
48
48
  "ahooks": "^3.4.0",
49
49
  "classnames": "^2.3.0",