@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.
- package/.turbo/turbo-build.log +9 -9
- package/dist/index.js +146 -49
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +146 -49
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/assets/css/index.scss +1 -1
- package/src/components/EditorCanvas.tsx +176 -99
- package/src/index.tsx +74 -46
- package/src/utils/VmmlConverter.ts +0 -1
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
> @versa_ai/vmml-editor@1.0.
|
|
2
|
+
> @versa_ai/vmml-editor@1.0.16 build D:\code\work\vmml-player\packages\editor
|
|
3
3
|
> tsup
|
|
4
4
|
|
|
5
5
|
[34mCLI[39m Building entry: src/index.tsx
|
|
@@ -9,6 +9,7 @@
|
|
|
9
9
|
[34mCLI[39m Target: node16
|
|
10
10
|
[34mCJS[39m Build start
|
|
11
11
|
[34mESM[39m Build start
|
|
12
|
+
[34mDTS[39m Build start
|
|
12
13
|
|
|
13
14
|
[43m[30m WARN [39m[49m [33m▲ [43;33m[[43;30mWARNING[43;33m][0m [1mUsing / 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[0m [1m[35
|
|
|
123
124
|
|
|
124
125
|
|
|
125
126
|
|
|
126
|
-
[
|
|
127
|
-
[32mESM[39m [1mdist\index.mjs
|
|
128
|
-
[32mESM[39m
|
|
129
|
-
[
|
|
130
|
-
[32mCJS[39m [1mdist\index.js
|
|
131
|
-
[32mCJS[39m
|
|
132
|
-
[
|
|
133
|
-
[32mDTS[39m ⚡️ Build success in 2430ms
|
|
127
|
+
[32mESM[39m [1mdist\index.mjs [22m[32m111.04 KB[39m
|
|
128
|
+
[32mESM[39m [1mdist\index.mjs.map [22m[32m213.31 KB[39m
|
|
129
|
+
[32mESM[39m ⚡️ Build success in 1139ms
|
|
130
|
+
[32mCJS[39m [1mdist\index.js [22m[32m112.66 KB[39m
|
|
131
|
+
[32mCJS[39m [1mdist\index.js.map [22m[32m213.61 KB[39m
|
|
132
|
+
[32mCJS[39m ⚡️ Build success in 1141ms
|
|
133
|
+
[32mDTS[39m ⚡️ Build success in 2678ms
|
|
134
134
|
[32mDTS[39m [1mdist\index.d.ts [22m[32m158.00 B[39m
|
|
135
135
|
[32mDTS[39m [1mdist\index.d.mts [22m[32m158.00 B[39m
|
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:
|
|
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
|
-
|
|
1199
|
-
|
|
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
|
-
}
|
|
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
|
-
|
|
1252
|
-
|
|
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:
|
|
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
|
-
|
|
1381
|
+
if (isBatchModify) {
|
|
1382
|
+
onBatchModify(fObj, canvas);
|
|
1383
|
+
} else {
|
|
1384
|
+
vmmlConverterRef.current.updateClip(fObj);
|
|
1385
|
+
}
|
|
1317
1386
|
});
|
|
1318
|
-
|
|
1387
|
+
resolve(imgData);
|
|
1319
1388
|
});
|
|
1320
|
-
}
|
|
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
|
-
|
|
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 =
|
|
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(
|
|
2414
|
+
current.setVmml(vmmlState, pauseFrame);
|
|
2340
2415
|
} else {
|
|
2341
|
-
current.setVmml(
|
|
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
|
-
|
|
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 =
|
|
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
|
|
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 &&
|
|
2581
|
-
vmmlConverterRef.current
|
|
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
|
-
|
|
2584
|
-
|
|
2653
|
+
}, [canvasSize, vmmlState]);
|
|
2654
|
+
react.useEffect(() => {
|
|
2655
|
+
if (editableArray.length && (vmmlState == null ? void 0 : vmmlState.template)) {
|
|
2656
|
+
initCanEditClips(vmmlState.template.tracks);
|
|
2585
2657
|
}
|
|
2586
|
-
}, [
|
|
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 (
|
|
2589
|
-
initFcObjects(
|
|
2669
|
+
if (vmmlState) {
|
|
2670
|
+
initFcObjects(vmmlState.template.tracks);
|
|
2590
2671
|
}
|
|
2591
|
-
}, [
|
|
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(
|
|
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
|
-
[
|
|
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
|