@univerjs/docs-hyper-link-ui 0.17.0 → 0.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/index.js +24 -1
- package/lib/cjs/locale/ca-ES.js +1 -1
- package/lib/cjs/locale/en-US.js +1 -1
- package/lib/cjs/locale/es-ES.js +1 -1
- package/lib/cjs/locale/fa-IR.js +1 -1
- package/lib/cjs/locale/fr-FR.js +1 -1
- package/lib/cjs/locale/ja-JP.js +1 -1
- package/lib/cjs/locale/ko-KR.js +1 -1
- package/lib/cjs/locale/ru-RU.js +1 -1
- package/lib/cjs/locale/sk-SK.js +1 -1
- package/lib/cjs/locale/vi-VN.js +1 -1
- package/lib/cjs/locale/zh-CN.js +1 -1
- package/lib/cjs/locale/zh-TW.js +1 -1
- package/lib/es/index.js +24 -850
- package/lib/es/locale/ca-ES.js +1 -26
- package/lib/es/locale/en-US.js +1 -26
- package/lib/es/locale/es-ES.js +1 -26
- package/lib/es/locale/fa-IR.js +1 -26
- package/lib/es/locale/fr-FR.js +1 -26
- package/lib/es/locale/ja-JP.js +1 -26
- package/lib/es/locale/ko-KR.js +1 -26
- package/lib/es/locale/ru-RU.js +1 -26
- package/lib/es/locale/sk-SK.js +1 -26
- package/lib/es/locale/vi-VN.js +1 -26
- package/lib/es/locale/zh-CN.js +1 -26
- package/lib/es/locale/zh-TW.js +1 -26
- package/lib/index.css +146 -1
- package/lib/index.js +24 -850
- package/lib/locale/ca-ES.js +1 -26
- package/lib/locale/en-US.js +1 -26
- package/lib/locale/es-ES.js +1 -26
- package/lib/locale/fa-IR.js +1 -26
- package/lib/locale/fr-FR.js +1 -26
- package/lib/locale/ja-JP.js +1 -26
- package/lib/locale/ko-KR.js +1 -26
- package/lib/locale/ru-RU.js +1 -26
- package/lib/locale/sk-SK.js +1 -26
- package/lib/locale/vi-VN.js +1 -26
- package/lib/locale/zh-CN.js +1 -26
- package/lib/locale/zh-TW.js +1 -26
- package/lib/types/commands/commands/add-link.command.d.ts +16 -1
- package/lib/types/commands/commands/delete-link.command.d.ts +16 -1
- package/lib/types/commands/commands/update-link.command.d.ts +16 -1
- package/lib/types/commands/operations/popup.operation.d.ts +16 -1
- package/lib/types/config/config.d.ts +16 -1
- package/lib/types/controllers/doc-hyper-link-selection.controller.d.ts +15 -0
- package/lib/types/controllers/render-controllers/hyper-link-event.render-controller.d.ts +19 -3
- package/lib/types/controllers/render-controllers/render.controller.d.ts +18 -2
- package/lib/types/controllers/ui.controller.d.ts +17 -1
- package/lib/types/locale/ca-ES.d.ts +16 -1
- package/lib/types/locale/es-ES.d.ts +16 -1
- package/lib/types/locale/fa-IR.d.ts +16 -1
- package/lib/types/locale/fr-FR.d.ts +16 -1
- package/lib/types/locale/ja-JP.d.ts +16 -1
- package/lib/types/locale/ko-KR.d.ts +16 -1
- package/lib/types/locale/ru-RU.d.ts +16 -1
- package/lib/types/locale/sk-SK.d.ts +16 -1
- package/lib/types/locale/vi-VN.d.ts +16 -1
- package/lib/types/locale/zh-CN.d.ts +16 -1
- package/lib/types/locale/zh-TW.d.ts +16 -1
- package/lib/types/menu/menu.d.ts +17 -2
- package/lib/types/menu/schema.d.ts +16 -1
- package/lib/types/plugin.d.ts +16 -1
- package/lib/types/services/hyper-link-popup.service.d.ts +19 -3
- package/lib/umd/index.js +24 -1
- package/lib/umd/locale/ca-ES.js +1 -1
- package/lib/umd/locale/en-US.js +1 -1
- package/lib/umd/locale/es-ES.js +1 -1
- package/lib/umd/locale/fa-IR.js +1 -1
- package/lib/umd/locale/fr-FR.js +1 -1
- package/lib/umd/locale/ja-JP.js +1 -1
- package/lib/umd/locale/ko-KR.js +1 -1
- package/lib/umd/locale/ru-RU.js +1 -1
- package/lib/umd/locale/sk-SK.js +1 -1
- package/lib/umd/locale/vi-VN.js +1 -1
- package/lib/umd/locale/zh-CN.js +1 -1
- package/lib/umd/locale/zh-TW.js +1 -1
- package/package.json +13 -12
package/lib/cjs/index.js
CHANGED
|
@@ -1 +1,24 @@
|
|
|
1
|
-
"use strict";var me=Object.defineProperty;var Ce=(n,e,t)=>e in n?me(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var L=(n,e,t)=>Ce(n,typeof e!="symbol"?e+"":e,t);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("@univerjs/core"),_e=require("@univerjs/docs-hyper-link"),ye=require("@univerjs/engine-render"),y=require("@univerjs/docs"),$=require("@univerjs/docs-ui"),D=require("rxjs"),u=require("react/jsx-runtime"),C=require("@univerjs/design"),l=require("@univerjs/ui"),_=require("react"),Se="@univerjs/docs-hyper-link-ui",xe="0.17.0",ce={name:Se,version:xe},ke="docs-hyper-link-ui.config",oe={},de={type:o.CommandType.COMMAND,id:"docs.command.add-hyper-link",async handler(n,e){if(!e)return!1;const{payload:t,unitId:i,selections:r}=e,s=n.get(o.ICommandService),c=o.generateRandomId(),d=y.addCustomRangeBySelectionFactory(n,{rangeId:c,rangeType:o.CustomRangeType.HYPERLINK,properties:{url:t},unitId:i,selections:r});return d?s.syncExecuteCommand(d.id,d.params):!1}},ae={id:"docs.command.update-hyper-link",type:o.CommandType.COMMAND,handler(n,e){var h;if(!e)return!1;const{unitId:t,payload:i,segmentId:r,linkId:s}=e,c=n.get(o.ICommandService),d=n.get(o.IUniverInstanceService),v=n.get(y.DocSelectionManagerService).getActiveTextRange(),f=d.getUnit(t,o.UniverInstanceType.UNIVER_DOC);if(!v||!f)return!1;const I=(h=o.getBodySlice(f.getSelfOrHeaderFooterModel(r).getBody(),v.startOffset,v.endOffset).textRuns)==null?void 0:h[0];I&&(I.ed=e.label.length+1);const a=y.replaceSelectionFactory(n,{unitId:t,body:{dataStream:`${e.label}`,customRanges:[{rangeId:s,rangeType:o.CustomRangeType.HYPERLINK,startIndex:0,endIndex:e.label.length+1,properties:{url:i}}],textRuns:I?[I]:void 0},selection:{startOffset:v.startOffset,endOffset:v.endOffset,collapsed:!1,segmentId:r}});return a?c.syncExecuteCommand(a.id,a.params):!1}};function Le(n){return/^[a-zA-Z]+:\/\//.test(n)}function De(n){return/^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$/.test(n)}function we(n){return Le(n)?n:De(n)?`mailto://${n}`:`https://${n}`}const E=()=>{const n=l.useDependency(x),e=l.useDependency(o.LocaleService),t=l.useObservable(n.editingLink$),i=l.useDependency(o.ICommandService),r=l.useDependency(o.IUniverInstanceService),s=l.useDependency(y.DocSelectionManagerService),[c,d]=_.useState(""),[g,v]=_.useState(""),[f,m]=_.useState(!1),I=o.Tools.isLegalUrl(c),a=t?r.getUnit(t.unitId,o.UniverInstanceType.UNIVER_DOC):r.getCurrentUnitForType(o.UniverInstanceType.UNIVER_DOC);_.useEffect(()=>{var z,J,Q,X,ee,ne,te,ie,re;const p=s.getActiveTextRange();if(!p)return;if(t){const M=(z=a==null?void 0:a.getSelfOrHeaderFooterModel(t.segmentId))==null?void 0:z.getBody(),U=(J=M==null?void 0:M.customRanges)==null?void 0:J.find(K=>(t==null?void 0:t.linkId)===K.rangeId&&K.startIndex===t.startIndex&&K.endIndex===t.endIndex);a&&U&&(d((X=(Q=U.properties)==null?void 0:Q.url)!=null?X:""),v(o.BuildTextUtils.transform.getPlainText(o.getBodySlice(M,U.startIndex,U.endIndex+1).dataStream)));return}const k=(ee=a==null?void 0:a.getSelfOrHeaderFooterModel(p.segmentId))==null?void 0:ee.getBody(),G=k?p:null,R=G&&((te=o.BuildTextUtils.customRange.getCustomRangesInterestsWithSelection(G,(ne=k==null?void 0:k.customRanges)!=null?ne:[]))==null?void 0:te[0]);a&&R&&d((re=(ie=R==null?void 0:R.properties)==null?void 0:ie.url)!=null?re:"")},[a,t,s,r]);const h=()=>{n.hideEditPopup()},S=()=>{if(m(!0),!I||!a)return;const p=we(c);if(!t)i.executeCommand(de.id,{unitId:a.getUnitId(),payload:p});else{if(!g)return;i.executeCommand(ae.id,{unitId:a.getUnitId(),payload:p,linkId:t.linkId,label:g,segmentId:t.segmentId})}n.hideEditPopup()};if(a)return u.jsxs("div",{className:C.clsx("univer-box-border univer-w-[328px] univer-rounded-xl univer-bg-white univer-px-6 univer-py-5 univer-shadow dark:!univer-bg-gray-900",C.borderClassName),children:[u.jsxs("div",{children:[t?u.jsx(C.FormLayout,{label:e.t("docLink.edit.label"),error:f&&!g?e.t("docLink.edit.labelError"):"",children:u.jsx(C.Input,{value:g,onChange:v,autoFocus:!0,onKeyDown:p=>{p.keyCode===l.KeyCode.ENTER&&S()}})}):null,u.jsx(C.FormLayout,{label:e.t("docLink.edit.address"),error:f&&!I?e.t("docLink.edit.addressError"):"",children:u.jsx(C.Input,{value:c,onChange:d,autoFocus:!0,onKeyDown:p=>{p.keyCode===l.KeyCode.ENTER&&S()}})})]}),u.jsxs("div",{className:"univer-flex univer-justify-end univer-gap-3",children:[u.jsx(C.Button,{onClick:h,children:e.t("docLink.edit.cancel")}),u.jsx(C.Button,{variant:"primary",disabled:!c,onClick:S,children:e.t("docLink.edit.confirm")})]})]})};E.componentKey="docs-hyper-link-edit";function P({ref:n,...e}){const{icon:t,id:i,className:r,extend:s,...c}=e,d=`univerjs-icon univerjs-icon-${i} ${r||""}`.trim(),g=_.useRef(`_${Re()}`);return ue(t,`${i}`,{defIds:t.defIds,idSuffix:g.current},{ref:n,className:d,...c},s)}function ue(n,e,t,i,r){return _.createElement(n.tag,{key:e,...Oe(n,t,r),...i},(Pe(n,t).children||[]).map((s,c)=>ue(s,`${e}-${n.tag}-${c}`,t,void 0,r)))}function Oe(n,e,t){const i={...n.attrs};t!=null&&t.colorChannel1&&i.fill==="colorChannel1"&&(i.fill=t.colorChannel1),n.tag==="mask"&&i.id&&(i.id=i.id+e.idSuffix),Object.entries(i).forEach(([s,c])=>{s==="mask"&&typeof c=="string"&&(i[s]=c.replace(/url\(#(.*)\)/,`url(#$1${e.idSuffix})`))});const{defIds:r}=e;return!r||r.length===0||(n.tag==="use"&&i["xlink:href"]&&(i["xlink:href"]=i["xlink:href"]+e.idSuffix),Object.entries(i).forEach(([s,c])=>{typeof c=="string"&&(i[s]=c.replace(/url\(#(.*)\)/,`url(#$1${e.idSuffix})`))})),i}function Pe(n,e){var i;const{defIds:t}=e;return!t||t.length===0?n:n.tag==="defs"&&((i=n.children)!=null&&i.length)?{...n,children:n.children.map(r=>typeof r.attrs.id=="string"&&t&&t.includes(r.attrs.id)?{...r,attrs:{...r.attrs,id:r.attrs.id+e.idSuffix}}:r)}:n}function Re(){return Math.random().toString(36).substring(2,8)}P.displayName="UniverIcon";const Me={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M4.1302 12.4251C4.25802 13.7417 5.36779 14.7708 6.71792 14.7708H11.7179C13.1539 14.7708 14.3179 13.6067 14.3179 12.1708V6.1708C14.3179 4.78586 13.2351 3.65383 11.8698 3.57517C11.742 2.25858 10.6323 1.22949 9.28213 1.22949H4.28213C2.84619 1.22949 1.68213 2.39355 1.68213 3.82949V9.82949C1.68213 11.2144 2.76497 12.3465 4.1302 12.4251ZM10.6583 3.5708H6.71792C5.28198 3.5708 4.11792 4.73486 4.11792 6.1708V11.22C3.4221 11.1387 2.88213 10.5471 2.88213 9.82949V3.82949C2.88213 3.05629 3.50893 2.42949 4.28213 2.42949H9.28213C9.96695 2.42949 10.5369 2.92119 10.6583 3.5708ZM13.1179 6.1708C13.1179 5.3976 12.4911 4.7708 11.7179 4.7708H6.71792C5.94472 4.7708 5.31792 5.3976 5.31792 6.1708V12.1708C5.31792 12.944 5.94472 13.5708 6.71792 13.5708H11.7179C12.4911 13.5708 13.1179 12.944 13.1179 12.1708V6.1708Z",fillRule:"evenodd",clipRule:"evenodd"}}]},le=_.forwardRef(function(e,t){return _.createElement(P,Object.assign({},e,{id:"copy-icon",ref:t,icon:Me}))});le.displayName="CopyIcon";const Ue={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M9.8816 1.97978C11.0177 0.843607 12.862 0.884962 14.0004 2.02342C15.1389 3.16188 15.1803 5.00612 14.0441 6.14228L11.399 8.78737C11.1608 9.02559 10.7746 9.02559 10.5363 8.78737C10.2981 8.54915 10.2981 8.16292 10.5363 7.9247L13.1814 5.2796C13.8195 4.64155 13.8217 3.57006 13.1378 2.8861C12.4538 2.20211 11.3823 2.20438 10.7443 2.84245L7.6976 5.88911L7.69317 5.89349C7.05959 6.53211 7.05894 7.60014 7.74132 8.28252C7.97954 8.52074 7.97954 8.90697 7.74132 9.14519C7.5031 9.38341 7.11687 9.38341 6.87865 9.14519C5.74016 8.00671 5.69884 6.16251 6.83497 5.02633L6.84021 5.02116L9.8816 1.97978Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M4.61426 7.2364C4.85248 6.99818 5.23871 6.99818 5.47693 7.2364C5.71515 7.47462 5.71515 7.86085 5.47693 8.09907L2.83183 10.7442C2.19375 11.3823 2.1915 12.4537 2.87547 13.1377C3.55945 13.8217 4.6309 13.8194 5.26899 13.1813L8.31566 10.1347C8.32262 10.1277 8.32971 10.121 8.33691 10.1144C8.34408 10.1064 8.3515 10.0986 8.35916 10.091C8.99721 9.45291 8.99949 8.38145 8.3155 7.69746C8.07728 7.45924 8.07728 7.07301 8.3155 6.83479C8.55372 6.59657 8.93995 6.59657 9.17817 6.83479C10.3166 7.97327 10.358 9.81748 9.22183 10.9536C9.21487 10.9606 9.20779 10.9673 9.20058 10.9739C9.19341 10.9819 9.18599 10.9897 9.17833 10.9973L6.13166 14.044C4.99548 15.1802 3.15127 15.1389 2.01279 14.0004C0.874362 12.8619 0.83297 11.0177 1.96916 9.8815L4.61426 7.2364Z"}}]},W=_.forwardRef(function(e,t){return _.createElement(P,Object.assign({},e,{id:"link-icon",ref:t,icon:Ue}))});W.displayName="LinkIcon";const be={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 16 17",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M12.5935 3.47302C11.6354 2.51492 10.082 2.51492 9.12388 3.47302L7.83534 4.76157C7.60102 4.99588 7.22112 4.99588 6.98681 4.76157C6.75249 4.52725 6.75249 4.14735 6.98681 3.91304L8.27535 2.62449C9.70209 1.19776 12.0153 1.19776 13.442 2.62449C14.8688 4.05123 14.8688 6.36442 13.442 7.79116L12.1535 9.0797C11.9192 9.31402 11.5393 9.31402 11.3049 9.0797C11.0706 8.84539 11.0706 8.46549 11.3049 8.23117L12.5935 6.94263C13.5516 5.98452 13.5516 4.43113 12.5935 3.47302Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.40637 12.6606C2.44827 11.7025 2.44827 10.1491 3.40637 9.19102L4.69492 7.90248C4.92923 7.66816 4.92923 7.28826 4.69492 7.05395C4.4606 6.81963 4.0807 6.81963 3.84639 7.05395L2.55784 8.34249C1.13111 9.76923 1.13111 12.0824 2.55784 13.5092C3.98458 14.9359 6.29777 14.9359 7.72451 13.5092L9.01305 12.2206C9.24737 11.9863 9.24737 11.6064 9.01305 11.3721C8.77874 11.1378 8.39884 11.1378 8.16452 11.3721L6.87598 12.6606C5.91787 13.6187 4.36448 13.6187 3.40637 12.6606Z"}},{tag:"path",attrs:{fill:"currentColor",d:"M3.5852 2.80332C3.35088 2.569 2.97098 2.569 2.73667 2.80332C2.50235 3.03763 2.50235 3.41753 2.73667 3.65185L12.4151 13.3302C12.6494 13.5646 13.0293 13.5646 13.2636 13.3302C13.4979 13.0959 13.4979 12.716 13.2636 12.4817L3.5852 2.80332Z"}}]},pe=_.forwardRef(function(e,t){return _.createElement(P,Object.assign({},e,{id:"unlink-icon",ref:t,icon:be}))});pe.displayName="UnlinkIcon";const Ee={tag:"svg",attrs:{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 17 16",width:"1em",height:"1em"},children:[{tag:"path",attrs:{fill:"currentColor",d:"M12.6551 1.98906C11.7476 1.08113 10.2757 1.08149 9.3686 1.98987L4.82542 6.53955C4.75087 6.61421 4.69336 6.70411 4.65682 6.80309L3.2461 10.625C3.16506 10.8446 3.21909 11.0912 3.3845 11.2568C3.54991 11.4224 3.79651 11.4767 4.01616 11.3959L7.85031 9.98517C7.94979 9.94856 8.04014 9.89077 8.11508 9.81579L12.6552 5.27327C13.5618 4.36621 13.5618 2.89607 12.6551 1.98906ZM10.2177 2.83779C10.6562 2.39869 11.3677 2.39851 11.8064 2.8374C12.2447 3.27584 12.2447 3.9865 11.8065 4.42497L7.3392 8.89457L4.82213 9.82068L5.74706 7.31487L10.2177 2.83779Z",fillRule:"evenodd",clipRule:"evenodd"}},{tag:"path",attrs:{fill:"currentColor",d:"M1.79238 13.2999C1.46101 13.2999 1.19238 13.5685 1.19238 13.8999C1.19238 14.2313 1.46101 14.4999 1.79238 14.4999H14.4924C14.8238 14.4999 15.0924 14.2313 15.0924 13.8999C15.0924 13.5685 14.8238 13.2999 14.4924 13.2999H1.79238Z"}}]},ge=_.forwardRef(function(e,t){return _.createElement(P,Object.assign({},e,{id:"write-icon",ref:t,icon:Ee}))});ge.displayName="WriteIcon";const ve={type:o.CommandType.COMMAND,id:"docs.command.delete-hyper-link",async handler(n,e){if(!e)return!1;const{unitId:t,linkId:i,segmentId:r}=e,s=n.get(o.ICommandService),c=y.deleteCustomRangeFactory(n,{unitId:t,rangeId:i,segmentId:r});return c?await s.syncExecuteCommand(c.id,c.params):!1}},he=n=>{const e=n.get(y.DocSelectionManagerService),t=n.get(o.IUniverInstanceService),i=e.getTextRanges();if(!(i!=null&&i.length))return!0;const r=i[0];return!!(!t.getCurrentUnitForType(o.UniverInstanceType.UNIVER_DOC)||!r||r.collapsed)},w={type:o.CommandType.OPERATION,id:"doc.operation.show-hyper-link-edit-popup",handler(n,e){var c;const t=e==null?void 0:e.link,i=n.get(o.IUniverInstanceService);if(he(n)&&!t)return!1;const r=n.get(x),s=(t==null?void 0:t.unitId)||((c=i.getCurrentUnitForType(o.UniverInstanceType.UNIVER_DOC))==null?void 0:c.getUnitId());return s?(r.showEditPopup(s,t),!0):!1}},Z={type:o.CommandType.OPERATION,id:"doc.operation.toggle-hyper-link-info-popup",handler(n,e){const t=n.get(x);return e?(t.showInfoPopup(e),!0):(t.hideInfoPopup(),!0)}},Ie={type:o.CommandType.OPERATION,id:"doc.operation.click-hyper-link",handler(n,e){var v,f,m;if(!e)return!1;const{unitId:t,linkId:i,segmentId:r}=e,c=n.get(o.IUniverInstanceService).getUnit(t,o.UniverInstanceType.UNIVER_DOC),d=c==null?void 0:c.getSelfOrHeaderFooterModel(r).getBody(),g=(m=(f=(v=d==null?void 0:d.customRanges)==null?void 0:v.find(I=>I.rangeId===i&&I.rangeType===o.CustomRangeType.HYPERLINK))==null?void 0:f.properties)==null?void 0:m.url;return g&&window.open(g,"_blank","noopener noreferrer"),!0}},T=()=>{var S,p;const n=l.useDependency(x),e=l.useDependency(o.ICommandService),t=l.useDependency(l.IMessageService),i=l.useDependency(o.LocaleService),r=l.useObservable(n.showingLink$),s=l.useDependency(o.IUniverInstanceService);if(!r)return null;const{unitId:c,linkId:d,segmentId:g,startIndex:v,endIndex:f}=r,m=s.getUnit(c,o.UniverInstanceType.UNIVER_DOC),I=m==null?void 0:m.getSelfOrHeaderFooterModel(g).getBody(),a=(S=I==null?void 0:I.customRanges)==null?void 0:S.find(k=>k.rangeId===d&&k.rangeType===o.CustomRangeType.HYPERLINK&&k.startIndex===v&&k.endIndex===f);if(!a)return null;const h=(p=a.properties)==null?void 0:p.url;return u.jsxs("div",{className:C.clsx("univer-box-border univer-flex univer-max-w-80 univer-items-center univer-justify-between univer-overflow-hidden univer-rounded-lg univer-bg-white univer-p-3 univer-shadow dark:!univer-bg-gray-900",C.borderClassName),onClick:()=>{n.hideInfoPopup()},children:[u.jsxs("div",{className:"univer-flex univer-h-6 univer-flex-1 univer-cursor-pointer univer-items-center univer-truncate univer-text-sm univer-leading-5 univer-text-primary-500",onClick:()=>window.open(h,void 0,"noopener noreferrer"),children:[u.jsx("div",{className:"univer-mr-2 univer-flex univer-size-5 univer-flex-[0_0_auto] univer-items-center univer-justify-center univer-text-base univer-text-gray-900 dark:!univer-text-white",children:u.jsx(W,{})}),u.jsx(C.Tooltip,{showIfEllipsis:!0,title:h,children:u.jsx("span",{className:"univer-flex-1 univer-truncate",children:h})})]}),u.jsxs("div",{className:"univer-flex univer-h-6 univer-flex-[0_0_auto] univer-items-center univer-justify-center",children:[u.jsx("div",{className:"univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-text-base",onClick:()=>{navigator.clipboard.writeText(h),t.show({content:i.t("docLink.info.coped"),type:C.MessageType.Info})},children:u.jsx(C.Tooltip,{placement:"bottom",title:i.t("docLink.info.copy"),children:u.jsx(le,{})})}),u.jsx("div",{className:"univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-text-base",onClick:()=>{e.executeCommand(w.id,{link:r})},children:u.jsx(C.Tooltip,{placement:"bottom",title:i.t("docLink.info.edit"),children:u.jsx(ge,{})})}),u.jsx("div",{className:"univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center univer-justify-center univer-rounded univer-text-base",onClick:()=>{e.executeCommand(ve.id,{unitId:c,linkId:a.rangeId,segmentId:g})},children:u.jsx(C.Tooltip,{placement:"bottom",title:i.t("docLink.info.cancel"),children:u.jsx(pe,{})})})]})]})};T.componentKey="univer.doc.link-info-popup";var Te=Object.getOwnPropertyDescriptor,je=(n,e,t,i)=>{for(var r=i>1?void 0:i?Te(e,t):e,s=n.length-1,c;s>=0;s--)(c=n[s])&&(r=c(r)||r);return r},A=(n,e)=>(t,i)=>e(t,i,n);let x=class extends o.Disposable{constructor(e,t,i){super();L(this,"_editingLink$",new D.BehaviorSubject(null));L(this,"_showingLink$",new D.BehaviorSubject(null));L(this,"editingLink$",this._editingLink$.asObservable());L(this,"showingLink$",this._showingLink$.asObservable());L(this,"_editPopup",null);L(this,"_infoPopup",null);this._docCanvasPopupManagerService=e,this._textSelectionManagerService=t,this._univerInstanceService=i,this.disposeWithMe(()=>{this._editingLink$.complete(),this._showingLink$.complete()})}get editing(){return this._editingLink$.value}get showing(){return this._showingLink$.value}showEditPopup(e,t){this._editPopup&&this._editPopup.dispose(),this._editingLink$.next(t);const i=this._textSelectionManagerService.getTextRanges({unitId:e,subUnitId:e});let r=i==null?void 0:i[i.length-1];if(t){const{segmentId:s,segmentPage:c,startIndex:d,endIndex:g}=t;r={collapsed:!1,startOffset:d,endOffset:g+1,segmentId:s,segmentPage:c},this._textSelectionManagerService.replaceDocRanges([{startOffset:d,endOffset:g+1}])}return r?(this._editPopup=this._docCanvasPopupManagerService.attachPopupToRange(r,{componentKey:E.componentKey,direction:"bottom"},e),this._editPopup):null}hideEditPopup(){var e;this._editingLink$.next(null),(e=this._editPopup)==null||e.dispose()}showInfoPopup(e){var v,f,m,I,a,h;const{linkId:t,unitId:i,segmentId:r,segmentPage:s,startIndex:c,endIndex:d}=e;if(!(((v=this.showing)==null?void 0:v.linkId)===t&&((f=this.showing)==null?void 0:f.unitId)===i&&((m=this.showing)==null?void 0:m.segmentId)===r&&((I=this.showing)==null?void 0:I.segmentPage)===s&&((a=this.showing)==null?void 0:a.startIndex)===c&&((h=this.showing)==null?void 0:h.endIndex)===d||(this._infoPopup&&this._infoPopup.dispose(),!this._univerInstanceService.getUnit(i,o.UniverInstanceType.UNIVER_DOC))))return this._showingLink$.next({unitId:i,linkId:t,segmentId:r,segmentPage:s,startIndex:c,endIndex:d}),this._infoPopup=this._docCanvasPopupManagerService.attachPopupToRange({collapsed:!1,startOffset:c,endOffset:d+1,segmentId:r,segmentPage:s},{componentKey:T.componentKey,direction:"top-center",multipleDirection:"top",onClickOutside:()=>{this.hideInfoPopup()}},i),this._infoPopup}hideInfoPopup(){var e;this._showingLink$.next(null),(e=this._infoPopup)==null||e.dispose()}};x=je([A(0,o.Inject($.DocCanvasPopManagerService)),A(1,o.Inject(y.DocSelectionManagerService)),A(2,o.IUniverInstanceService)],x);var Ne=Object.getOwnPropertyDescriptor,$e=(n,e,t,i)=>{for(var r=i>1?void 0:i?Ne(e,t):e,s=n.length-1,c;s>=0;s--)(c=n[s])&&(r=c(r)||r);return r},B=(n,e)=>(t,i)=>e(t,i,n);let j=class extends o.Disposable{constructor(n,e,t){super(),this._commandService=n,this._univerInstanceService=e,this._docHyperLinkService=t,this._initSelectionChange()}_initSelectionChange(){this.disposeWithMe(this._commandService.onCommandExecuted(n=>{var e,t,i;if(n.id===y.SetTextSelectionsOperation.id){const r=n.params,{unitId:s,ranges:c,segmentId:d}=r,g=this._univerInstanceService.getUnit(s,o.UniverInstanceType.UNIVER_DOC),v=c[0];if(v&&g){const{startOffset:f,endOffset:m,collapsed:I,segmentPage:a}=v,h=(t=(e=g.getSelfOrHeaderFooterModel(d))==null?void 0:e.getBody())==null?void 0:t.customRanges;if(I){const S=(i=h==null?void 0:h.findIndex(p=>p.startIndex<f&&p.endIndex>m-1))!=null?i:-1;if(S>-1){const p=h[S];this._docHyperLinkService.showInfoPopup({unitId:s,linkId:p.rangeId,segmentId:d,segmentPage:a,startIndex:p.startIndex,endIndex:p.endIndex});return}}else if(h==null?void 0:h.find(p=>p.startIndex<=f&&p.endIndex>=m-1))return}this._docHyperLinkService.hideInfoPopup(),this._docHyperLinkService.hideEditPopup()}}))}};j=$e([B(0,o.ICommandService),B(1,o.IUniverInstanceService),B(2,o.Inject(x))],j);var He=Object.getOwnPropertyDescriptor,Ke=(n,e,t,i)=>{for(var r=i>1?void 0:i?He(e,t):e,s=n.length-1,c;s>=0;s--)(c=n[s])&&(r=c(r)||r);return r},O=(n,e)=>(t,i)=>e(t,i,n);let Y=class extends o.Disposable{constructor(n,e,t,i,r,s){super(),this._context=n,this._docEventManagerService=e,this._commandService=t,this._hyperLinkPopupService=i,this._docSkeletonManagerService=r,this._docSelectionManagerService=s,!(this._context.unitId===o.DOCS_ZEN_EDITOR_UNIT_ID_KEY||this._context.unitId===o.DOCS_NORMAL_EDITOR_UNIT_ID_KEY)&&(this._initHover(),this._initClick())}get _skeleton(){return this._docSkeletonManagerService.getSkeleton()}_hideInfoPopup(){this._hyperLinkPopupService.showing&&this._commandService.executeCommand(Z.id)}_initHover(){this.disposeWithMe(this._docEventManagerService.hoverCustomRanges$.subscribe(n=>{var r;const e=n.find(s=>s.range.rangeType===o.CustomRangeType.HYPERLINK),t=this._docSelectionManagerService.getTextRanges(),i=t==null?void 0:t[0].segmentId;if(((r=e==null?void 0:e.segmentId)!=null?r:"")!==i){this._hideInfoPopup();return}e?this._commandService.executeCommand(Z.id,{unitId:this._context.unitId,linkId:e.range.rangeId,segmentId:e.segmentId,segmentPage:e.segmentPageIndex,rangeId:e.range.rangeId,startIndex:e.range.startIndex,endIndex:e.range.endIndex}):this._hideInfoPopup()}))}_initClick(){this.disposeWithMe(this._docEventManagerService.clickCustomRanges$.subscribe(n=>{const e=n.range;e&&this._commandService.executeCommand(Ie.id,{unitId:this._context.unitId,linkId:e.rangeId,segmentId:n.segmentId})}))}};Y=Ke([O(1,o.Inject($.DocEventManagerService)),O(2,o.ICommandService),O(3,o.Inject(x)),O(4,o.Inject(y.DocSkeletonManagerService)),O(5,o.Inject(y.DocSelectionManagerService))],Y);var Ae=Object.getOwnPropertyDescriptor,Be=(n,e,t,i)=>{for(var r=i>1?void 0:i?Ae(e,t):e,s=n.length-1,c;s>=0;s--)(c=n[s])&&(r=c(r)||r);return r},F=(n,e)=>(t,i)=>e(t,i,n);let q=class extends o.Disposable{constructor(n,e,t,i){super(),this._context=n,this._docInterceptorService=e,this._hyperLinkService=t,this._docRenderController=i,this._init(),this._initReRender()}_init(){this._docInterceptorService.intercept(y.DOC_INTERCEPTOR_POINT.CUSTOM_RANGE,{handler:(n,e,t)=>{if(!n)return t(n);const{unitId:i,index:r}=e,s=this._hyperLinkService.showing;if(!s)return t({...n,active:!1});const{linkId:c,unitId:d,startIndex:g,endIndex:v}=s,f=d===i&&n.rangeId===c&&r>=g&&r<=v;return t({...n,active:f})}})}_initReRender(){this.disposeWithMe(this._hyperLinkService.showingLink$.pipe(D.distinctUntilChanged((n,e)=>(n==null?void 0:n.linkId)===(e==null?void 0:e.linkId)&&(n==null?void 0:n.unitId)===(e==null?void 0:e.unitId)&&(n==null?void 0:n.startIndex)===(e==null?void 0:e.startIndex)),D.pairwise()).subscribe(([n,e])=>{e?e.unitId===this._context.unitId&&this._docRenderController.reRender(e.unitId):n&&n.unitId===this._context.unitId&&this._docRenderController.reRender(n.unitId)}))}};q=Be([F(1,o.Inject(y.DocInterceptorService)),F(2,o.Inject(x)),F(3,o.Inject($.DocRenderController))],q);const fe="doc-hyper-link-icon";function se(n){return{id:w.id,type:l.MenuItemType.BUTTON,icon:fe,title:"docLink.menu.tooltip",tooltip:"docLink.menu.tooltip",hidden$:l.getMenuHiddenObservable(n,o.UniverInstanceType.UNIVER_DOC),disabled$:new D.Observable(function(e){const i=n.get(y.DocSelectionManagerService).textSelection$.pipe(D.debounceTime(16)).subscribe(()=>{e.next(he(n))});return()=>{i.unsubscribe()}})}}const Fe={id:w.id,binding:l.MetaKeys.CTRL_COMMAND|l.KeyCode.K,description:"docLink.menu.tooltip",preconditions:$.whenDocAndEditorFocused},Ve={[l.RibbonInsertGroup.MEDIA]:{[w.id]:{order:1,menuItemFactory:se}},[l.ContextMenuPosition.MAIN_AREA]:{[l.ContextMenuGroup.DATA]:{[w.id]:{order:0,menuItemFactory:se}}}};var Ze=Object.getOwnPropertyDescriptor,Ye=(n,e,t,i)=>{for(var r=i>1?void 0:i?Ze(e,t):e,s=n.length-1,c;s>=0;s--)(c=n[s])&&(r=c(r)||r);return r},b=(n,e)=>(t,i)=>e(t,i,n);let N=class extends o.Disposable{constructor(n,e,t,i){super(),this._componentManager=n,this._commandService=e,this._menuManagerService=t,this._shortcutService=i,this._initComponents(),this._initCommands(),this._initMenus(),this._initShortcut()}_initComponents(){[[E.componentKey,E],[T.componentKey,T],[fe,W]].forEach(([n,e])=>{this.disposeWithMe(this._componentManager.register(n,e))})}_initCommands(){[de,ae,ve,w,Z,Ie].forEach(n=>{this._commandService.registerCommand(n)})}_initShortcut(){[Fe].forEach(n=>{this._shortcutService.registerShortcut(n)})}_initMenus(){this._menuManagerService.mergeMenu(Ve)}};N=Ye([b(0,o.Inject(l.ComponentManager)),b(1,o.ICommandService),b(2,l.IMenuManagerService),b(3,l.IShortcutService)],N);const qe="DOC_HYPER_LINK_UI_PLUGIN";var We=Object.defineProperty,Ge=Object.getOwnPropertyDescriptor,ze=(n,e,t)=>e in n?We(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t,Je=(n,e,t,i)=>{for(var r=i>1?void 0:i?Ge(e,t):e,s=n.length-1,c;s>=0;s--)(c=n[s])&&(r=c(r)||r);return r},V=(n,e)=>(t,i)=>e(t,i,n),H=(n,e,t)=>ze(n,typeof e!="symbol"?e+"":e,t);exports.UniverDocsHyperLinkUIPlugin=class extends o.Plugin{constructor(e=oe,t,i,r){super(),this._config=e,this._injector=t,this._renderManagerSrv=i,this._configService=r;const{menu:s,...c}=o.merge({},oe,this._config);s&&this._configService.setConfig("menu",s,{merge:!0}),this._configService.setConfig(ke,c)}onStarting(){[[x],[N],[j]].forEach(t=>{this._injector.add(t)}),this._injector.get(N)}onReady(){this._injector.get(j)}onRendered(){this._initRenderModule()}_initRenderModule(){[[q],[Y]].forEach(e=>{this._renderManagerSrv.registerRenderModule(o.UniverInstanceType.UNIVER_DOC,e)})}};H(exports.UniverDocsHyperLinkUIPlugin,"pluginName",qe);H(exports.UniverDocsHyperLinkUIPlugin,"packageName",ce.name);H(exports.UniverDocsHyperLinkUIPlugin,"version",ce.version);H(exports.UniverDocsHyperLinkUIPlugin,"type",o.UniverInstanceType.UNIVER_DOC);exports.UniverDocsHyperLinkUIPlugin=Je([o.DependentOn(_e.UniverDocsHyperLinkPlugin),V(1,o.Inject(o.Injector)),V(2,ye.IRenderManagerService),V(3,o.IConfigService)],exports.UniverDocsHyperLinkUIPlugin);
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require(`@univerjs/core`),t=require(`@univerjs/docs-hyper-link`),n=require(`@univerjs/engine-render`),r=require(`@univerjs/docs`),i=require(`@univerjs/docs-ui`),a=require(`rxjs`),o=require(`@univerjs/design`),s=require(`@univerjs/ui`),c=require(`react`),l=require(`react/jsx-runtime`),u=require(`@univerjs/icons`);var d=`@univerjs/docs-hyper-link-ui`,f=`0.18.0`;const p=`docs-hyper-link-ui.config`;Symbol(p);const m={},h={type:e.CommandType.COMMAND,id:`docs.command.add-hyper-link`,async handler(t,n){if(!n)return!1;let{payload:i,unitId:a,selections:o}=n,s=t.get(e.ICommandService),c=(0,r.addCustomRangeBySelectionFactory)(t,{rangeId:(0,e.generateRandomId)(),rangeType:e.CustomRangeType.HYPERLINK,properties:{url:i},unitId:a,selections:o});return c?s.syncExecuteCommand(c.id,c.params):!1}},g={id:`docs.command.update-hyper-link`,type:e.CommandType.COMMAND,handler(t,n){var i;if(!n)return!1;let{unitId:a,payload:o,segmentId:s,linkId:c}=n,l=t.get(e.ICommandService),u=t.get(e.IUniverInstanceService),d=t.get(r.DocSelectionManagerService).getActiveTextRange(),f=u.getUnit(a,e.UniverInstanceType.UNIVER_DOC);if(!d||!f)return!1;let p=(i=(0,e.getBodySlice)(f.getSelfOrHeaderFooterModel(s).getBody(),d.startOffset,d.endOffset).textRuns)==null?void 0:i[0];p&&(p.ed=n.label.length+1);let m=(0,r.replaceSelectionFactory)(t,{unitId:a,body:{dataStream:`${n.label}`,customRanges:[{rangeId:c,rangeType:e.CustomRangeType.HYPERLINK,startIndex:0,endIndex:n.label.length+1,properties:{url:o}}],textRuns:p?[p]:void 0},selection:{startOffset:d.startOffset,endOffset:d.endOffset,collapsed:!1,segmentId:s}});return m?l.syncExecuteCommand(m.id,m.params):!1}};function _(e){return/^[a-zA-Z]+:\/\//.test(e)}function v(e){return/^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$/.test(e)}function y(e){return _(e)?e:v(e)?`mailto://${e}`:`https://${e}`}const b=()=>{let t=(0,s.useDependency)(N),n=(0,s.useDependency)(e.LocaleService),i=(0,s.useObservable)(t.editingLink$),a=(0,s.useDependency)(e.ICommandService),u=(0,s.useDependency)(e.IUniverInstanceService),d=(0,s.useDependency)(r.DocSelectionManagerService),[f,p]=(0,c.useState)(``),[m,_]=(0,c.useState)(``),[v,b]=(0,c.useState)(!1),x=e.Tools.isLegalUrl(f),S=i?u.getUnit(i.unitId,e.UniverInstanceType.UNIVER_DOC):u.getCurrentUnitForType(e.UniverInstanceType.UNIVER_DOC);(0,c.useEffect)(()=>{var t,n,r;let a=d.getActiveTextRange();if(!a)return;if(i){var o,s;let t=S==null||(o=S.getSelfOrHeaderFooterModel(i.segmentId))==null?void 0:o.getBody(),n=t==null||(s=t.customRanges)==null?void 0:s.find(e=>(i==null?void 0:i.linkId)===e.rangeId&&e.startIndex===i.startIndex&&e.endIndex===i.endIndex);if(S&&n){var c,l;p((c=(l=n.properties)==null?void 0:l.url)==null?``:c),_(e.BuildTextUtils.transform.getPlainText((0,e.getBodySlice)(t,n.startIndex,n.endIndex+1).dataStream))}return}let u=S==null||(t=S.getSelfOrHeaderFooterModel(a.segmentId))==null?void 0:t.getBody(),f=u?a:null,m=f&&((n=e.BuildTextUtils.customRange.getCustomRangesInterestsWithSelection(f,(r=u==null?void 0:u.customRanges)==null?[]:r))==null?void 0:n[0]);if(S&&m){var h,g;p((h=m==null||(g=m.properties)==null?void 0:g.url)==null?``:h)}},[S,i,d,u]);let C=()=>{t.hideEditPopup()},w=()=>{if(b(!0),!x||!S)return;let e=y(f);if(!i)a.executeCommand(h.id,{unitId:S.getUnitId(),payload:e});else{if(!m)return;a.executeCommand(g.id,{unitId:S.getUnitId(),payload:e,linkId:i.linkId,label:m,segmentId:i.segmentId})}t.hideEditPopup()};if(S)return(0,l.jsxs)(`div`,{className:(0,o.clsx)(`
|
|
2
|
+
univer-box-border univer-w-[328px] univer-rounded-xl univer-bg-white univer-px-6 univer-py-5 univer-shadow
|
|
3
|
+
dark:!univer-bg-gray-900
|
|
4
|
+
`,o.borderClassName),children:[(0,l.jsxs)(`div`,{children:[i?(0,l.jsx)(o.FormLayout,{label:n.t(`docLink.edit.label`),error:v&&!m?n.t(`docLink.edit.labelError`):``,children:(0,l.jsx)(o.Input,{value:m,onChange:_,autoFocus:!0,onKeyDown:e=>{e.keyCode===s.KeyCode.ENTER&&w()}})}):null,(0,l.jsx)(o.FormLayout,{label:n.t(`docLink.edit.address`),error:v&&!x?n.t(`docLink.edit.addressError`):``,children:(0,l.jsx)(o.Input,{value:f,onChange:p,autoFocus:!0,onKeyDown:e=>{e.keyCode===s.KeyCode.ENTER&&w()}})})]}),(0,l.jsxs)(`div`,{className:`univer-flex univer-justify-end univer-gap-3`,children:[(0,l.jsx)(o.Button,{onClick:C,children:n.t(`docLink.edit.cancel`)}),(0,l.jsx)(o.Button,{variant:`primary`,disabled:!f,onClick:w,children:n.t(`docLink.edit.confirm`)})]})]})};b.componentKey=`docs-hyper-link-edit`;const x={type:e.CommandType.COMMAND,id:`docs.command.delete-hyper-link`,async handler(t,n){if(!n)return!1;let{unitId:i,linkId:a,segmentId:o}=n,s=t.get(e.ICommandService),c=(0,r.deleteCustomRangeFactory)(t,{unitId:i,rangeId:a,segmentId:o});return c?await s.syncExecuteCommand(c.id,c.params):!1}},S=t=>{let n=t.get(r.DocSelectionManagerService),i=t.get(e.IUniverInstanceService),a=n.getTextRanges();if(!(a!=null&&a.length))return!0;let o=a[0];return!!(!i.getCurrentUnitForType(e.UniverInstanceType.UNIVER_DOC)||!o||o.collapsed)},C={type:e.CommandType.OPERATION,id:`doc.operation.show-hyper-link-edit-popup`,handler(t,n){var r;let i=n==null?void 0:n.link,a=t.get(e.IUniverInstanceService);if(S(t)&&!i)return!1;let o=t.get(N),s=(i==null?void 0:i.unitId)||((r=a.getCurrentUnitForType(e.UniverInstanceType.UNIVER_DOC))==null?void 0:r.getUnitId());return s?(o.showEditPopup(s,i),!0):!1}},w={type:e.CommandType.OPERATION,id:`doc.operation.toggle-hyper-link-info-popup`,handler(e,t){let n=e.get(N);return t?(n.showInfoPopup(t),!0):(n.hideInfoPopup(),!0)}},T={type:e.CommandType.OPERATION,id:`doc.operation.click-hyper-link`,handler(t,n){var r;if(!n)return!1;let{unitId:i,linkId:a,segmentId:o}=n,s=t.get(e.IUniverInstanceService).getUnit(i,e.UniverInstanceType.UNIVER_DOC),c=s==null?void 0:s.getSelfOrHeaderFooterModel(o).getBody(),l=c==null||(r=c.customRanges)==null||(r=r.find(t=>t.rangeId===a&&t.rangeType===e.CustomRangeType.HYPERLINK))==null||(r=r.properties)==null?void 0:r.url;return l&&window.open(l,`_blank`,`noopener noreferrer`),!0}},E=()=>{var t,n;let r=(0,s.useDependency)(N),i=(0,s.useDependency)(e.ICommandService),a=(0,s.useDependency)(s.IMessageService),c=(0,s.useDependency)(e.LocaleService),d=(0,s.useObservable)(r.showingLink$),f=(0,s.useDependency)(e.IUniverInstanceService);if(!d)return null;let{unitId:p,linkId:m,segmentId:h,startIndex:g,endIndex:_}=d,v=f.getUnit(p,e.UniverInstanceType.UNIVER_DOC),y=v==null?void 0:v.getSelfOrHeaderFooterModel(h).getBody(),b=y==null||(t=y.customRanges)==null?void 0:t.find(t=>t.rangeId===m&&t.rangeType===e.CustomRangeType.HYPERLINK&&t.startIndex===g&&t.endIndex===_);if(!b)return null;let S=(n=b.properties)==null?void 0:n.url;return(0,l.jsxs)(`div`,{className:(0,o.clsx)(`
|
|
5
|
+
univer-box-border univer-flex univer-max-w-80 univer-items-center univer-justify-between
|
|
6
|
+
univer-overflow-hidden univer-rounded-lg univer-bg-white univer-p-3 univer-shadow
|
|
7
|
+
dark:!univer-bg-gray-900
|
|
8
|
+
`,o.borderClassName),onClick:()=>{r.hideInfoPopup()},children:[(0,l.jsxs)(`div`,{className:`
|
|
9
|
+
univer-flex univer-h-6 univer-flex-1 univer-cursor-pointer univer-items-center univer-truncate
|
|
10
|
+
univer-text-sm univer-leading-5 univer-text-primary-500
|
|
11
|
+
`,onClick:()=>window.open(S,void 0,`noopener noreferrer`),children:[(0,l.jsx)(`div`,{className:`
|
|
12
|
+
univer-mr-2 univer-flex univer-size-5 univer-flex-[0_0_auto] univer-items-center
|
|
13
|
+
univer-justify-center univer-text-base univer-text-gray-900
|
|
14
|
+
dark:!univer-text-white
|
|
15
|
+
`,children:(0,l.jsx)(u.LinkIcon,{})}),(0,l.jsx)(o.Tooltip,{showIfEllipsis:!0,title:S,children:(0,l.jsx)(`span`,{className:`univer-flex-1 univer-truncate`,children:S})})]}),(0,l.jsxs)(`div`,{className:`univer-flex univer-h-6 univer-flex-[0_0_auto] univer-items-center univer-justify-center`,children:[(0,l.jsx)(`div`,{className:`
|
|
16
|
+
univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center
|
|
17
|
+
univer-justify-center univer-rounded univer-text-base
|
|
18
|
+
`,onClick:()=>{navigator.clipboard.writeText(S),a.show({content:c.t(`docLink.info.coped`),type:o.MessageType.Info})},children:(0,l.jsx)(o.Tooltip,{placement:`bottom`,title:c.t(`docLink.info.copy`),children:(0,l.jsx)(u.CopyIcon,{})})}),(0,l.jsx)(`div`,{className:`
|
|
19
|
+
univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center
|
|
20
|
+
univer-justify-center univer-rounded univer-text-base
|
|
21
|
+
`,onClick:()=>{i.executeCommand(C.id,{link:d})},children:(0,l.jsx)(o.Tooltip,{placement:`bottom`,title:c.t(`docLink.info.edit`),children:(0,l.jsx)(u.WriteIcon,{})})}),(0,l.jsx)(`div`,{className:`
|
|
22
|
+
univer-ml-2 univer-flex univer-size-6 univer-cursor-pointer univer-items-center
|
|
23
|
+
univer-justify-center univer-rounded univer-text-base
|
|
24
|
+
`,onClick:()=>{i.executeCommand(x.id,{unitId:p,linkId:b.rangeId,segmentId:h})},children:(0,l.jsx)(o.Tooltip,{placement:`bottom`,title:c.t(`docLink.info.cancel`),children:(0,l.jsx)(u.UnlinkIcon,{})})})]})]})};E.componentKey=`univer.doc.link-info-popup`;function D(e){"@babel/helpers - typeof";return D=typeof Symbol==`function`&&typeof Symbol.iterator==`symbol`?function(e){return typeof e}:function(e){return e&&typeof Symbol==`function`&&e.constructor===Symbol&&e!==Symbol.prototype?`symbol`:typeof e},D(e)}function O(e,t){if(D(e)!=`object`||!e)return e;var n=e[Symbol.toPrimitive];if(n!==void 0){var r=n.call(e,t||`default`);if(D(r)!=`object`)return r;throw TypeError(`@@toPrimitive must return a primitive value.`)}return(t===`string`?String:Number)(e)}function k(e){var t=O(e,`string`);return D(t)==`symbol`?t:t+``}function A(e,t,n){return(t=k(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function j(e,t){return function(n,r){t(n,r,e)}}function M(e,t,n,r){var i=arguments.length,a=i<3?t:r===null?r=Object.getOwnPropertyDescriptor(t,n):r,o;if(typeof Reflect==`object`&&typeof Reflect.decorate==`function`)a=Reflect.decorate(e,t,n,r);else for(var s=e.length-1;s>=0;s--)(o=e[s])&&(a=(i<3?o(a):i>3?o(t,n,a):o(t,n))||a);return i>3&&a&&Object.defineProperty(t,n,a),a}let N=class extends e.Disposable{constructor(e,t,n){super(),this._docCanvasPopupManagerService=e,this._textSelectionManagerService=t,this._univerInstanceService=n,A(this,`_editingLink$`,new a.BehaviorSubject(null)),A(this,`_showingLink$`,new a.BehaviorSubject(null)),A(this,`editingLink$`,this._editingLink$.asObservable()),A(this,`showingLink$`,this._showingLink$.asObservable()),A(this,`_editPopup`,null),A(this,`_infoPopup`,null),this.disposeWithMe(()=>{this._editingLink$.complete(),this._showingLink$.complete()})}get editing(){return this._editingLink$.value}get showing(){return this._showingLink$.value}showEditPopup(e,t){this._editPopup&&this._editPopup.dispose(),this._editingLink$.next(t);let n=this._textSelectionManagerService.getTextRanges({unitId:e,subUnitId:e}),r=n==null?void 0:n[n.length-1];if(t){let{segmentId:e,segmentPage:n,startIndex:i,endIndex:a}=t;r={collapsed:!1,startOffset:i,endOffset:a+1,segmentId:e,segmentPage:n},this._textSelectionManagerService.replaceDocRanges([{startOffset:i,endOffset:a+1}])}return r?(this._editPopup=this._docCanvasPopupManagerService.attachPopupToRange(r,{componentKey:b.componentKey,direction:`bottom`},e),this._editPopup):null}hideEditPopup(){var e;this._editingLink$.next(null),(e=this._editPopup)==null||e.dispose()}showInfoPopup(t){var n,r,i,a,o,s;let{linkId:c,unitId:l,segmentId:u,segmentPage:d,startIndex:f,endIndex:p}=t;if(!(((n=this.showing)==null?void 0:n.linkId)===c&&((r=this.showing)==null?void 0:r.unitId)===l&&((i=this.showing)==null?void 0:i.segmentId)===u&&((a=this.showing)==null?void 0:a.segmentPage)===d&&((o=this.showing)==null?void 0:o.startIndex)===f&&((s=this.showing)==null?void 0:s.endIndex)===p)&&(this._infoPopup&&this._infoPopup.dispose(),this._univerInstanceService.getUnit(l,e.UniverInstanceType.UNIVER_DOC)))return this._showingLink$.next({unitId:l,linkId:c,segmentId:u,segmentPage:d,startIndex:f,endIndex:p}),this._infoPopup=this._docCanvasPopupManagerService.attachPopupToRange({collapsed:!1,startOffset:f,endOffset:p+1,segmentId:u,segmentPage:d},{componentKey:E.componentKey,direction:`top-center`,multipleDirection:`top`,onClickOutside:()=>{this.hideInfoPopup()}},l),this._infoPopup}hideInfoPopup(){var e;this._showingLink$.next(null),(e=this._infoPopup)==null||e.dispose()}};N=M([j(0,(0,e.Inject)(i.DocCanvasPopManagerService)),j(1,(0,e.Inject)(r.DocSelectionManagerService)),j(2,e.IUniverInstanceService)],N);let P=class extends e.Disposable{constructor(e,t,n){super(),this._commandService=e,this._univerInstanceService=t,this._docHyperLinkService=n,this._initSelectionChange()}_initSelectionChange(){this.disposeWithMe(this._commandService.onCommandExecuted(t=>{if(t.id===r.SetTextSelectionsOperation.id){let{unitId:r,ranges:a,segmentId:o}=t.params,s=this._univerInstanceService.getUnit(r,e.UniverInstanceType.UNIVER_DOC),c=a[0];if(c&&s){var n;let{startOffset:e,endOffset:t,collapsed:a,segmentPage:l}=c,u=(n=s.getSelfOrHeaderFooterModel(o))==null||(n=n.getBody())==null?void 0:n.customRanges;if(a){var i;let n=(i=u==null?void 0:u.findIndex(n=>n.startIndex<e&&n.endIndex>t-1))==null?-1:i;if(n>-1){let e=u[n];this._docHyperLinkService.showInfoPopup({unitId:r,linkId:e.rangeId,segmentId:o,segmentPage:l,startIndex:e.startIndex,endIndex:e.endIndex});return}}else if(u!=null&&u.find(n=>n.startIndex<=e&&n.endIndex>=t-1))return}this._docHyperLinkService.hideInfoPopup(),this._docHyperLinkService.hideEditPopup()}}))}};P=M([j(0,e.ICommandService),j(1,e.IUniverInstanceService),j(2,(0,e.Inject)(N))],P);let F=class extends e.Disposable{get _skeleton(){return this._docSkeletonManagerService.getSkeleton()}constructor(t,n,r,i,a,o){super(),this._context=t,this._docEventManagerService=n,this._commandService=r,this._hyperLinkPopupService=i,this._docSkeletonManagerService=a,this._docSelectionManagerService=o,!(this._context.unitId===e.DOCS_ZEN_EDITOR_UNIT_ID_KEY||this._context.unitId===e.DOCS_NORMAL_EDITOR_UNIT_ID_KEY)&&(this._initHover(),this._initClick())}_hideInfoPopup(){this._hyperLinkPopupService.showing&&this._commandService.executeCommand(w.id)}_initHover(){this.disposeWithMe(this._docEventManagerService.hoverCustomRanges$.subscribe(t=>{var n;let r=t.find(t=>t.range.rangeType===e.CustomRangeType.HYPERLINK),i=this._docSelectionManagerService.getTextRanges(),a=i==null?void 0:i[0].segmentId;if(((n=r==null?void 0:r.segmentId)==null?``:n)!==a){this._hideInfoPopup();return}r?this._commandService.executeCommand(w.id,{unitId:this._context.unitId,linkId:r.range.rangeId,segmentId:r.segmentId,segmentPage:r.segmentPageIndex,rangeId:r.range.rangeId,startIndex:r.range.startIndex,endIndex:r.range.endIndex}):this._hideInfoPopup()}))}_initClick(){this.disposeWithMe(this._docEventManagerService.clickCustomRanges$.subscribe(e=>{let t=e.range;t&&this._commandService.executeCommand(T.id,{unitId:this._context.unitId,linkId:t.rangeId,segmentId:e.segmentId})}))}};F=M([j(1,(0,e.Inject)(i.DocEventManagerService)),j(2,e.ICommandService),j(3,(0,e.Inject)(N)),j(4,(0,e.Inject)(r.DocSkeletonManagerService)),j(5,(0,e.Inject)(r.DocSelectionManagerService))],F);let I=class extends e.Disposable{constructor(e,t,n,r){super(),this._context=e,this._docInterceptorService=t,this._hyperLinkService=n,this._docRenderController=r,this._init(),this._initReRender()}_init(){this._docInterceptorService.intercept(r.DOC_INTERCEPTOR_POINT.CUSTOM_RANGE,{handler:(e,t,n)=>{if(!e)return n(e);let{unitId:r,index:i}=t,a=this._hyperLinkService.showing;if(!a)return n({...e,active:!1});let{linkId:o,unitId:s,startIndex:c,endIndex:l}=a,u=s===r&&e.rangeId===o&&i>=c&&i<=l;return n({...e,active:u})}})}_initReRender(){this.disposeWithMe(this._hyperLinkService.showingLink$.pipe((0,a.distinctUntilChanged)((e,t)=>(e==null?void 0:e.linkId)===(t==null?void 0:t.linkId)&&(e==null?void 0:e.unitId)===(t==null?void 0:t.unitId)&&(e==null?void 0:e.startIndex)===(t==null?void 0:t.startIndex)),(0,a.pairwise)()).subscribe(([e,t])=>{t?t.unitId===this._context.unitId&&this._docRenderController.reRender(t.unitId):e&&e.unitId===this._context.unitId&&this._docRenderController.reRender(e.unitId)}))}};I=M([j(1,(0,e.Inject)(r.DocInterceptorService)),j(2,(0,e.Inject)(N)),j(3,(0,e.Inject)(i.DocRenderController))],I);const L=`doc-hyper-link-icon`;function R(t){return{id:C.id,type:s.MenuItemType.BUTTON,icon:L,title:`docLink.menu.tooltip`,tooltip:`docLink.menu.tooltip`,hidden$:(0,s.getMenuHiddenObservable)(t,e.UniverInstanceType.UNIVER_DOC),disabled$:new a.Observable(function(e){let n=t.get(r.DocSelectionManagerService).textSelection$.pipe((0,a.debounceTime)(16)).subscribe(()=>{e.next(S(t))});return()=>{n.unsubscribe()}})}}const z={id:C.id,binding:s.MetaKeys.CTRL_COMMAND|s.KeyCode.K,description:`docLink.menu.tooltip`,preconditions:i.whenDocAndEditorFocused},B={[s.RibbonInsertGroup.MEDIA]:{[C.id]:{order:1,menuItemFactory:R}},[s.ContextMenuPosition.MAIN_AREA]:{[s.ContextMenuGroup.DATA]:{[C.id]:{order:0,menuItemFactory:R}}}};let V=class extends e.Disposable{constructor(e,t,n,r){super(),this._componentManager=e,this._commandService=t,this._menuManagerService=n,this._shortcutService=r,this._initComponents(),this._initCommands(),this._initMenus(),this._initShortcut()}_initComponents(){[[b.componentKey,b],[E.componentKey,E],[L,u.LinkIcon]].forEach(([e,t])=>{this.disposeWithMe(this._componentManager.register(e,t))})}_initCommands(){[h,g,x,C,w,T].forEach(e=>{this._commandService.registerCommand(e)})}_initShortcut(){[z].forEach(e=>{this._shortcutService.registerShortcut(e)})}_initMenus(){this._menuManagerService.mergeMenu(B)}};V=M([j(0,(0,e.Inject)(s.ComponentManager)),j(1,e.ICommandService),j(2,s.IMenuManagerService),j(3,s.IShortcutService)],V);let H=class extends e.Plugin{constructor(t=m,n,r,i){super(),this._config=t,this._injector=n,this._renderManagerSrv=r,this._configService=i;let{menu:a,...o}=(0,e.merge)({},m,this._config);a&&this._configService.setConfig(`menu`,a,{merge:!0}),this._configService.setConfig(p,o)}onStarting(){[[N],[V],[P]].forEach(e=>{this._injector.add(e)}),this._injector.get(V)}onReady(){this._injector.get(P)}onRendered(){this._initRenderModule()}_initRenderModule(){[[I],[F]].forEach(t=>{this._renderManagerSrv.registerRenderModule(e.UniverInstanceType.UNIVER_DOC,t)})}};A(H,`pluginName`,`DOC_HYPER_LINK_UI_PLUGIN`),A(H,`packageName`,d),A(H,`version`,f),A(H,`type`,e.UniverInstanceType.UNIVER_DOC),H=M([(0,e.DependentOn)(t.UniverDocsHyperLinkPlugin),j(1,(0,e.Inject)(e.Injector)),j(2,n.IRenderManagerService),j(3,e.IConfigService)],H),Object.defineProperty(exports,`UniverDocsHyperLinkUIPlugin`,{enumerable:!0,get:function(){return H}});
|
package/lib/cjs/locale/ca-ES.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Confirma`,cancel:`Cancel·la`,title:`Enllaç`,address:`Enllaç`,placeholder:`Si us plau, introdueix una URL`,addressError:`La URL no és vàlida!`,label:`Etiqueta`,labelError:`Si us plau, introdueix l'etiqueta de l'enllaç`},info:{copy:`Copia`,edit:`Edita`,cancel:`Elimina l'enllaç`,coped:`Enllaç copiat al porta-retalls`},menu:{tooltip:`Afegeix enllaç`}}};module.exports=e;
|
package/lib/cjs/locale/en-US.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Confirm`,cancel:`Cancel`,title:`Link`,address:`Link`,placeholder:`Please input a link url`,addressError:`Url is illegal!`,label:`Label`,labelError:`Please input label of link`},info:{copy:`Copy`,edit:`Edit`,cancel:`Cancel link`,coped:`Link copied to clipboard`},menu:{tooltip:`Add link`}}};module.exports=e;
|
package/lib/cjs/locale/es-ES.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Confirmar`,cancel:`Cancelar`,title:`Enlace`,address:`Enlace`,placeholder:`Por favor, introduce una URL`,addressError:`¡La URL no es válida!`,label:`Etiqueta`,labelError:`Por favor, introduce la etiqueta del enlace`},info:{copy:`Copiar`,edit:`Editar`,cancel:`Eliminar enlace`,coped:`Enlace copiado al portapapeles`},menu:{tooltip:`Añadir enlace`}}};module.exports=e;
|
package/lib/cjs/locale/fa-IR.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`تایید`,cancel:`انصراف`,title:`لینک`,address:`لینک`,placeholder:`لطفا یک آدرس لینک وارد کنید`,addressError:`آدرس غیرمجاز است!`,label:`برچسب`,labelError:`لطفا برچسب لینک را وارد کنید`},info:{copy:`کپی`,edit:`ویرایش`,cancel:`لینک را لغو کنید`,coped:`لینک به کلیپ بورد کپی شد`},menu:{tooltip:`افزودن لینک`}}};module.exports=e;
|
package/lib/cjs/locale/fr-FR.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Confirmer`,cancel:`Annuler`,title:`Lien`,address:`Link`,placeholder:`Veuillez entrer un lien`,addressError:`L'url est illégal!`,label:`Label`,labelError:`Veuillez entrer le label du lien`},info:{copy:`Copy`,edit:`Edit`,cancel:`Cancel link`,coped:`Link copied to clipboard`},menu:{tooltip:`Add link`}}};module.exports=e;
|
package/lib/cjs/locale/ja-JP.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`OK`,cancel:`キャンセル`,title:`リンク`,address:`アドレス`,placeholder:`リンクのURLを入力してください`,addressError:`URLが正しくありません!`,label:`表示文字列`,labelError:`リンクの表示文字列を入力してください`},info:{copy:`コピー`,edit:`編集`,cancel:`リンク解除`,coped:`リンクがクリップボードにコピーされました`},menu:{tooltip:`ハイパーリンクの挿入`}}};module.exports=e;
|
package/lib/cjs/locale/ko-KR.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`확인`,cancel:`취소`,title:`링크`,address:`링크`,placeholder:`링크 URL을 입력해주세요`,addressError:`URL이 올바르지 않습니다!`,label:`라벨`,labelError:`링크 라벨을 입력해주세요`},info:{copy:`복사`,edit:`편집`,cancel:`링크 취소`,coped:`링크가 클립보드에 복사되었습니다`},menu:{tooltip:`링크 추가`}}};module.exports=e;
|
package/lib/cjs/locale/ru-RU.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Подтвердить`,cancel:`Отменить`,title:`Ссылка`,address:`Ссылка`,label:`Текст`,labelError:`Введите текст ссылки`,placeholder:`Пожалуйста, введите ссылку`,addressError:`Пожалуйста, введите корректную ссылку`},info:{copy:`Копировать`,edit:`Редактировать`,cancel:`Отменить ссылку`,coped:`Ссылка скопирована в буфер обмена`},menu:{tooltip:`Добавить ссылку`}}};module.exports=e;
|
package/lib/cjs/locale/sk-SK.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Potvrdiť`,cancel:`Zrušiť`,title:`Odkaz`,address:`Odkaz`,placeholder:`Zadajte URL odkazu`,addressError:`URL je neplatná!`,label:`Popisok`,labelError:`Zadajte popis odkazu`},info:{copy:`Kopírovať`,edit:`Upraviť`,cancel:`Zrušiť odkaz`,coped:`Odkaz skopírovaný do schránky`},menu:{tooltip:`Pridať odkaz`}}};module.exports=e;
|
package/lib/cjs/locale/vi-VN.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`Xác nhận`,cancel:`Hủy`,title:`Liên kết`,address:`Liên kết`,label:`Nhãn`,labelError:`Vui lòng nhập nhãn liên kết`,placeholder:`Vui lòng nhập liên kết hợp lệ`,addressError:`Vui lòng nhập liên kết hợp lệ`},info:{copy:`Sao chép`,edit:`Chỉnh sửa`,cancel:`Hủy liên kết`,coped:`Liên kết đã được sao chép vào clipboard`},menu:{tooltip:`Thêm liên kết`}}};module.exports=e;
|
package/lib/cjs/locale/zh-CN.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`确认`,cancel:`取消`,title:`链接`,address:`链接`,label:`文本`,labelError:`请输入链接文本`,placeholder:`请输入合法的链接`,addressError:`请输入合法的链接`},info:{copy:`复制`,edit:`编辑`,cancel:`取消链接`,coped:`链接已被复制到剪贴板`},menu:{tooltip:`添加链接`}}};module.exports=e;
|
package/lib/cjs/locale/zh-TW.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
const e={docLink:{edit:{confirm:`確認`,cancel:`取消`,title:`連結`,address:`連結`,label:`文本`,labelError:`请输入链接文本`,placeholder:`請輸入合法的連結`,addressError:`請輸入合法的連結`},info:{copy:`複製`,edit:`編輯`,cancel:`取消連結`,coped:`連結已複製到剪貼板`},menu:{tooltip:`新增連結`}}};module.exports=e;
|