@versa_ai/vmml-editor 1.0.47 → 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.47 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
@@ -9,7 +9,6 @@
9
9
  CLI Target: node16
10
10
  CJS Build start
11
11
  ESM Build start
12
- DTS Build start
13
12
 
14
13
   WARN  ▲ [WARNING] Using / for division outside of calc() is deprecated and will be removed in Dart Sass 2.0.0.
15
14
 
@@ -124,12 +123,13 @@ More info and automated migrator: https://sass-lang.com/d/slash-div [35
124
123
 
125
124
 
126
125
 
127
- ESM dist\index.mjs 115.63 KB
128
- ESM dist\index.mjs.map 224.90 KB
129
- ESM ⚡️ Build success in 918ms
130
- CJS dist\index.js 117.40 KB
131
- CJS dist\index.js.map 225.19 KB
132
- CJS ⚡️ Build success in 918ms
133
- DTS ⚡️ Build success in 2182ms
126
+ DTS Build start
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/README.md CHANGED
@@ -1 +1 @@
1
- # `@versa_ai/vmml-editor`
1
+ # `@versa_ai/vmml-editor`
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);
@@ -1344,6 +1344,8 @@ var EditorCanvas = react.forwardRef(
1344
1344
  window.dispatchEvent(event);
1345
1345
  };
1346
1346
  const createTextObjs = async ({ strokeW, stColor, fontAssetUrl = null, letterSpace, bgColor, textContent, textBasicInfo, textColor }) => {
1347
+ const { width, height } = vmml.template.dimension;
1348
+ const fontSize = vmmlUtils.getFontSize(width, height);
1347
1349
  let fontFamily = "sansMedium";
1348
1350
  if (fontAssetUrl) {
1349
1351
  const base64 = await loadFont(fontAssetUrl);
@@ -1354,7 +1356,9 @@ var EditorCanvas = react.forwardRef(
1354
1356
  }
1355
1357
  const lines = textContent.split("\n").filter((item) => item);
1356
1358
  const lineHeight = 22 + strokeW;
1357
- const paddingX = 7;
1359
+ const paddingX = 60 * 22 / fontSize;
1360
+ const paddingY = 50 * 22 / fontSize;
1361
+ const round = 40 * 22 / fontSize;
1358
1362
  const groupWidth = Math.max(...lines.map((l) => {
1359
1363
  let options = { fontSize: 22, fontFamily, strokeWidth: strokeW ?? 0 };
1360
1364
  if (letterSpace) options.charSpacing = letterSpace;
@@ -1366,11 +1370,11 @@ var EditorCanvas = react.forwardRef(
1366
1370
  lines.forEach((line, idx) => {
1367
1371
  const y = -groupHeight / 2 + lineHeight / 2 + idx * lineHeight;
1368
1372
  let originX = textBasicInfo.textAlign;
1369
- let left = paddingX;
1373
+ let left = -groupWidth / 2 + paddingX;
1370
1374
  if (originX === "center") {
1371
- left = groupWidth / 2;
1375
+ left = 0;
1372
1376
  } else if (originX === "right") {
1373
- left = groupWidth - paddingX;
1377
+ left = groupWidth / 2 - paddingX;
1374
1378
  }
1375
1379
  const strokeText = new fabric.fabric.Text(line || " ", {
1376
1380
  fontFamily,
@@ -1382,7 +1386,6 @@ var EditorCanvas = react.forwardRef(
1382
1386
  originY: "center",
1383
1387
  left,
1384
1388
  top: y,
1385
- textAlign: "left",
1386
1389
  objectCaching: false
1387
1390
  });
1388
1391
  const fillText = new fabric.fabric.Text(line || " ", {
@@ -1395,7 +1398,6 @@ var EditorCanvas = react.forwardRef(
1395
1398
  strokeWidth: 0,
1396
1399
  left,
1397
1400
  top: y,
1398
- textAlign: "left",
1399
1401
  objectCaching: false
1400
1402
  });
1401
1403
  if (letterSpace) {
@@ -1406,19 +1408,30 @@ var EditorCanvas = react.forwardRef(
1406
1408
  });
1407
1409
  const bgRect = new fabric.fabric.Rect({
1408
1410
  width: groupWidth,
1409
- height: groupHeight + 13,
1411
+ height: groupHeight + paddingY * 2,
1410
1412
  // padddingY: 6.5
1411
1413
  fill: bgColor,
1412
- originX: "left",
1414
+ originX: "center",
1413
1415
  originY: "center",
1414
- rx: 5,
1415
- ry: 5
1416
+ rx: round,
1417
+ ry: round
1416
1418
  });
1417
1419
  return {
1418
1420
  objects: [bgRect, ...textObjs],
1419
1421
  fontFamily
1420
1422
  };
1421
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
+ };
1422
1435
  const createTextFromClipCanvas = async (clip, fc2) => {
1423
1436
  return new Promise(async (resolve) => {
1424
1437
  const canvas = fc || fc2;
@@ -1426,10 +1439,7 @@ var EditorCanvas = react.forwardRef(
1426
1439
  const { width, height } = vmml.template.dimension;
1427
1440
  const fontSize = vmmlUtils.getFontSize(width, height);
1428
1441
  const { textContent, backgroundColor, textColor, posParam, fontAssetUrl, alignType, strokeColor, strokeWidth, letterSpacing } = clip.textClip;
1429
- const scaleX = posParam.scaleX * fontSize / 22 / widthScaleRef.current;
1430
- const scaleY = posParam.scaleY * fontSize / 22 / heightScaleRef.current;
1431
- const left = canvasSize.width * posParam.centerX;
1432
- const top = canvasSize.height * posParam.centerY;
1442
+ const { left, top, scaleX, scaleY } = getOrigin(posParam, fontSize);
1433
1443
  const bgColor = backgroundColor ? vmmlUtils.argbToRgba(backgroundColor) : "transparent";
1434
1444
  const strokeW = strokeColor && strokeWidth ? strokeWidth * 30 * 1.5 / fontSize : 0;
1435
1445
  const stColor = strokeColor ? vmmlUtils.argbToRgba(strokeColor) : "transparent";
@@ -1567,42 +1577,69 @@ var EditorCanvas = react.forwardRef(
1567
1577
  resolve(true);
1568
1578
  });
1569
1579
  };
1570
- 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 }) => {
1571
1581
  var _a;
1582
+ const { width, height } = vmml.template.dimension;
1583
+ const fontSize = vmmlUtils.getFontSize(width, height);
1572
1584
  const target = fc.getObjects().find((item) => {
1573
1585
  var _a2;
1574
1586
  return ((_a2 = item.clipData) == null ? void 0 : _a2.id) === id;
1575
1587
  });
1576
- const center = target.getCenterPoint();
1577
- 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;
1578
1589
  if (originClip && (target == null ? void 0 : target.type) === "group") {
1590
+ const center = target.getCenterPoint();
1579
1591
  const objects = target.getObjects();
1580
1592
  const strokeText = objects[1];
1581
1593
  target._objects.length = 0;
1582
- 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
+ }
1583
1606
  textObjects.forEach((obj) => {
1584
1607
  target.addWithUpdate(obj);
1585
1608
  });
1609
+ const inFrame = vmmlUtils.getFrames(originClip.inPoint, 30);
1610
+ const durationFrame = vmmlUtils.getFrames(originClip.duration, 30);
1586
1611
  target.set({
1587
- visible: true,
1612
+ visible: frame >= inFrame && frame < inFrame + durationFrame,
1588
1613
  clipData: {
1589
1614
  ...target.clipData,
1590
1615
  textBasicInfo,
1591
1616
  textColor,
1592
1617
  text: textContent,
1593
1618
  bgColor,
1619
+ fontAssetUrl,
1620
+ fontFamily,
1594
1621
  isAiError: false
1595
1622
  }
1596
1623
  });
1597
- target._calcBounds();
1598
- target._updateObjectsCoords();
1599
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
+ });
1600
1632
  originClip.textClip = {
1601
1633
  ...originClip.textClip,
1602
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,
1603
1639
  backgroundColor: bgColor,
1604
1640
  textColor,
1605
- strokeColor: ""
1641
+ fontAssetUrl,
1642
+ strokeColor: stColor
1606
1643
  };
1607
1644
  target.setCoords();
1608
1645
  fc == null ? void 0 : fc.requestRenderAll();
@@ -2478,6 +2515,8 @@ var EditorFn = ({
2478
2515
  pauseWhenBuffering = false,
2479
2516
  isBatchModify = false,
2480
2517
  textWarapCenter = false,
2518
+ backgroundColor = "#000",
2519
+ existenceBorderRadio = true,
2481
2520
  hideConfig = { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2482
2521
  // { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2483
2522
  }, ref) => {
@@ -2508,9 +2547,9 @@ var EditorFn = ({
2508
2547
  const vmmlConverterRef = react.useRef(null);
2509
2548
  const [initFcObjs, setInitFcObjs] = react.useState([]);
2510
2549
  const [editClips, setEditClips] = react.useState([]);
2511
- const [refreshEdit, setRefreshEdit] = react.useState(0);
2512
2550
  const vmmlFlag = react.useRef(false);
2513
2551
  const needPlay = react.useRef(true);
2552
+ const needFreshEdit = react.useRef(true);
2514
2553
  const setVmml = () => {
2515
2554
  const { current } = vmmlPlayerRef;
2516
2555
  if (!current) return;
@@ -2769,7 +2808,7 @@ var EditorFn = ({
2769
2808
  }
2770
2809
  }, [canvasSize, vmmlState]);
2771
2810
  react.useEffect(() => {
2772
- if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template)) {
2811
+ if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template) && needFreshEdit.current) {
2773
2812
  initCanEditClips(vmmlState.template.tracks);
2774
2813
  }
2775
2814
  }, [editableArray, vmmlState]);
@@ -2834,12 +2873,58 @@ var EditorFn = ({
2834
2873
  if (!isSame) {
2835
2874
  const currentV = cloneDeep__default.default(convertedVmml);
2836
2875
  (_e = (_d = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _d.clear) == null ? void 0 : _e.call(_d);
2876
+ needFreshEdit.current = true;
2837
2877
  setVmmlState(currentV);
2838
2878
  setDurationInFrames(vmmlUtils.getFrames(((_f = currentV == null ? void 0 : currentV.template) == null ? void 0 : _f.duration) || 1, fps));
2839
2879
  }
2840
2880
  playerCurrent.setVmml(convertedVmml, currentFrame);
2841
2881
  if (isSame) (_g = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _g.call(canvasCurrent, currentFrame);
2842
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
+ };
2843
2928
  const getCurrentFrame = () => {
2844
2929
  if (!player) return 0;
2845
2930
  return player.getCurrentFrame();
@@ -2870,7 +2955,9 @@ var EditorFn = ({
2870
2955
  // 完成按钮事件
2871
2956
  editorSeekTo,
2872
2957
  // editor的seek事件 入参:frame
2873
- updateEditor
2958
+ updateEditor,
2959
+ // 更新editor 入参:vmml, frame
2960
+ updateEditorTextClips
2874
2961
  // 更新editor 入参:vmml, frame
2875
2962
  }),
2876
2963
  [vmmlState, player]
@@ -2902,9 +2989,10 @@ var EditorFn = ({
2902
2989
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "vessel", onClick: onClickMain, children: /* @__PURE__ */ jsxRuntime.jsx(
2903
2990
  vmmlPlayer.VmmlPlayer,
2904
2991
  {
2992
+ backgroundColor,
2905
2993
  ref: vmmlPlayerRef,
2906
2994
  vmml: vmmlState,
2907
- existenceBorderRadio: true,
2995
+ existenceBorderRadio,
2908
2996
  moveToBeginningWhenEnded: true,
2909
2997
  muted: true,
2910
2998
  fps,
@@ -2940,6 +3028,7 @@ var EditorFn = ({
2940
3028
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
2941
3029
  Controls_default,
2942
3030
  {
3031
+ backgroundColor,
2943
3032
  player,
2944
3033
  vmmlRef: vmmlPlayerRef,
2945
3034
  fps,