@versa_ai/vmml-editor 1.0.48 → 1.0.50

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,5 +1,5 @@
1
1
 
2
- > @versa_ai/vmml-editor@1.0.48 build D:\code\work\vmml-player\packages\editor
2
+ > @versa_ai/vmml-editor@1.0.50 build D:\code\work\vmml-player\packages\editor
3
3
  > tsup
4
4
 
5
5
  CLI Building entry: src/index.tsx
@@ -124,12 +124,12 @@ More info and automated migrator: https://sass-lang.com/d/slash-div [35
124
124
 
125
125
 
126
126
  DTS Build start
127
- ESM dist\index.mjs 115.85 KB
128
- ESM dist\index.mjs.map 225.42 KB
129
- ESM ⚡️ Build success in 914ms
130
- CJS dist\index.js 117.63 KB
131
- CJS dist\index.js.map 225.71 KB
132
- CJS ⚡️ Build success in 915ms
133
- DTS ⚡️ Build success in 1983ms
127
+ CJS dist\index.js 121.84 KB
128
+ CJS dist\index.js.map 233.86 KB
129
+ CJS ⚡️ Build success in 878ms
130
+ ESM dist\index.mjs 119.97 KB
131
+ ESM dist\index.mjs.map 233.56 KB
132
+ ESM ⚡️ Build success in 878ms
133
+ DTS ⚡️ Build success in 2585ms
134
134
  DTS dist\index.d.ts 158.00 B
135
135
  DTS dist\index.d.mts 158.00 B
package/dist/index.js CHANGED
@@ -86,7 +86,6 @@ var css = `@charset "UTF-8";
86
86
  position: relative;
87
87
  display: flex;
88
88
  justify-content: center;
89
- border-radius: 3.2vw;
90
89
  overflow: hidden;
91
90
  }
92
91
  .editor .main .vessel {
@@ -313,7 +312,7 @@ var css = `@charset "UTF-8";
313
312
  width: 60px !important;
314
313
  }
315
314
  }
316
- /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"D:\\code\\work\\vmml-player\\packages\\editor\\src\\assets\\css","sources":["index.scss"],"names":[],"mappings":";AAAA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGJ;EACE;;AAGF;EACE;EAEA;;AAGF;EAEE;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAKJ;EACI;EACA;EAGA;EACA;;AAEJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGA;EACE;EACA;EACA;EACA;;AAGJ;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;;AAKR;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AAGJ;EACE;;AAIF;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAKN;EACE;;AAGF;EACE;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AACA;EACE;EACA;EACA;;;AAQV;EAEI;IACE;IACA;;EAEF;IACE;IACA;IACA;IACA;IACA;;EACA;IACE;;EAGA;IACE;IACA;IACA;IACA;;EAGJ;IACE;;EACA;IACE;;EACA;IACE;IACA;IACA;;EACA;IACE;IACA;IACA;;EAEF;IACE;IACA;;EAEF;IACE;IACA;IACA;;EAEF;IACE;IACA;IACA;;EAKR;IACE","sourcesContent":[".editor{\r\n  background: #000;\r\n  width: 100%;\r\n  overflow: hidden;\r\n  display: flex;\r\n  flex-direction: column;\r\n  .padding-box {\r\n    flex: 1;\r\n  }\r\n  // 顶部\r\n  &>.header{\r\n    width: 100%;\r\n    display: flex;\r\n    justify-content: space-between;\r\n    align-items: center;\r\n    height: 11.467vw;\r\n    padding-left: 4.4vw;\r\n    padding-right: 3.2vw;\r\n    box-sizing: border-box;\r\n    position: relative;\r\n    &>.close{\r\n      width: 4vw;\r\n      height: 4vw;\r\n      img{\r\n        width: 100%;\r\n        height: 100%;\r\n      }\r\n    }\r\n    &>.history-operate{\r\n      height: 7.2vw;\r\n      display: none;\r\n      align-items: center;\r\n      position: absolute;\r\n      left: 50%;\r\n      top: 50%;\r\n      transform: translate(-50%,-50%);\r\n      img{\r\n        width: 4.667vw;\r\n        height: 5.067vw;\r\n      }\r\n      &>img:last-child{\r\n        margin-left: 8vw;\r\n      }\r\n    }\r\n    &>.next-button{\r\n      width: 16vw;\r\n      height: 7.2vw;\r\n      line-height: 7.2vw;\r\n      background: #1677FF;\r\n      border-radius: 6.533vw;\r\n      text-align: center;\r\n      font-size: 3.2vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .text-style{\r\n    filter:blur(10px)\r\n  }\r\n\r\n  .editor-vessel {\r\n    width: 100%;\r\n    // padding-top: 3.2vw;\r\n    height: 100%;\r\n  }\r\n  //player与画布\r\n  .main{\r\n    // width: 81.467vw;\r\n    width: 100%;\r\n    height: 100%;\r\n    // height: 144.8vw;\r\n    margin: auto;\r\n    position: relative;\r\n    display: flex;\r\n    justify-content: center;\r\n    border-radius: 3.2vw;\r\n    overflow: hidden;\r\n    .vessel {\r\n      width: 100%;\r\n      height: 100%;\r\n    }\r\n    \r\n  }\r\n\r\n  .controls-box {\r\n      position: relative;\r\n      height: 12vw;\r\n      // position: absolute;\r\n      // bottom: 0;\r\n      width: 100%;\r\n      border-radius: 3.2vw;\r\n  }\r\n  .player-controls {\r\n    display: flex;\r\n    align-items: center;\r\n    width: 100%;\r\n    height: 100%;\r\n    padding: 0 2.13vw;\r\n    box-sizing: border-box;\r\n    background: linear-gradient( 180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.6) 100%);\r\n    .mr-16 {\r\n      margin-right: 2.13vw;\r\n    }\r\n    .player-controls-toggle {\r\n      >img {\r\n        display: block;\r\n        width: 4.8vw;\r\n        height: 4.8vw;\r\n        cursor: pointer;\r\n      }\r\n    }\r\n    .player-controls-seekbar {\r\n      flex: 1;\r\n      position: relative;\r\n      .seekbar-container {\r\n        height: 100%;\r\n        user-select: none;\r\n        touch-action: none;\r\n        position: relative;\r\n        cursor: pointer;\r\n        box-sizing: border-box;\r\n        .seekbar-background {\r\n          user-select: none;\r\n          height: 1.6vw;\r\n          width: 100%;\r\n          background-color: rgba(255, 255, 255, 0.2);\r\n          border-radius: 1vw;\r\n          .seekbar-fill {\r\n            position: absolute;\r\n            user-select: none;\r\n            width: 100%;\r\n            height: 100%;\r\n            border-radius: 1vw;\r\n          }\r\n          .seekbar-line {\r\n            height: 100%;\r\n            border-radius: 1vw;\r\n            background-color: #eeeeee;\r\n          }\r\n          .seekbar-sign {\r\n            width: 10px;\r\n            position: absolute;\r\n            top: 50%;\r\n            margin-top: -6px;\r\n          }\r\n          .seekbar-cirle {\r\n            position: absolute;\r\n            top: -0.8vw;\r\n            width: 3.2vw;\r\n            height: 3.2vw;\r\n            border-radius: 50%;\r\n            background: #eeeeee;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    .player-controls-time {\r\n      width: 10vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .play-btn {\r\n    position: absolute;\r\n    bottom: 4vw;\r\n    left: 3vw;\r\n    width: 4.8vw;\r\n    height: 4.8vw;\r\n    img {\r\n      width: 100%;\r\n      height: 100%;\r\n      display: block;\r\n    }\r\n  }\r\n  .opacity-06 {\r\n    opacity: 0.6;\r\n  }\r\n\r\n  //底部\r\n  .footer{\r\n    display: flex;\r\n    justify-content: center;\r\n    box-sizing: border-box;\r\n    width: 100%;\r\n    padding: 0 20.333vw 10.933vw;\r\n    &>div{\r\n      width: 30%;\r\n      margin: 0 15%;\r\n      img{\r\n        width: 6.4vw;\r\n        height: 6.4vw;\r\n        display: block;\r\n        margin: auto;\r\n      }\r\n      p{\r\n        font-size: 3.2vw;\r\n        color: #fff;\r\n        margin-top: 1.867vw;\r\n        text-align: center;\r\n      }\r\n    }\r\n  }\r\n\r\n  .not-show-text{\r\n    justify-content: space-around;\r\n  }\r\n\r\n  .editor-video-menu {\r\n    position: fixed;\r\n    // height: 38.13vh;\r\n    height: 0;\r\n    width: 100%;\r\n    background: #1E1E1E;\r\n    bottom: 0;\r\n    border-radius: 8px 8px 0 0;\r\n    transition: all 0.5s ease-in-out;  \r\n    &.active {\r\n      height: 38.13vh;\r\n    }\r\n    .editor-video-menu-header {\r\n      display: flex;\r\n      padding: 1.6vw 1.6vw 0;\r\n      height: 4.81vh;\r\n      line-height: 4.81vh;\r\n      color: rgba(255, 255, 255, 0.40);\r\n      overflow: hidden;\r\n      overflow-x: auto;\r\n      &::-webkit-scrollbar {\r\n        display: none; /* 隐藏滚动条 */\r\n      }\r\n      >div {\r\n        margin: 0 3.2vw;\r\n        white-space: nowrap;\r\n      }\r\n      .active {\r\n        color: #FFFFFF;\r\n      }\r\n    }\r\n    .editor-video-menu-itmes {\r\n      padding: 0 3.33vw;\r\n      max-height: calc(100% - 4.81vh - 1.6vw);\r\n      display: grid;\r\n      grid-template-columns: repeat(4, 1fr);\r\n      row-gap: 3.2vw;\r\n      column-gap: 2.6vw;\r\n      overflow: auto;\r\n      >div {\r\n        width: 21.33vw;\r\n        height: 21.33vw;\r\n        background-color: #1e1e1e;\r\n        img {\r\n          width: 100%;\r\n          height: 100%;\r\n          object-fit: contain;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n\r\n@media screen and (min-width: 750px) {\r\n  .editor {\r\n    .controls-box {\r\n      height: 20% !important;\r\n      border-radius: 3.2vw;\r\n    }\r\n    .player-controls {\r\n      display: flex;\r\n      align-items: center;\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0 1%;\r\n      .mr-16 {\r\n        margin-right: 2.13vw;\r\n      }\r\n      .player-controls-toggle {\r\n        >img {\r\n          display: block;\r\n          width: 30px !important;\r\n          height: 30px !important;\r\n          cursor: pointer;\r\n        }\r\n      }\r\n      .player-controls-seekbar {\r\n        flex: 1;\r\n        .seekbar-container {\r\n          height: 2px !important;\r\n          .seekbar-background {\r\n            height: 8px !important;\r\n            width: 100%;\r\n            border-radius: 1vw;\r\n            .seekbar-fill {\r\n              width: 100%;\r\n              height: 8px !important;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-line {\r\n              height: 100%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-sign {\r\n              width: 10px;\r\n              top: 50%;\r\n              margin-top: -6px;\r\n            }\r\n            .seekbar-cirle {\r\n              top: -5px !important;\r\n              width: 20px !important;\r\n              height: 20px !important;\r\n            }\r\n          }\r\n        }\r\n      }\r\n      .player-controls-time {\r\n        width: 60px !important;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n"]} */`;
315
+ /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"D:\\code\\work\\vmml-player\\packages\\editor\\src\\assets\\css","sources":["index.scss"],"names":[],"mappings":";AAAA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGJ;EACE;;AAGF;EACE;EAEA;;AAGF;EAEE;EACA;EAEA;EACA;EACA;EACA;EAEA;;AACA;EACE;EACA;;AAKJ;EACI;EACA;EAGA;EACA;;AAEJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAGA;EACE;EACA;EACA;EACA;;AAGJ;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;;AAKR;EACE;EACA;;AAGJ;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AAGJ;EACE;;AAIF;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AACA;EACE;EACA;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;;AAKN;EACE;;AAGF;EACE;EAEA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;;AAEF;EACE;;AAGJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;;AACA;EACE;EACA;EACA;;;AAQV;EAEI;IACE;IACA;;EAEF;IACE;IACA;IACA;IACA;IACA;;EACA;IACE;;EAGA;IACE;IACA;IACA;IACA;;EAGJ;IACE;;EACA;IACE;;EACA;IACE;IACA;IACA;;EACA;IACE;IACA;IACA;;EAEF;IACE;IACA;;EAEF;IACE;IACA;IACA;;EAEF;IACE;IACA;IACA;;EAKR;IACE","sourcesContent":[".editor{\r\n  background: #000;\r\n  width: 100%;\r\n  overflow: hidden;\r\n  display: flex;\r\n  flex-direction: column;\r\n  .padding-box {\r\n    flex: 1;\r\n  }\r\n  // 顶部\r\n  &>.header{\r\n    width: 100%;\r\n    display: flex;\r\n    justify-content: space-between;\r\n    align-items: center;\r\n    height: 11.467vw;\r\n    padding-left: 4.4vw;\r\n    padding-right: 3.2vw;\r\n    box-sizing: border-box;\r\n    position: relative;\r\n    &>.close{\r\n      width: 4vw;\r\n      height: 4vw;\r\n      img{\r\n        width: 100%;\r\n        height: 100%;\r\n      }\r\n    }\r\n    &>.history-operate{\r\n      height: 7.2vw;\r\n      display: none;\r\n      align-items: center;\r\n      position: absolute;\r\n      left: 50%;\r\n      top: 50%;\r\n      transform: translate(-50%,-50%);\r\n      img{\r\n        width: 4.667vw;\r\n        height: 5.067vw;\r\n      }\r\n      &>img:last-child{\r\n        margin-left: 8vw;\r\n      }\r\n    }\r\n    &>.next-button{\r\n      width: 16vw;\r\n      height: 7.2vw;\r\n      line-height: 7.2vw;\r\n      background: #1677FF;\r\n      border-radius: 6.533vw;\r\n      text-align: center;\r\n      font-size: 3.2vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .text-style{\r\n    filter:blur(10px)\r\n  }\r\n\r\n  .editor-vessel {\r\n    width: 100%;\r\n    // padding-top: 3.2vw;\r\n    height: 100%;\r\n  }\r\n  //player与画布\r\n  .main{\r\n    // width: 81.467vw;\r\n    width: 100%;\r\n    height: 100%;\r\n    // height: 144.8vw;\r\n    margin: auto;\r\n    position: relative;\r\n    display: flex;\r\n    justify-content: center;\r\n    // border-radius: 3.2vw;\r\n    overflow: hidden;\r\n    .vessel {\r\n      width: 100%;\r\n      height: 100%;\r\n    }\r\n    \r\n  }\r\n\r\n  .controls-box {\r\n      position: relative;\r\n      height: 12vw;\r\n      // position: absolute;\r\n      // bottom: 0;\r\n      width: 100%;\r\n      border-radius: 3.2vw;\r\n  }\r\n  .player-controls {\r\n    display: flex;\r\n    align-items: center;\r\n    width: 100%;\r\n    height: 100%;\r\n    padding: 0 2.13vw;\r\n    box-sizing: border-box;\r\n    background: linear-gradient( 180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.6) 100%);\r\n    .mr-16 {\r\n      margin-right: 2.13vw;\r\n    }\r\n    .player-controls-toggle {\r\n      >img {\r\n        display: block;\r\n        width: 4.8vw;\r\n        height: 4.8vw;\r\n        cursor: pointer;\r\n      }\r\n    }\r\n    .player-controls-seekbar {\r\n      flex: 1;\r\n      position: relative;\r\n      .seekbar-container {\r\n        height: 100%;\r\n        user-select: none;\r\n        touch-action: none;\r\n        position: relative;\r\n        cursor: pointer;\r\n        box-sizing: border-box;\r\n        .seekbar-background {\r\n          user-select: none;\r\n          height: 1.6vw;\r\n          width: 100%;\r\n          background-color: rgba(255, 255, 255, 0.2);\r\n          border-radius: 1vw;\r\n          .seekbar-fill {\r\n            position: absolute;\r\n            user-select: none;\r\n            width: 100%;\r\n            height: 100%;\r\n            border-radius: 1vw;\r\n          }\r\n          .seekbar-line {\r\n            height: 100%;\r\n            border-radius: 1vw;\r\n            background-color: #eeeeee;\r\n          }\r\n          .seekbar-sign {\r\n            width: 10px;\r\n            position: absolute;\r\n            top: 50%;\r\n            margin-top: -6px;\r\n          }\r\n          .seekbar-cirle {\r\n            position: absolute;\r\n            top: -0.8vw;\r\n            width: 3.2vw;\r\n            height: 3.2vw;\r\n            border-radius: 50%;\r\n            background: #eeeeee;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    .player-controls-time {\r\n      width: 10vw;\r\n      color: #fff;\r\n    }\r\n  }\r\n  .play-btn {\r\n    position: absolute;\r\n    bottom: 4vw;\r\n    left: 3vw;\r\n    width: 4.8vw;\r\n    height: 4.8vw;\r\n    img {\r\n      width: 100%;\r\n      height: 100%;\r\n      display: block;\r\n    }\r\n  }\r\n  .opacity-06 {\r\n    opacity: 0.6;\r\n  }\r\n\r\n  //底部\r\n  .footer{\r\n    display: flex;\r\n    justify-content: center;\r\n    box-sizing: border-box;\r\n    width: 100%;\r\n    padding: 0 20.333vw 10.933vw;\r\n    &>div{\r\n      width: 30%;\r\n      margin: 0 15%;\r\n      img{\r\n        width: 6.4vw;\r\n        height: 6.4vw;\r\n        display: block;\r\n        margin: auto;\r\n      }\r\n      p{\r\n        font-size: 3.2vw;\r\n        color: #fff;\r\n        margin-top: 1.867vw;\r\n        text-align: center;\r\n      }\r\n    }\r\n  }\r\n\r\n  .not-show-text{\r\n    justify-content: space-around;\r\n  }\r\n\r\n  .editor-video-menu {\r\n    position: fixed;\r\n    // height: 38.13vh;\r\n    height: 0;\r\n    width: 100%;\r\n    background: #1E1E1E;\r\n    bottom: 0;\r\n    border-radius: 8px 8px 0 0;\r\n    transition: all 0.5s ease-in-out;  \r\n    &.active {\r\n      height: 38.13vh;\r\n    }\r\n    .editor-video-menu-header {\r\n      display: flex;\r\n      padding: 1.6vw 1.6vw 0;\r\n      height: 4.81vh;\r\n      line-height: 4.81vh;\r\n      color: rgba(255, 255, 255, 0.40);\r\n      overflow: hidden;\r\n      overflow-x: auto;\r\n      &::-webkit-scrollbar {\r\n        display: none; /* 隐藏滚动条 */\r\n      }\r\n      >div {\r\n        margin: 0 3.2vw;\r\n        white-space: nowrap;\r\n      }\r\n      .active {\r\n        color: #FFFFFF;\r\n      }\r\n    }\r\n    .editor-video-menu-itmes {\r\n      padding: 0 3.33vw;\r\n      max-height: calc(100% - 4.81vh - 1.6vw);\r\n      display: grid;\r\n      grid-template-columns: repeat(4, 1fr);\r\n      row-gap: 3.2vw;\r\n      column-gap: 2.6vw;\r\n      overflow: auto;\r\n      >div {\r\n        width: 21.33vw;\r\n        height: 21.33vw;\r\n        background-color: #1e1e1e;\r\n        img {\r\n          width: 100%;\r\n          height: 100%;\r\n          object-fit: contain;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n\r\n@media screen and (min-width: 750px) {\r\n  .editor {\r\n    .controls-box {\r\n      height: 20% !important;\r\n      border-radius: 3.2vw;\r\n    }\r\n    .player-controls {\r\n      display: flex;\r\n      align-items: center;\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0 1%;\r\n      .mr-16 {\r\n        margin-right: 2.13vw;\r\n      }\r\n      .player-controls-toggle {\r\n        >img {\r\n          display: block;\r\n          width: 30px !important;\r\n          height: 30px !important;\r\n          cursor: pointer;\r\n        }\r\n      }\r\n      .player-controls-seekbar {\r\n        flex: 1;\r\n        .seekbar-container {\r\n          height: 2px !important;\r\n          .seekbar-background {\r\n            height: 8px !important;\r\n            width: 100%;\r\n            border-radius: 1vw;\r\n            .seekbar-fill {\r\n              width: 100%;\r\n              height: 8px !important;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-line {\r\n              height: 100%;\r\n              border-radius: 1vw;\r\n            }\r\n            .seekbar-sign {\r\n              width: 10px;\r\n              top: 50%;\r\n              margin-top: -6px;\r\n            }\r\n            .seekbar-cirle {\r\n              top: -5px !important;\r\n              width: 20px !important;\r\n              height: 20px !important;\r\n            }\r\n          }\r\n        }\r\n      }\r\n      .player-controls-time {\r\n        width: 60px !important;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n"]} */`;
317
316
  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
318
317
 
319
318
  // src/utils/const.ts
@@ -428,7 +427,7 @@ var SeekBar = ({ player, vmmlRef, frame, durationInFrames, intoEdit, setDragStat
428
427
  ] }) });
429
428
  };
430
429
  var SeekBar_default = SeekBar;
431
- var Controls = ({ player, vmmlRef, frame, fps, durationInFrames, intoEdit, isPlaying, setDragState, onControlsClick, signList }) => {
430
+ var Controls = ({ player, vmmlRef, frame, fps, durationInFrames, intoEdit, isPlaying, setDragState, onControlsClick, signList, backgroundColor }) => {
432
431
  const onClickToggle = (e) => {
433
432
  if (isPlaying) {
434
433
  intoEdit();
@@ -436,7 +435,7 @@ var Controls = ({ player, vmmlRef, frame, fps, durationInFrames, intoEdit, isPla
436
435
  onControlsClick();
437
436
  }
438
437
  };
439
- return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "player-controls", children: [
438
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "player-controls", style: { backgroundColor }, children: [
440
439
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "player-controls-toggle mr-16 opacity-06", onClick: onClickToggle, children: isPlaying ? /* @__PURE__ */ jsxRuntime.jsx("img", { src: pauseIcon, alt: "\u6682\u505C" }) : /* @__PURE__ */ jsxRuntime.jsx("img", { src: playIcon, alt: "\u64AD\u653E" }) }),
441
440
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "player-controls-time opacity-06", children: vmmlUtils.formatTime(frame / fps) }),
442
441
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "player-controls-seekbar mr-16", children: /* @__PURE__ */ jsxRuntime.jsx(SeekBar_default, { player, vmmlRef, frame, durationInFrames, intoEdit, setDragState, signList }) }),
@@ -1056,6 +1055,7 @@ var EditorCanvas = react.forwardRef(
1056
1055
  const canvas = new fabric.fabric.Canvas("canvas", {
1057
1056
  width: canvasSize.width,
1058
1057
  height: canvasSize.height,
1058
+ uniScaleKey: "",
1059
1059
  selection: false
1060
1060
  // 画布框选
1061
1061
  });
@@ -1240,6 +1240,7 @@ var EditorCanvas = react.forwardRef(
1240
1240
  }
1241
1241
  };
1242
1242
  const createEditObjes = async (canvas, time) => {
1243
+ setCanvasScale(vmml);
1243
1244
  const promises = editClips.map((clip) => {
1244
1245
  if (clip.videoClip) {
1245
1246
  return createImageFromClip(clip);
@@ -1370,11 +1371,11 @@ var EditorCanvas = react.forwardRef(
1370
1371
  lines.forEach((line, idx) => {
1371
1372
  const y = -groupHeight / 2 + lineHeight / 2 + idx * lineHeight;
1372
1373
  let originX = textBasicInfo.textAlign;
1373
- let left = paddingX;
1374
+ let left = -groupWidth / 2 + paddingX;
1374
1375
  if (originX === "center") {
1375
- left = groupWidth / 2;
1376
+ left = 0;
1376
1377
  } else if (originX === "right") {
1377
- left = groupWidth - paddingX;
1378
+ left = groupWidth / 2 - paddingX;
1378
1379
  }
1379
1380
  const strokeText = new fabric.fabric.Text(line || " ", {
1380
1381
  fontFamily,
@@ -1386,7 +1387,6 @@ var EditorCanvas = react.forwardRef(
1386
1387
  originY: "center",
1387
1388
  left,
1388
1389
  top: y,
1389
- textAlign: "left",
1390
1390
  objectCaching: false
1391
1391
  });
1392
1392
  const fillText = new fabric.fabric.Text(line || " ", {
@@ -1399,7 +1399,6 @@ var EditorCanvas = react.forwardRef(
1399
1399
  strokeWidth: 0,
1400
1400
  left,
1401
1401
  top: y,
1402
- textAlign: "left",
1403
1402
  objectCaching: false
1404
1403
  });
1405
1404
  if (letterSpace) {
@@ -1413,7 +1412,7 @@ var EditorCanvas = react.forwardRef(
1413
1412
  height: groupHeight + paddingY * 2,
1414
1413
  // padddingY: 6.5
1415
1414
  fill: bgColor,
1416
- originX: "left",
1415
+ originX: "center",
1417
1416
  originY: "center",
1418
1417
  rx: round,
1419
1418
  ry: round
@@ -1423,6 +1422,17 @@ var EditorCanvas = react.forwardRef(
1423
1422
  fontFamily
1424
1423
  };
1425
1424
  };
1425
+ const getOrigin = (posParam, fontSize) => {
1426
+ const scaleX = posParam.scaleX * fontSize / 22 / widthScaleRef.current;
1427
+ const scaleY = posParam.scaleY * fontSize / 22 / heightScaleRef.current;
1428
+ const left = canvasSize.width * posParam.centerX;
1429
+ const top = canvasSize.height * posParam.centerY;
1430
+ return { scaleX, scaleY, top, left };
1431
+ };
1432
+ const setCanvasScale = (vmml2) => {
1433
+ heightScaleRef.current = vmml2.template.dimension.height / canvasSize.height;
1434
+ widthScaleRef.current = vmml2.template.dimension.width / canvasSize.width;
1435
+ };
1426
1436
  const createTextFromClipCanvas = async (clip, fc2) => {
1427
1437
  return new Promise(async (resolve) => {
1428
1438
  const canvas = fc || fc2;
@@ -1430,10 +1440,7 @@ var EditorCanvas = react.forwardRef(
1430
1440
  const { width, height } = vmml.template.dimension;
1431
1441
  const fontSize = vmmlUtils.getFontSize(width, height);
1432
1442
  const { textContent, backgroundColor, textColor, posParam, fontAssetUrl, alignType, strokeColor, strokeWidth, letterSpacing } = clip.textClip;
1433
- const scaleX = posParam.scaleX * fontSize / 22 / widthScaleRef.current;
1434
- const scaleY = posParam.scaleY * fontSize / 22 / heightScaleRef.current;
1435
- const left = canvasSize.width * posParam.centerX;
1436
- const top = canvasSize.height * posParam.centerY;
1443
+ const { left, top, scaleX, scaleY } = getOrigin(posParam, fontSize);
1437
1444
  const bgColor = backgroundColor ? vmmlUtils.argbToRgba(backgroundColor) : "transparent";
1438
1445
  const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : 0;
1439
1446
  const stColor = strokeColor ? vmmlUtils.argbToRgba(strokeColor) : "transparent";
@@ -1571,42 +1578,69 @@ var EditorCanvas = react.forwardRef(
1571
1578
  resolve(true);
1572
1579
  });
1573
1580
  };
1574
- const updateText = async ({ id, textContent, bgColor, textColor, textBasicInfo, fontAssetUrl }) => {
1581
+ const updateText = async ({ id, textContent, bgColor, textColor, strokeColor, letterSpacing, strokeWidth, textBasicInfo, fontAssetUrl, posParam = null, alignType }) => {
1575
1582
  var _a;
1583
+ const { width, height } = vmml.template.dimension;
1584
+ const fontSize = vmmlUtils.getFontSize(width, height);
1576
1585
  const target = fc.getObjects().find((item) => {
1577
1586
  var _a2;
1578
1587
  return ((_a2 = item.clipData) == null ? void 0 : _a2.id) === id;
1579
1588
  });
1580
- const center = target.getCenterPoint();
1581
- const originClip = (_a = target.clipData) == null ? void 0 : _a.originClip;
1589
+ const originClip = ((_a = target == null ? void 0 : target.clipData) == null ? void 0 : _a.originClip) ?? null;
1582
1590
  if (originClip && (target == null ? void 0 : target.type) === "group") {
1591
+ const center = target.getCenterPoint();
1583
1592
  const objects = target.getObjects();
1584
1593
  const strokeText = objects[1];
1585
1594
  target._objects.length = 0;
1586
- const { objects: textObjects } = await createTextObjs({ strokeW: strokeText.strokeWidth, stColor: "", fontAssetUrl, letterSpace: strokeText.charSpacing, bgColor, textContent, textBasicInfo, textColor });
1595
+ const stColor = strokeColor ?? "";
1596
+ const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : strokeText.strokeWidth;
1597
+ const letterSpace = letterSpacing ? letterSpacing * 22 / fontSize * 45 : strokeText.charSpacing;
1598
+ const { objects: textObjects, fontFamily } = await createTextObjs({ strokeW: strokeW ?? 0, stColor, fontAssetUrl, letterSpace: letterSpace ?? 0, bgColor, textContent, textBasicInfo, textColor });
1599
+ let top = target.top;
1600
+ let left = target.left;
1601
+ let scaleX = target.scaleX;
1602
+ let scaleY = target.scaleY;
1603
+ if (posParam) {
1604
+ const obj = getOrigin(posParam, fontSize);
1605
+ ({ left, top, scaleX, scaleY } = obj);
1606
+ }
1587
1607
  textObjects.forEach((obj) => {
1588
1608
  target.addWithUpdate(obj);
1589
1609
  });
1610
+ const inFrame = vmmlUtils.getFrames(originClip.inPoint, 30);
1611
+ const durationFrame = vmmlUtils.getFrames(originClip.duration, 30);
1590
1612
  target.set({
1591
- visible: true,
1613
+ visible: frame >= inFrame && frame < inFrame + durationFrame,
1592
1614
  clipData: {
1593
1615
  ...target.clipData,
1594
1616
  textBasicInfo,
1595
1617
  textColor,
1596
1618
  text: textContent,
1597
1619
  bgColor,
1620
+ fontAssetUrl,
1621
+ fontFamily,
1598
1622
  isAiError: false
1599
1623
  }
1600
1624
  });
1601
- target._calcBounds();
1602
- target._updateObjectsCoords();
1603
1625
  target.setPositionByOrigin(center, "center", "center");
1626
+ target.set({
1627
+ visible: frame >= inFrame && frame < inFrame + durationFrame,
1628
+ top,
1629
+ left,
1630
+ scaleY,
1631
+ scaleX
1632
+ });
1604
1633
  originClip.textClip = {
1605
1634
  ...originClip.textClip,
1606
1635
  textContent,
1636
+ letterSpacing: letterSpacing ?? 0,
1637
+ strokeWidth: strokeWidth ?? 0,
1638
+ alignType: alignType ?? (originClip == null ? void 0 : originClip.alignType) ?? 0,
1639
+ posParam: posParam ?? originClip.posParam,
1607
1640
  backgroundColor: bgColor,
1608
1641
  textColor,
1609
- strokeColor: ""
1642
+ fontAssetUrl,
1643
+ strokeColor: stColor
1610
1644
  };
1611
1645
  target.setCoords();
1612
1646
  fc == null ? void 0 : fc.requestRenderAll();
@@ -2482,6 +2516,8 @@ var EditorFn = ({
2482
2516
  pauseWhenBuffering = false,
2483
2517
  isBatchModify = false,
2484
2518
  textWarapCenter = false,
2519
+ backgroundColor = "#000",
2520
+ existenceBorderRadio = true,
2485
2521
  hideConfig = { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2486
2522
  // { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2487
2523
  }, ref) => {
@@ -2512,9 +2548,9 @@ var EditorFn = ({
2512
2548
  const vmmlConverterRef = react.useRef(null);
2513
2549
  const [initFcObjs, setInitFcObjs] = react.useState([]);
2514
2550
  const [editClips, setEditClips] = react.useState([]);
2515
- const [refreshEdit, setRefreshEdit] = react.useState(0);
2516
2551
  const vmmlFlag = react.useRef(false);
2517
2552
  const needPlay = react.useRef(true);
2553
+ const needFreshEdit = react.useRef(true);
2518
2554
  const setVmml = () => {
2519
2555
  const { current } = vmmlPlayerRef;
2520
2556
  if (!current) return;
@@ -2773,7 +2809,7 @@ var EditorFn = ({
2773
2809
  }
2774
2810
  }, [canvasSize, vmmlState]);
2775
2811
  react.useEffect(() => {
2776
- if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template)) {
2812
+ if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template) && needFreshEdit.current) {
2777
2813
  initCanEditClips(vmmlState.template.tracks);
2778
2814
  }
2779
2815
  }, [editableArray, vmmlState]);
@@ -2838,12 +2874,58 @@ var EditorFn = ({
2838
2874
  if (!isSame) {
2839
2875
  const currentV = cloneDeep__default.default(convertedVmml);
2840
2876
  (_e = (_d = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _d.clear) == null ? void 0 : _e.call(_d);
2877
+ needFreshEdit.current = true;
2841
2878
  setVmmlState(currentV);
2842
2879
  setDurationInFrames(vmmlUtils.getFrames(((_f = currentV == null ? void 0 : currentV.template) == null ? void 0 : _f.duration) || 1, fps));
2843
2880
  }
2844
2881
  playerCurrent.setVmml(convertedVmml, currentFrame);
2845
2882
  if (isSame) (_g = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _g.call(canvasCurrent, currentFrame);
2846
2883
  };
2884
+ const updateEditorTextClips = (v, checkFrame) => {
2885
+ var _a2, _b, _c, _d, _e, _f;
2886
+ const { current: playerCurrent } = vmmlPlayerRef;
2887
+ const { current: canvasCurrent } = canvasRef;
2888
+ if (!playerCurrent) return;
2889
+ const playing = ((_b = (_a2 = playerCurrent == null ? void 0 : playerCurrent.playerRef) == null ? void 0 : _a2.isPlaying) == null ? void 0 : _b.call(_a2)) ?? false;
2890
+ if (!playing) needPlay.current = false;
2891
+ const currentFrame = checkFrame ?? (((_c = player == null ? void 0 : player.getCurrentFrame) == null ? void 0 : _c.call(player)) ?? frame ?? pauseFrame);
2892
+ setFrame(currentFrame);
2893
+ const convertedVmml = v;
2894
+ const currentV = cloneDeep__default.default(convertedVmml);
2895
+ needFreshEdit.current = false;
2896
+ setVmmlState(currentV);
2897
+ const tracks = (_e = (_d = currentV == null ? void 0 : currentV.template) == null ? void 0 : _d.tracks) == null ? void 0 : _e.filter((track) => track.type === 2);
2898
+ tracks == null ? void 0 : tracks.forEach((track) => {
2899
+ var _a3;
2900
+ (_a3 = track == null ? void 0 : track.clips) == null ? void 0 : _a3.forEach((clip) => {
2901
+ const { textClip = null } = clip;
2902
+ if (textClip) {
2903
+ const { textContent, backgroundColor: backgroundColor2, textColor, fontAssetUrl, alignType, letterSpacing, strokeWidth, strokeColor, posParam } = textClip;
2904
+ const textFill = vmmlUtils.argbToRgba(textColor || "#ffffffff");
2905
+ const textBasicInfo = {
2906
+ isBack: backgroundColor2 ? true : false,
2907
+ colorValue: textFill,
2908
+ colorName: "custom",
2909
+ textAlign: alignType === 1 ? "center" : alignType === 2 ? "right" : "left"
2910
+ };
2911
+ canvasCurrent == null ? void 0 : canvasCurrent.updateText({
2912
+ id: clip.id,
2913
+ textContent,
2914
+ letterSpacing,
2915
+ strokeWidth,
2916
+ strokeColor: vmmlUtils.argbToRgba(strokeColor),
2917
+ bgColor: vmmlUtils.argbToRgba(backgroundColor2),
2918
+ textColor: vmmlUtils.argbToRgba(textColor),
2919
+ fontAssetUrl,
2920
+ textBasicInfo,
2921
+ posParam
2922
+ });
2923
+ }
2924
+ });
2925
+ });
2926
+ playerCurrent.setVmml(convertedVmml, currentFrame);
2927
+ (_f = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _f.call(canvasCurrent, currentFrame);
2928
+ };
2847
2929
  const getCurrentFrame = () => {
2848
2930
  if (!player) return 0;
2849
2931
  return player.getCurrentFrame();
@@ -2874,7 +2956,9 @@ var EditorFn = ({
2874
2956
  // 完成按钮事件
2875
2957
  editorSeekTo,
2876
2958
  // editor的seek事件 入参:frame
2877
- updateEditor
2959
+ updateEditor,
2960
+ // 更新editor 入参:vmml, frame
2961
+ updateEditorTextClips
2878
2962
  // 更新editor 入参:vmml, frame
2879
2963
  }),
2880
2964
  [vmmlState, player]
@@ -2906,9 +2990,10 @@ var EditorFn = ({
2906
2990
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "vessel", onClick: onClickMain, children: /* @__PURE__ */ jsxRuntime.jsx(
2907
2991
  vmmlPlayer.VmmlPlayer,
2908
2992
  {
2993
+ backgroundColor,
2909
2994
  ref: vmmlPlayerRef,
2910
2995
  vmml: vmmlState,
2911
- existenceBorderRadio: true,
2996
+ existenceBorderRadio,
2912
2997
  moveToBeginningWhenEnded: true,
2913
2998
  muted: true,
2914
2999
  fps,
@@ -2944,6 +3029,7 @@ var EditorFn = ({
2944
3029
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
2945
3030
  Controls_default,
2946
3031
  {
3032
+ backgroundColor,
2947
3033
  player,
2948
3034
  vmmlRef: vmmlPlayerRef,
2949
3035
  fps,