@versa_ai/vmml-editor 1.0.29 → 1.0.31

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.29 build D:\code\work\vmml-player\packages\editor
2
+ > @versa_ai/vmml-editor@1.0.31 build D:\code\work\vmml-player\packages\editor
3
3
  > tsup
4
4
 
5
5
  CLI Building entry: src/index.tsx
@@ -124,12 +124,12 @@ More info and automated migrator: https://sass-lang.com/d/slash-div [35
124
124
 
125
125
 
126
126
  DTS Build start
127
- ESM dist\index.mjs 114.18 KB
128
- ESM dist\index.mjs.map 219.48 KB
129
- ESM ⚡️ Build success in 693ms
130
- CJS dist\index.js 115.82 KB
131
- CJS dist\index.js.map 219.77 KB
132
- CJS ⚡️ Build success in 694ms
133
- DTS ⚡️ Build success in 1988ms
127
+ ESM dist\index.mjs 114.31 KB
128
+ ESM dist\index.mjs.map 220.87 KB
129
+ ESM ⚡️ Build success in 852ms
130
+ CJS dist\index.js 115.92 KB
131
+ CJS dist\index.js.map 221.16 KB
132
+ CJS ⚡️ Build success in 853ms
133
+ DTS ⚡️ Build success in 7106ms
134
134
  DTS dist\index.d.ts 158.00 B
135
135
  DTS dist\index.d.mts 158.00 B
Binary file
package/dist/index.js CHANGED
@@ -89,14 +89,13 @@ var css = `@charset "UTF-8";
89
89
  width: 100%;
90
90
  height: 100%;
91
91
  }
92
- .editor .main .controls-box {
92
+ .editor .controls-box {
93
+ position: relative;
93
94
  height: 12vw;
94
- position: absolute;
95
- bottom: 0;
96
95
  width: 100%;
97
96
  border-radius: 3.2vw;
98
97
  }
99
- .editor .main .player-controls {
98
+ .editor .player-controls {
100
99
  display: flex;
101
100
  align-items: center;
102
101
  width: 100%;
@@ -105,20 +104,20 @@ var css = `@charset "UTF-8";
105
104
  box-sizing: border-box;
106
105
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
107
106
  }
108
- .editor .main .player-controls .mr-16 {
107
+ .editor .player-controls .mr-16 {
109
108
  margin-right: 2.13vw;
110
109
  }
111
- .editor .main .player-controls .player-controls-toggle > img {
110
+ .editor .player-controls .player-controls-toggle > img {
112
111
  display: block;
113
112
  width: 4.8vw;
114
113
  height: 4.8vw;
115
114
  cursor: pointer;
116
115
  }
117
- .editor .main .player-controls .player-controls-seekbar {
116
+ .editor .player-controls .player-controls-seekbar {
118
117
  flex: 1;
119
118
  position: relative;
120
119
  }
121
- .editor .main .player-controls .player-controls-seekbar .seekbar-container {
120
+ .editor .player-controls .player-controls-seekbar .seekbar-container {
122
121
  height: 100%;
123
122
  user-select: none;
124
123
  touch-action: none;
@@ -126,32 +125,32 @@ var css = `@charset "UTF-8";
126
125
  cursor: pointer;
127
126
  box-sizing: border-box;
128
127
  }
129
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background {
128
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background {
130
129
  user-select: none;
131
130
  height: 1.6vw;
132
131
  width: 100%;
133
132
  background-color: rgba(255, 255, 255, 0.2);
134
133
  border-radius: 1vw;
135
134
  }
136
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-fill {
135
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-fill {
137
136
  position: absolute;
138
137
  user-select: none;
139
138
  width: 100%;
140
139
  height: 100%;
141
140
  border-radius: 1vw;
142
141
  }
143
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-line {
142
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-line {
144
143
  height: 100%;
145
144
  border-radius: 1vw;
146
145
  background-color: #eeeeee;
147
146
  }
148
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-sign {
147
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-sign {
149
148
  width: 10px;
150
149
  position: absolute;
151
150
  top: 50%;
152
151
  margin-top: -6px;
153
152
  }
154
- .editor .main .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-cirle {
153
+ .editor .player-controls .player-controls-seekbar .seekbar-container .seekbar-background .seekbar-cirle {
155
154
  position: absolute;
156
155
  top: -0.8vw;
157
156
  width: 3.2vw;
@@ -159,23 +158,23 @@ var css = `@charset "UTF-8";
159
158
  border-radius: 50%;
160
159
  background: #eeeeee;
161
160
  }
162
- .editor .main .player-controls .player-controls-time {
161
+ .editor .player-controls .player-controls-time {
163
162
  width: 10vw;
164
163
  color: #fff;
165
164
  }
166
- .editor .main .play-btn {
165
+ .editor .play-btn {
167
166
  position: absolute;
168
167
  bottom: 4vw;
169
168
  left: 3vw;
170
169
  width: 4.8vw;
171
170
  height: 4.8vw;
172
171
  }
173
- .editor .main .play-btn img {
172
+ .editor .play-btn img {
174
173
  width: 100%;
175
174
  height: 100%;
176
175
  display: block;
177
176
  }
178
- .editor .main .opacity-06 {
177
+ .editor .opacity-06 {
179
178
  opacity: 0.6;
180
179
  }
181
180
  .editor .footer {
@@ -310,7 +309,7 @@ var css = `@charset "UTF-8";
310
309
  width: 60px !important;
311
310
  }
312
311
  }
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"]} */`;
312
+ /*# 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: 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
313
  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
315
314
 
316
315
  // src/utils/const.ts
@@ -1012,7 +1011,7 @@ function usePeekControl(canvas, hideConfig) {
1012
1011
  return canvas;
1013
1012
  }
1014
1013
  var EditorCanvas = react.forwardRef(
1015
- ({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig }, ref) => {
1014
+ ({ previewState, showCanvas, canvasSize, enterPreview, intoTextEdit, frame, vmml, dragState, initFcObjs, editClips = [], onVideoChange, isBatchModify, hideConfig, textWarapCenter }, ref) => {
1016
1015
  const [fc, setFc] = react.useState(null);
1017
1016
  const [history, setHistory] = react.useState(null);
1018
1017
  const [canvasReady, setCanvasReady] = react.useState(false);
@@ -1454,6 +1453,7 @@ var EditorCanvas = react.forwardRef(
1454
1453
  lines.forEach((line) => {
1455
1454
  const p = document.createElement("p");
1456
1455
  p.style.position = "relative";
1456
+ p.style.display = "flex";
1457
1457
  p.style.fontSize = "22px";
1458
1458
  p.style.lineHeight = "22px";
1459
1459
  p.style.fontFamily = fontFamily;
@@ -1462,6 +1462,7 @@ var EditorCanvas = react.forwardRef(
1462
1462
  p.style.padding = "0";
1463
1463
  if (letterSpacing) p.style.letterSpacing = `${letterSpacing}px`;
1464
1464
  p.style.zIndex = "2";
1465
+ if (textWarapCenter) p.style.justifyContent = "center";
1465
1466
  const fill = document.createElement("span");
1466
1467
  fill.textContent = line || " ";
1467
1468
  fill.style.color = textColor;
@@ -1470,11 +1471,17 @@ var EditorCanvas = react.forwardRef(
1470
1471
  const stroke = document.createElement("span");
1471
1472
  stroke.textContent = line || " ";
1472
1473
  stroke.style.position = "absolute";
1473
- stroke.style.left = "0";
1474
- stroke.style.top = "0";
1475
1474
  stroke.style.color = "transparent";
1476
1475
  stroke.style.webkitTextStrokeWidth = `${strokeW}px`;
1477
1476
  stroke.style.webkitTextStrokeColor = stColor;
1477
+ if (textWarapCenter) {
1478
+ stroke.style.left = "50%";
1479
+ stroke.style.top = "50%";
1480
+ stroke.style.transform = "translate(-50%, -50%)";
1481
+ } else {
1482
+ stroke.style.left = "0";
1483
+ stroke.style.top = "0";
1484
+ }
1478
1485
  stroke.style.zIndex = "-1";
1479
1486
  p.appendChild(fill);
1480
1487
  p.appendChild(stroke);
@@ -2420,6 +2427,7 @@ var EditorFn = ({
2420
2427
  height = "100vh",
2421
2428
  pauseWhenBuffering = false,
2422
2429
  isBatchModify = false,
2430
+ textWarapCenter = false,
2423
2431
  hideConfig = null
2424
2432
  // { hideDelete: false, hideEdit: false, hideMute: false, hideVolume: false }
2425
2433
  }, ref) => {
@@ -2706,15 +2714,6 @@ var EditorFn = ({
2706
2714
  initCanEditClips(vmmlState.template.tracks);
2707
2715
  }
2708
2716
  }, [editableArray, refreshEdit, vmmlState]);
2709
- react.useEffect(() => {
2710
- var _a2;
2711
- if (propVmml) {
2712
- const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(propVmml);
2713
- setVmmlState(convertedVmml);
2714
- setDurationInFrames(vmmlUtils.getFrames(((_a2 = propVmml == null ? void 0 : propVmml.template) == null ? void 0 : _a2.duration) || 1, fps));
2715
- setRefreshEdit(Date.now());
2716
- }
2717
- }, [propVmml]);
2718
2717
  react.useEffect(() => {
2719
2718
  if (vmmlState) {
2720
2719
  initFcObjects(vmmlState.template.tracks);
@@ -2724,8 +2723,10 @@ var EditorFn = ({
2724
2723
  if (player) {
2725
2724
  const parent = player.getContainerNode();
2726
2725
  if (!canvasSize.width) {
2726
+ console.log(parent, "parent>>>>");
2727
2727
  const playerElement = parent == null ? void 0 : parent.children[0];
2728
2728
  const { width, height: height2 } = (playerElement == null ? void 0 : playerElement.getBoundingClientRect()) || {};
2729
+ console.log(height2);
2729
2730
  setCanvasSize({ width, height: height2, top: playerElement.offsetTop });
2730
2731
  }
2731
2732
  player.addEventListener("play", onPlay);
@@ -2762,31 +2763,30 @@ var EditorFn = ({
2762
2763
  setPreviewState(false);
2763
2764
  }
2764
2765
  }, [dragState]);
2765
- const updateVmml = (v, checkFrame) => {
2766
- var _a2, _b;
2766
+ const updateEditor = (v, checkFrame) => {
2767
+ var _a2, _b, _c, _d;
2767
2768
  const { current: playerCurrent } = vmmlPlayerRef;
2768
2769
  const { current: canvasCurrent } = canvasRef;
2769
2770
  if (!playerCurrent) return;
2770
- (_b = (_a2 = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _a2.clear) == null ? void 0 : _b.call(_a2);
2771
+ const isSame = JSON.stringify(v) === JSON.stringify(vmmlState);
2772
+ console.log(v, vmmlState, isSame, "\u5224\u65ADvmml\u662F\u5426\u76F8\u540C");
2771
2773
  needPlay.current = false;
2772
- const currentFrame = checkFrame ?? pauseFrame;
2773
- requestAnimationFrame(() => {
2774
- var _a3;
2775
- const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(v);
2774
+ const convertedVmml = vmmlUtils.convertVmmlTextScaleByForbidden(v);
2775
+ if (!isSame) {
2776
+ (_b = (_a2 = canvasCurrent == null ? void 0 : canvasCurrent.getCanvasCtx()) == null ? void 0 : _a2.clear) == null ? void 0 : _b.call(_a2);
2776
2777
  setVmmlState(convertedVmml);
2777
- setDurationInFrames(vmmlUtils.getFrames(((_a3 = v == null ? void 0 : v.template) == null ? void 0 : _a3.duration) || 1, fps));
2778
- playerCurrent.setVmml(convertedVmml, currentFrame);
2778
+ setDurationInFrames(vmmlUtils.getFrames(((_c = v == null ? void 0 : v.template) == null ? void 0 : _c.duration) || 1, fps));
2779
2779
  setRefreshEdit(Date.now());
2780
- if (canvasCurrent) {
2781
- canvasCurrent.checkObjectInPoint(currentFrame);
2782
- }
2783
- });
2780
+ }
2781
+ const currentFrame = checkFrame ?? pauseFrame;
2782
+ playerCurrent.setVmml(convertedVmml, currentFrame);
2783
+ (_d = canvasCurrent == null ? void 0 : canvasCurrent.checkObjectInPoint) == null ? void 0 : _d.call(canvasCurrent, currentFrame);
2784
2784
  };
2785
2785
  const getCurrentFrame = () => {
2786
2786
  if (!player) return 0;
2787
2787
  return player.getCurrentFrame();
2788
2788
  };
2789
- const EditorSeekTo = (frame2) => {
2789
+ const editorSeekTo = (frame2) => {
2790
2790
  var _a2;
2791
2791
  (_a2 = player == null ? void 0 : player.seekTo) == null ? void 0 : _a2.call(player, frame2 ?? 0);
2792
2792
  const { current: canvasCurrent } = canvasRef;
@@ -2799,13 +2799,20 @@ var EditorFn = ({
2799
2799
  () => ({
2800
2800
  getActions,
2801
2801
  getfcObject,
2802
+ // 获取画布上所有对象
2802
2803
  getCurrentFrame,
2804
+ // 获取当前帧
2803
2805
  getVmml,
2804
- EditorSeekTo,
2806
+ // 获取vmml
2805
2807
  getPlayer,
2808
+ // 获取player实例
2806
2809
  texteditClose,
2807
2810
  textFinish,
2808
- updateVmml
2811
+ // 完成按钮事件
2812
+ editorSeekTo,
2813
+ // editor的seek事件 入参:frame
2814
+ updateEditor
2815
+ // 更新editor 入参:vmml, frame
2809
2816
  }),
2810
2817
  [vmmlState, player]
2811
2818
  );
@@ -2845,7 +2852,8 @@ var EditorFn = ({
2845
2852
  onPlayerReady,
2846
2853
  premountFor: 40,
2847
2854
  pauseWhenBuffering,
2848
- filterIds
2855
+ filterIds,
2856
+ textWarapCenter
2849
2857
  }
2850
2858
  ) }),
2851
2859
  /* @__PURE__ */ jsxRuntime.jsx(
@@ -2864,26 +2872,27 @@ var EditorFn = ({
2864
2872
  editClips,
2865
2873
  onVideoChange,
2866
2874
  isBatchModify,
2867
- hideConfig
2875
+ hideConfig,
2876
+ textWarapCenter
2868
2877
  }
2869
2878
  ),
2870
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
2871
- Controls_default,
2872
- {
2873
- player,
2874
- vmmlRef: vmmlPlayerRef,
2875
- fps,
2876
- durationInFrames,
2877
- intoEdit,
2878
- frame,
2879
- isPlaying,
2880
- setDragState,
2881
- onControlsClick,
2882
- signList
2883
- }
2884
- ) }),
2885
2879
  /* @__PURE__ */ jsxRuntime.jsx(Loading_default, { show: loading })
2886
2880
  ] }) }),
2881
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "controls-box", children: /* @__PURE__ */ jsxRuntime.jsx(
2882
+ Controls_default,
2883
+ {
2884
+ player,
2885
+ vmmlRef: vmmlPlayerRef,
2886
+ fps,
2887
+ durationInFrames,
2888
+ intoEdit,
2889
+ frame,
2890
+ isPlaying,
2891
+ setDragState,
2892
+ onControlsClick,
2893
+ signList
2894
+ }
2895
+ ) }),
2887
2896
  /* @__PURE__ */ jsxRuntime.jsx("div", { className: "padding-box" }),
2888
2897
  (maxText > 0 || maxVideo > 0) && /* @__PURE__ */ jsxRuntime.jsxs("section", { style: menuStyles, className: `footer ${menuState === "text" ? "text-style" : ""}`, children: [
2889
2898
  maxText > 0 && /* @__PURE__ */ jsxRuntime.jsxs(