@versa_ai/vmml-editor 1.0.48 → 1.0.49

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.49 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.82 KB
128
+ CJS dist\index.js.map 233.81 KB
129
+ CJS ⚡️ Build success in 666ms
130
+ ESM dist\index.mjs 119.95 KB
131
+ ESM dist\index.mjs.map 233.51 KB
132
+ ESM ⚡️ Build success in 666ms
133
+ DTS ⚡️ Build success in 1560ms
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 }) }),
@@ -1240,6 +1239,7 @@ var EditorCanvas = react.forwardRef(
1240
1239
  }
1241
1240
  };
1242
1241
  const createEditObjes = async (canvas, time) => {
1242
+ setCanvasScale(vmml);
1243
1243
  const promises = editClips.map((clip) => {
1244
1244
  if (clip.videoClip) {
1245
1245
  return createImageFromClip(clip);
@@ -1370,11 +1370,11 @@ var EditorCanvas = react.forwardRef(
1370
1370
  lines.forEach((line, idx) => {
1371
1371
  const y = -groupHeight / 2 + lineHeight / 2 + idx * lineHeight;
1372
1372
  let originX = textBasicInfo.textAlign;
1373
- let left = paddingX;
1373
+ let left = -groupWidth / 2 + paddingX;
1374
1374
  if (originX === "center") {
1375
- left = groupWidth / 2;
1375
+ left = 0;
1376
1376
  } else if (originX === "right") {
1377
- left = groupWidth - paddingX;
1377
+ left = groupWidth / 2 - paddingX;
1378
1378
  }
1379
1379
  const strokeText = new fabric.fabric.Text(line || " ", {
1380
1380
  fontFamily,
@@ -1386,7 +1386,6 @@ var EditorCanvas = react.forwardRef(
1386
1386
  originY: "center",
1387
1387
  left,
1388
1388
  top: y,
1389
- textAlign: "left",
1390
1389
  objectCaching: false
1391
1390
  });
1392
1391
  const fillText = new fabric.fabric.Text(line || " ", {
@@ -1399,7 +1398,6 @@ var EditorCanvas = react.forwardRef(
1399
1398
  strokeWidth: 0,
1400
1399
  left,
1401
1400
  top: y,
1402
- textAlign: "left",
1403
1401
  objectCaching: false
1404
1402
  });
1405
1403
  if (letterSpace) {
@@ -1413,7 +1411,7 @@ var EditorCanvas = react.forwardRef(
1413
1411
  height: groupHeight + paddingY * 2,
1414
1412
  // padddingY: 6.5
1415
1413
  fill: bgColor,
1416
- originX: "left",
1414
+ originX: "center",
1417
1415
  originY: "center",
1418
1416
  rx: round,
1419
1417
  ry: round
@@ -1423,6 +1421,17 @@ var EditorCanvas = react.forwardRef(
1423
1421
  fontFamily
1424
1422
  };
1425
1423
  };
1424
+ const getOrigin = (posParam, fontSize) => {
1425
+ const scaleX = posParam.scaleX * fontSize / 22 / widthScaleRef.current;
1426
+ const scaleY = posParam.scaleY * fontSize / 22 / heightScaleRef.current;
1427
+ const left = canvasSize.width * posParam.centerX;
1428
+ const top = canvasSize.height * posParam.centerY;
1429
+ return { scaleX, scaleY, top, left };
1430
+ };
1431
+ const setCanvasScale = (vmml2) => {
1432
+ heightScaleRef.current = vmml2.template.dimension.height / canvasSize.height;
1433
+ widthScaleRef.current = vmml2.template.dimension.width / canvasSize.width;
1434
+ };
1426
1435
  const createTextFromClipCanvas = async (clip, fc2) => {
1427
1436
  return new Promise(async (resolve) => {
1428
1437
  const canvas = fc || fc2;
@@ -1430,10 +1439,7 @@ var EditorCanvas = react.forwardRef(
1430
1439
  const { width, height } = vmml.template.dimension;
1431
1440
  const fontSize = vmmlUtils.getFontSize(width, height);
1432
1441
  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;
1442
+ const { left, top, scaleX, scaleY } = getOrigin(posParam, fontSize);
1437
1443
  const bgColor = backgroundColor ? vmmlUtils.argbToRgba(backgroundColor) : "transparent";
1438
1444
  const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : 0;
1439
1445
  const stColor = strokeColor ? vmmlUtils.argbToRgba(strokeColor) : "transparent";
@@ -1571,42 +1577,69 @@ var EditorCanvas = react.forwardRef(
1571
1577
  resolve(true);
1572
1578
  });
1573
1579
  };
1574
- const updateText = async ({ id, textContent, bgColor, textColor, textBasicInfo, fontAssetUrl }) => {
1580
+ const updateText = async ({ id, textContent, bgColor, textColor, strokeColor, letterSpacing, strokeWidth, textBasicInfo, fontAssetUrl, posParam = null, alignType }) => {
1575
1581
  var _a;
1582
+ const { width, height } = vmml.template.dimension;
1583
+ const fontSize = vmmlUtils.getFontSize(width, height);
1576
1584
  const target = fc.getObjects().find((item) => {
1577
1585
  var _a2;
1578
1586
  return ((_a2 = item.clipData) == null ? void 0 : _a2.id) === id;
1579
1587
  });
1580
- const center = target.getCenterPoint();
1581
- const originClip = (_a = target.clipData) == null ? void 0 : _a.originClip;
1588
+ const originClip = ((_a = target == null ? void 0 : target.clipData) == null ? void 0 : _a.originClip) ?? null;
1582
1589
  if (originClip && (target == null ? void 0 : target.type) === "group") {
1590
+ const center = target.getCenterPoint();
1583
1591
  const objects = target.getObjects();
1584
1592
  const strokeText = objects[1];
1585
1593
  target._objects.length = 0;
1586
- const { objects: textObjects } = await createTextObjs({ strokeW: strokeText.strokeWidth, stColor: "", fontAssetUrl, letterSpace: strokeText.charSpacing, bgColor, textContent, textBasicInfo, textColor });
1594
+ const stColor = strokeColor ?? "";
1595
+ const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : strokeText.strokeWidth;
1596
+ const letterSpace = letterSpacing ? letterSpacing * 22 / fontSize * 45 : strokeText.charSpacing;
1597
+ const { objects: textObjects, fontFamily } = await createTextObjs({ strokeW: strokeW ?? 0, stColor, fontAssetUrl, letterSpace: letterSpace ?? 0, bgColor, textContent, textBasicInfo, textColor });
1598
+ let top = target.top;
1599
+ let left = target.left;
1600
+ let scaleX = target.scaleX;
1601
+ let scaleY = target.scaleY;
1602
+ if (posParam) {
1603
+ const obj = getOrigin(posParam, fontSize);
1604
+ ({ left, top, scaleX, scaleY } = obj);
1605
+ }
1587
1606
  textObjects.forEach((obj) => {
1588
1607
  target.addWithUpdate(obj);
1589
1608
  });
1609
+ const inFrame = vmmlUtils.getFrames(originClip.inPoint, 30);
1610
+ const durationFrame = vmmlUtils.getFrames(originClip.duration, 30);
1590
1611
  target.set({
1591
- visible: true,
1612
+ visible: frame >= inFrame && frame < inFrame + durationFrame,
1592
1613
  clipData: {
1593
1614
  ...target.clipData,
1594
1615
  textBasicInfo,
1595
1616
  textColor,
1596
1617
  text: textContent,
1597
1618
  bgColor,
1619
+ fontAssetUrl,
1620
+ fontFamily,
1598
1621
  isAiError: false
1599
1622
  }
1600
1623
  });
1601
- target._calcBounds();
1602
- target._updateObjectsCoords();
1603
1624
  target.setPositionByOrigin(center, "center", "center");
1625
+ target.set({
1626
+ visible: frame >= inFrame && frame < inFrame + durationFrame,
1627
+ top,
1628
+ left,
1629
+ scaleY,
1630
+ scaleX
1631
+ });
1604
1632
  originClip.textClip = {
1605
1633
  ...originClip.textClip,
1606
1634
  textContent,
1635
+ letterSpacing: letterSpacing ?? 0,
1636
+ strokeWidth: strokeWidth ?? 0,
1637
+ alignType: alignType ?? (originClip == null ? void 0 : originClip.alignType) ?? 0,
1638
+ posParam: posParam ?? originClip.posParam,
1607
1639
  backgroundColor: bgColor,
1608
1640
  textColor,
1609
- strokeColor: ""
1641
+ fontAssetUrl,
1642
+ strokeColor: stColor
1610
1643
  };
1611
1644
  target.setCoords();
1612
1645
  fc == null ? void 0 : fc.requestRenderAll();
@@ -2482,6 +2515,8 @@ var EditorFn = ({
2482
2515
  pauseWhenBuffering = false,
2483
2516
  isBatchModify = false,
2484
2517
  textWarapCenter = false,
2518
+ backgroundColor = "#000",
2519
+ existenceBorderRadio = true,
2485
2520
  hideConfig = { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2486
2521
  // { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2487
2522
  }, ref) => {
@@ -2512,9 +2547,9 @@ var EditorFn = ({
2512
2547
  const vmmlConverterRef = react.useRef(null);
2513
2548
  const [initFcObjs, setInitFcObjs] = react.useState([]);
2514
2549
  const [editClips, setEditClips] = react.useState([]);
2515
- const [refreshEdit, setRefreshEdit] = react.useState(0);
2516
2550
  const vmmlFlag = react.useRef(false);
2517
2551
  const needPlay = react.useRef(true);
2552
+ const needFreshEdit = react.useRef(true);
2518
2553
  const setVmml = () => {
2519
2554
  const { current } = vmmlPlayerRef;
2520
2555
  if (!current) return;
@@ -2773,7 +2808,7 @@ var EditorFn = ({
2773
2808
  }
2774
2809
  }, [canvasSize, vmmlState]);
2775
2810
  react.useEffect(() => {
2776
- if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template)) {
2811
+ if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template) && needFreshEdit.current) {
2777
2812
  initCanEditClips(vmmlState.template.tracks);
2778
2813
  }
2779
2814
  }, [editableArray, vmmlState]);
@@ -2838,12 +2873,58 @@ var EditorFn = ({
2838
2873
  if (!isSame) {
2839
2874
  const currentV = cloneDeep__default.default(convertedVmml);
2840
2875
  (_e = (_d = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _d.clear) == null ? void 0 : _e.call(_d);
2876
+ needFreshEdit.current = true;
2841
2877
  setVmmlState(currentV);
2842
2878
  setDurationInFrames(vmmlUtils.getFrames(((_f = currentV == null ? void 0 : currentV.template) == null ? void 0 : _f.duration) || 1, fps));
2843
2879
  }
2844
2880
  playerCurrent.setVmml(convertedVmml, currentFrame);
2845
2881
  if (isSame) (_g = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _g.call(canvasCurrent, currentFrame);
2846
2882
  };
2883
+ const updateEditorTextClips = (v, checkFrame) => {
2884
+ var _a2, _b, _c, _d, _e, _f;
2885
+ const { current: playerCurrent } = vmmlPlayerRef;
2886
+ const { current: canvasCurrent } = canvasRef;
2887
+ if (!playerCurrent) return;
2888
+ const playing = ((_b = (_a2 = playerCurrent == null ? void 0 : playerCurrent.playerRef) == null ? void 0 : _a2.isPlaying) == null ? void 0 : _b.call(_a2)) ?? false;
2889
+ if (!playing) needPlay.current = false;
2890
+ const currentFrame = checkFrame ?? (((_c = player == null ? void 0 : player.getCurrentFrame) == null ? void 0 : _c.call(player)) ?? frame ?? pauseFrame);
2891
+ setFrame(currentFrame);
2892
+ const convertedVmml = v;
2893
+ const currentV = cloneDeep__default.default(convertedVmml);
2894
+ needFreshEdit.current = false;
2895
+ setVmmlState(currentV);
2896
+ const tracks = (_e = (_d = currentV == null ? void 0 : currentV.template) == null ? void 0 : _d.tracks) == null ? void 0 : _e.filter((track) => track.type === 2);
2897
+ tracks == null ? void 0 : tracks.forEach((track) => {
2898
+ var _a3;
2899
+ (_a3 = track == null ? void 0 : track.clips) == null ? void 0 : _a3.forEach((clip) => {
2900
+ const { textClip = null } = clip;
2901
+ if (textClip) {
2902
+ const { textContent, backgroundColor: backgroundColor2, textColor, fontAssetUrl, alignType, letterSpacing, strokeWidth, strokeColor, posParam } = textClip;
2903
+ const textFill = vmmlUtils.argbToRgba(textColor || "#ffffffff");
2904
+ const textBasicInfo = {
2905
+ isBack: backgroundColor2 ? true : false,
2906
+ colorValue: textFill,
2907
+ colorName: "custom",
2908
+ textAlign: alignType === 1 ? "center" : alignType === 2 ? "right" : "left"
2909
+ };
2910
+ canvasCurrent == null ? void 0 : canvasCurrent.updateText({
2911
+ id: clip.id,
2912
+ textContent,
2913
+ letterSpacing,
2914
+ strokeWidth,
2915
+ strokeColor: vmmlUtils.argbToRgba(strokeColor),
2916
+ bgColor: vmmlUtils.argbToRgba(backgroundColor2),
2917
+ textColor: vmmlUtils.argbToRgba(textColor),
2918
+ fontAssetUrl,
2919
+ textBasicInfo,
2920
+ posParam
2921
+ });
2922
+ }
2923
+ });
2924
+ });
2925
+ playerCurrent.setVmml(convertedVmml, currentFrame);
2926
+ (_f = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _f.call(canvasCurrent, currentFrame);
2927
+ };
2847
2928
  const getCurrentFrame = () => {
2848
2929
  if (!player) return 0;
2849
2930
  return player.getCurrentFrame();
@@ -2874,7 +2955,9 @@ var EditorFn = ({
2874
2955
  // 完成按钮事件
2875
2956
  editorSeekTo,
2876
2957
  // editor的seek事件 入参:frame
2877
- updateEditor
2958
+ updateEditor,
2959
+ // 更新editor 入参:vmml, frame
2960
+ updateEditorTextClips
2878
2961
  // 更新editor 入参:vmml, frame
2879
2962
  }),
2880
2963
  [vmmlState, player]
@@ -2906,9 +2989,10 @@ var EditorFn = ({
2906
2989
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "vessel", onClick: onClickMain, children: /* @__PURE__ */ jsxRuntime.jsx(
2907
2990
  vmmlPlayer.VmmlPlayer,
2908
2991
  {
2992
+ backgroundColor,
2909
2993
  ref: vmmlPlayerRef,
2910
2994
  vmml: vmmlState,
2911
- existenceBorderRadio: true,
2995
+ existenceBorderRadio,
2912
2996
  moveToBeginningWhenEnded: true,
2913
2997
  muted: true,
2914
2998
  fps,
@@ -2944,6 +3028,7 @@ var EditorFn = ({
2944
3028
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
2945
3029
  Controls_default,
2946
3030
  {
3031
+ backgroundColor,
2947
3032
  player,
2948
3033
  vmmlRef: vmmlPlayerRef,
2949
3034
  fps,