@versa_ai/vmml-editor 1.0.14 → 1.0.16

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.14 build D:\code\work\vmml-player\packages\editor
2
+ > @versa_ai/vmml-editor@1.0.16 build D:\code\work\vmml-player\packages\editor
3
3
  > tsup
4
4
 
5
5
  CLI Building entry: src/index.tsx
@@ -9,6 +9,7 @@
9
9
  CLI Target: node16
10
10
  CJS Build start
11
11
  ESM Build start
12
+ DTS Build start
12
13
 
13
14
   WARN  ▲ [WARNING] Using / for division outside of calc() is deprecated and will be removed in Dart Sass 2.0.0.
14
15
 
@@ -123,13 +124,12 @@ More info and automated migrator: https://sass-lang.com/d/slash-div [35
123
124
 
124
125
 
125
126
 
126
- DTS Build start
127
- ESM dist\index.mjs 107.63 KB
128
- ESM dist\index.mjs.map 206.39 KB
129
- ESM ⚡️ Build success in 805ms
130
- CJS dist\index.js 109.17 KB
131
- CJS dist\index.js.map 206.67 KB
132
- CJS ⚡️ Build success in 805ms
133
- DTS ⚡️ Build success in 2430ms
127
+ ESM dist\index.mjs 111.04 KB
128
+ ESM dist\index.mjs.map 213.31 KB
129
+ ESM ⚡️ Build success in 1139ms
130
+ CJS dist\index.js 112.66 KB
131
+ CJS dist\index.js.map 213.61 KB
132
+ CJS ⚡️ Build success in 1141ms
133
+ DTS ⚡️ Build success in 2678ms
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
@@ -307,10 +307,10 @@ var css = `@charset "UTF-8";
307
307
  height: 20px !important;
308
308
  }
309
309
  .editor .player-controls .player-controls-time {
310
- width: 6vw !important;
310
+ width: 60px !important;
311
311
  }
312
312
  }
313
- /*# 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;;AAEF;EACE;EACA;EACA;EACA;EACA;;AAEF;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;;AAKJ;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    .controls-box {\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  //底部\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: 80%;\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: 6vw !important;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n"]} */`;
313
+ /*# 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;;AAEF;EACE;EACA;EACA;EACA;EACA;;AAEF;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;;AAKJ;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    .controls-box {\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  //底部\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: 80%;\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"]} */`;
314
314
  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
315
315
 
316
316
  // src/utils/const.ts
@@ -577,7 +577,6 @@ var VmmlConverter = class {
577
577
  }
578
578
  //更新位置
579
579
  setPosParam(fObj) {
580
- console.log("setPosParam fObj", fObj);
581
580
  const {
582
581
  clipData: { type },
583
582
  centerPoint,
@@ -1001,9 +1000,11 @@ function usePeekControl(canvas, hideConfig) {
1001
1000
  return canvas;
1002
1001
  }
1003
1002
  var EditorCanvas = react.forwardRef(
1004
- ({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, onVideoChange, isBatchModify, hideConfig }, ref) => {
1003
+ ({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig }, ref) => {
1005
1004
  const [fc, setFc] = react.useState(null);
1006
1005
  const [history, setHistory] = react.useState(null);
1006
+ const [canvasReady, setCanvasReady] = react.useState(false);
1007
+ const editRenderTime = react.useRef(0);
1007
1008
  const waitFcTasks = react.useRef([]);
1008
1009
  const vmmlConverterRef = react.useRef(null);
1009
1010
  const heightScaleRef = react.useRef(1);
@@ -1023,6 +1024,7 @@ var EditorCanvas = react.forwardRef(
1023
1024
  setFc(canvas);
1024
1025
  initCanvasEvent(canvas);
1025
1026
  usePeekControl(canvas, hideConfig);
1027
+ setCanvasReady(true);
1026
1028
  };
1027
1029
  const createFcObjs = (canvas) => {
1028
1030
  const ns = Math.floor(frame / 30 * 1e6);
@@ -1194,9 +1196,42 @@ var EditorCanvas = react.forwardRef(
1194
1196
  waitFcTasks.current.push(updateImage.bind(void 0, id, base64));
1195
1197
  }
1196
1198
  };
1199
+ const createEditObjes = async (canvas, time) => {
1200
+ const allObjects = canvas.getObjects();
1201
+ const toRemove = [];
1202
+ allObjects.forEach((obj) => {
1203
+ var _a;
1204
+ if ((_a = obj == null ? void 0 : obj.clipData) == null ? void 0 : _a.originClip) {
1205
+ toRemove.push(obj);
1206
+ }
1207
+ });
1208
+ toRemove.forEach((obj) => canvas.remove(obj));
1209
+ const promises = editClips.map((clip) => {
1210
+ if (clip.videoClip) {
1211
+ return createImageFromClip(clip);
1212
+ }
1213
+ if (clip.textClip && !clip.audioClip) {
1214
+ return createTextFromClip(clip);
1215
+ }
1216
+ });
1217
+ const res = await Promise.allSettled(promises);
1218
+ const objects = [];
1219
+ res.forEach((item) => {
1220
+ if (item.status === "fulfilled" && item.value) {
1221
+ objects.push(item.value);
1222
+ }
1223
+ });
1224
+ if (editRenderTime.current === time) {
1225
+ canvas.add(...objects).renderAll();
1226
+ }
1227
+ };
1197
1228
  const createImageFromClip = (clip, fc2) => {
1198
- const canvas = fc || fc2;
1199
- if (canvas && canvasSize.width) {
1229
+ return new Promise((resolve) => {
1230
+ const canvas = fc || fc2;
1231
+ if (!canvas || !canvasSize.width) {
1232
+ resolve(null);
1233
+ return;
1234
+ }
1200
1235
  const url = /video/g.test(clip.videoClip.mimeType) ? "" : clip.videoClip.sourceUrl;
1201
1236
  fabric.fabric.Image.fromURL(url, (img) => {
1202
1237
  const { dimension, posParam } = clip.videoClip;
@@ -1230,16 +1265,14 @@ var EditorCanvas = react.forwardRef(
1230
1265
  },
1231
1266
  visible: frame >= inFrame && frame < inFrame + durationFrame
1232
1267
  });
1233
- canvas.add(img);
1234
1268
  img.on("modified", () => {
1235
1269
  const fObj = convertToJSON(img);
1236
1270
  fObj.src = "";
1237
1271
  vmmlConverterRef.current.updateClip(fObj);
1238
1272
  });
1273
+ resolve(img);
1239
1274
  });
1240
- } else {
1241
- waitFcTasks.current.push(createImageFromClip.bind(void 0, clip));
1242
- }
1275
+ });
1243
1276
  };
1244
1277
  const handleRedo = () => {
1245
1278
  history.redo();
@@ -1247,9 +1280,41 @@ var EditorCanvas = react.forwardRef(
1247
1280
  const handleUndo = () => {
1248
1281
  history.undo();
1249
1282
  };
1283
+ const onBatchModify = (fObj, canvas) => {
1284
+ var _a;
1285
+ if (!canvas) return;
1286
+ const textObjects = canvas.getObjects().filter((item) => {
1287
+ var _a2;
1288
+ return ((_a2 = item == null ? void 0 : item.clipData) == null ? void 0 : _a2.type) === "\u6587\u5B57";
1289
+ });
1290
+ const { left, top, scaleX, scaleY, angle } = fObj;
1291
+ textObjects.forEach((textObj) => {
1292
+ textObj.set({
1293
+ left,
1294
+ top,
1295
+ scaleX,
1296
+ scaleY,
1297
+ angle
1298
+ });
1299
+ textObj.setCoords();
1300
+ const updatedFObj = convertToJSON(textObj);
1301
+ vmmlConverterRef.current.updateClip(updatedFObj);
1302
+ });
1303
+ canvas.renderAll();
1304
+ const event = new CustomEvent("editor-vmml-batch-change", {
1305
+ detail: {
1306
+ vmml: ((_a = vmmlConverterRef.current) == null ? void 0 : _a.vmml) ?? null
1307
+ }
1308
+ });
1309
+ window.dispatchEvent(event);
1310
+ };
1250
1311
  const createTextFromClip = async (clip, fc2) => {
1251
- const canvas = fc || fc2;
1252
- if (canvas) {
1312
+ return new Promise(async (resolve) => {
1313
+ const canvas = fc || fc2;
1314
+ if (!canvas) {
1315
+ resolve(null);
1316
+ return;
1317
+ }
1253
1318
  const { width, height } = vmml.template.dimension;
1254
1319
  const fontSize = vmmlUtils.getFontSize(width, height);
1255
1320
  const { textContent, backgroundColor, textColor, posParam, fontAssetUrl, alignType } = clip.textClip;
@@ -1287,7 +1352,7 @@ var EditorCanvas = react.forwardRef(
1287
1352
  originX: "center",
1288
1353
  originY: "center",
1289
1354
  clipData: {
1290
- id: uuid.v4(),
1355
+ id: clip.id,
1291
1356
  inPoint: clip.inPoint,
1292
1357
  inFrame: vmmlUtils.getFrames(clip.inPoint, 30),
1293
1358
  type: "\u6587\u5B57",
@@ -1313,13 +1378,15 @@ var EditorCanvas = react.forwardRef(
1313
1378
  if (fObj.clipData.isAiError) {
1314
1379
  fObj.clipData.textColor = "rgba(0, 0, 0, 0)";
1315
1380
  }
1316
- vmmlConverterRef.current.updateClip(fObj);
1381
+ if (isBatchModify) {
1382
+ onBatchModify(fObj, canvas);
1383
+ } else {
1384
+ vmmlConverterRef.current.updateClip(fObj);
1385
+ }
1317
1386
  });
1318
- canvas.add(imgData).renderAll();
1387
+ resolve(imgData);
1319
1388
  });
1320
- } else {
1321
- waitFcTasks.current.push(createTextFromClip.bind(void 0, clip));
1322
- }
1389
+ });
1323
1390
  };
1324
1391
  const getFontFamilyName = (url) => {
1325
1392
  const filename = url.split("/").pop() || "";
@@ -1498,6 +1565,12 @@ var EditorCanvas = react.forwardRef(
1498
1565
  vmmlConverterRef.current = new VmmlConverter_default({ vmml, canvasSize });
1499
1566
  }
1500
1567
  }, [canvasSize, vmml]);
1568
+ react.useEffect(() => {
1569
+ if (editClips.length && canvasReady && fc) {
1570
+ editRenderTime.current = Date.now();
1571
+ createEditObjes(fc, editRenderTime.current);
1572
+ }
1573
+ }, [editClips, canvasReady]);
1501
1574
  react.useEffect(() => {
1502
1575
  if (fc) {
1503
1576
  const historyClass2 = new HistoryClass(fc);
@@ -2288,7 +2361,7 @@ var VideoMenu = ({ createImage, videoMenus, menuState }) => {
2288
2361
  var VideoMenu_default = VideoMenu;
2289
2362
  var historyClass = new HistoryClass();
2290
2363
  var EditorFn = ({
2291
- vmml,
2364
+ vmml: propVmml,
2292
2365
  pauseFrame = 0,
2293
2366
  maxText = 10,
2294
2367
  maxVideo = 5,
@@ -2305,7 +2378,7 @@ var EditorFn = ({
2305
2378
  // { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2306
2379
  }, ref) => {
2307
2380
  var _a;
2308
- vmml = vmmlUtils.convertVmmlTextScaleByForbidden(vmml);
2381
+ const [vmmlState, setVmmlState] = react.useState(() => vmmlUtils.convertVmmlTextScaleByForbidden(propVmml));
2309
2382
  const textMenuRef = react.useRef(null);
2310
2383
  const vmmlPlayerRef = react.useRef();
2311
2384
  const canvasRef = react.useRef();
@@ -2317,7 +2390,7 @@ var EditorFn = ({
2317
2390
  const [isPlaying, setIsPlaying] = react.useState(false);
2318
2391
  const [showCanvas, setShowCanvas] = react.useState(false);
2319
2392
  const [filterIds, setFilterIds] = react.useState([]);
2320
- const [durationInFrames, setDurationInFrames] = react.useState(vmmlUtils.getFrames(((_a = vmml == null ? void 0 : vmml.template) == null ? void 0 : _a.duration) || 1, fps));
2393
+ const [durationInFrames, setDurationInFrames] = react.useState(vmmlUtils.getFrames(((_a = vmmlState == null ? void 0 : vmmlState.template) == null ? void 0 : _a.duration) || 1, fps));
2321
2394
  const [previewState, setPreviewState] = react.useState(true);
2322
2395
  const [menuState, setMenuState] = react.useState("");
2323
2396
  const [canvasSize, setCanvasSize] = react.useState({ width: 0, height: 0, top: 0 });
@@ -2330,15 +2403,17 @@ var EditorFn = ({
2330
2403
  const [dragState, setDragState] = react.useState(0);
2331
2404
  const vmmlConverterRef = react.useRef(null);
2332
2405
  const [initFcObjs, setInitFcObjs] = react.useState([]);
2406
+ const [editClips, setEditClips] = react.useState([]);
2407
+ const [refreshEdit, setRefreshEdit] = react.useState(0);
2333
2408
  const vmmlFlag = react.useRef(false);
2334
2409
  const needPlay = react.useRef(true);
2335
2410
  const setVmml = () => {
2336
2411
  const { current } = vmmlPlayerRef;
2337
2412
  if (!current) return;
2338
2413
  if (!once.current) {
2339
- current.setVmml(vmml, pauseFrame);
2414
+ current.setVmml(vmmlState, pauseFrame);
2340
2415
  } else {
2341
- current.setVmml(vmml, frame);
2416
+ current.setVmml(vmmlState, frame);
2342
2417
  }
2343
2418
  };
2344
2419
  const onPlayerReady = () => {
@@ -2512,18 +2587,9 @@ var EditorFn = ({
2512
2587
  setBuffering(false);
2513
2588
  };
2514
2589
  const initCanEditClips = (tracks = []) => {
2515
- if (editableArray.length) {
2590
+ if (editableArray.length && tracks.length) {
2516
2591
  const list = findEditClips(tracks);
2517
- if (list.length) {
2518
- const { current } = canvasRef;
2519
- list.forEach((clip) => {
2520
- if (clip.videoClip) {
2521
- current.createImageFromClip(clip);
2522
- } else {
2523
- current.createTextFromClip(clip);
2524
- }
2525
- });
2526
- }
2592
+ setEditClips(list);
2527
2593
  }
2528
2594
  };
2529
2595
  const findEditClips = (tracks = []) => {
@@ -2551,7 +2617,7 @@ var EditorFn = ({
2551
2617
  };
2552
2618
  const getVmml = () => {
2553
2619
  try {
2554
- const tracks = vmml.template.tracks.filter((item) => item.editorType === "\u6587\u5B57");
2620
+ const tracks = vmmlState.template.tracks.filter((item) => item.editorType === "\u6587\u5B57");
2555
2621
  tracks.forEach((track) => {
2556
2622
  track.clips.forEach((clip) => {
2557
2623
  clip.fObj.src = "";
@@ -2560,7 +2626,7 @@ var EditorFn = ({
2560
2626
  } catch {
2561
2627
  console.log("\u51FA\u9519\u4E86");
2562
2628
  }
2563
- return vmml;
2629
+ return vmmlState;
2564
2630
  };
2565
2631
  const getPlayer = () => {
2566
2632
  return player;
@@ -2577,18 +2643,33 @@ var EditorFn = ({
2577
2643
  }
2578
2644
  }, [previewState]);
2579
2645
  react.useEffect(() => {
2580
- if (canvasSize.width && canvasSize.height && !vmmlConverterRef.current && vmml) {
2581
- vmmlConverterRef.current = new VmmlConverter_default({ vmml, canvasSize });
2646
+ if (canvasSize.width && canvasSize.height && vmmlState) {
2647
+ if (!vmmlConverterRef.current) {
2648
+ vmmlConverterRef.current = new VmmlConverter_default({ vmml: vmmlState, canvasSize });
2649
+ } else {
2650
+ vmmlConverterRef.current.vmml = vmmlState;
2651
+ }
2582
2652
  }
2583
- if (canvasSize.width) {
2584
- initCanEditClips(vmml.template.tracks);
2653
+ }, [canvasSize, vmmlState]);
2654
+ react.useEffect(() => {
2655
+ if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template)) {
2656
+ initCanEditClips(vmmlState.template.tracks);
2585
2657
  }
2586
- }, [canvasSize, vmml]);
2658
+ }, [editableArray, refreshEdit]);
2659
+ react.useEffect(() => {
2660
+ var _a2;
2661
+ if (propVmml) {
2662
+ const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(propVmml);
2663
+ setVmmlState(convertedVmml);
2664
+ setDurationInFrames(vmmlUtils.getFrames(((_a2 = propVmml == null ? void 0 : propVmml.template) == null ? void 0 : _a2.duration) || 1, fps));
2665
+ setRefreshEdit(Date.now());
2666
+ }
2667
+ }, [propVmml]);
2587
2668
  react.useEffect(() => {
2588
- if (vmml) {
2589
- initFcObjects(vmml.template.tracks);
2669
+ if (vmmlState) {
2670
+ initFcObjects(vmmlState.template.tracks);
2590
2671
  }
2591
- }, [vmml]);
2672
+ }, [vmmlState]);
2592
2673
  react.useEffect(() => {
2593
2674
  if (player) {
2594
2675
  const parent = player.getContainerNode();
@@ -2623,7 +2704,7 @@ var EditorFn = ({
2623
2704
  if (dragState === 2) {
2624
2705
  needPlay.current = false;
2625
2706
  const { current } = vmmlPlayerRef;
2626
- current.setVmml(vmml, frame, false);
2707
+ current.setVmml(vmmlState, frame, false);
2627
2708
  setShowCanvas(false);
2628
2709
  }
2629
2710
  if (dragState === 3 || dragState === 4) {
@@ -2631,6 +2712,20 @@ var EditorFn = ({
2631
2712
  setPreviewState(false);
2632
2713
  }
2633
2714
  }, [dragState]);
2715
+ const updateVmml = (v) => {
2716
+ var _a2;
2717
+ const { current: playerCurrent } = vmmlPlayerRef;
2718
+ const { current: canvasCurrent } = canvasRef;
2719
+ if (!playerCurrent) return;
2720
+ const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(v);
2721
+ setVmmlState(convertedVmml);
2722
+ setDurationInFrames(vmmlUtils.getFrames(((_a2 = v == null ? void 0 : v.template) == null ? void 0 : _a2.duration) || 1, fps));
2723
+ playerCurrent.setVmml(convertedVmml, pauseFrame);
2724
+ setRefreshEdit(Date.now());
2725
+ if (canvasCurrent) {
2726
+ canvasCurrent.checkObjectInPoint(pauseFrame);
2727
+ }
2728
+ };
2634
2729
  react.useImperativeHandle(
2635
2730
  ref,
2636
2731
  () => ({
@@ -2639,9 +2734,10 @@ var EditorFn = ({
2639
2734
  getVmml,
2640
2735
  getPlayer,
2641
2736
  texteditClose,
2642
- textFinish
2737
+ textFinish,
2738
+ updateVmml
2643
2739
  }),
2644
- [vmml, player]
2740
+ [vmmlState, player]
2645
2741
  );
2646
2742
  const texteditClose = () => {
2647
2743
  if (textMenuRef) {
@@ -2671,7 +2767,7 @@ var EditorFn = ({
2671
2767
  vmmlPlayer.VmmlPlayer,
2672
2768
  {
2673
2769
  ref: vmmlPlayerRef,
2674
- vmml,
2770
+ vmml: vmmlState,
2675
2771
  existenceBorderRadio: true,
2676
2772
  moveToBeginningWhenEnded: true,
2677
2773
  muted: true,
@@ -2692,9 +2788,10 @@ var EditorFn = ({
2692
2788
  enterPreview,
2693
2789
  intoTextEdit,
2694
2790
  frame,
2695
- vmml,
2791
+ vmml: vmmlState,
2696
2792
  dragState,
2697
2793
  initFcObjs,
2794
+ editClips,
2698
2795
  onVideoChange,
2699
2796
  isBatchModify,
2700
2797
  hideConfig