2021-10-01 16:24:42 +08:00
|
|
|
|
Vue.component("http-webp-config-box", {
|
2021-10-07 16:47:14 +08:00
|
|
|
|
props: ["v-webp-config", "v-is-location", "v-is-group"],
|
2021-10-01 16:24:42 +08:00
|
|
|
|
data: function () {
|
|
|
|
|
|
let config = this.vWebpConfig
|
|
|
|
|
|
if (config == null) {
|
|
|
|
|
|
config = {
|
|
|
|
|
|
isPrior: false,
|
|
|
|
|
|
isOn: false,
|
|
|
|
|
|
quality: 50,
|
|
|
|
|
|
minLength: {count: 0, "unit": "kb"},
|
|
|
|
|
|
maxLength: {count: 0, "unit": "kb"},
|
2021-10-11 13:56:51 +08:00
|
|
|
|
mimeTypes: ["image/png", "image/jpeg", "image/bmp"],
|
|
|
|
|
|
extensions: [".png", ".jpeg", ".jpg", ".bmp"],
|
2021-10-01 16:24:42 +08:00
|
|
|
|
conds: null
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (config.mimeTypes == null) {
|
|
|
|
|
|
config.mimeTypes = []
|
|
|
|
|
|
}
|
|
|
|
|
|
if (config.extensions == null) {
|
|
|
|
|
|
config.extensions = []
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
|
config: config,
|
|
|
|
|
|
moreOptionsVisible: false,
|
|
|
|
|
|
quality: config.quality
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
watch: {
|
|
|
|
|
|
quality: function (v) {
|
|
|
|
|
|
let quality = parseInt(v)
|
|
|
|
|
|
if (isNaN(quality)) {
|
|
|
|
|
|
quality = 90
|
|
|
|
|
|
} else if (quality < 1) {
|
|
|
|
|
|
quality = 1
|
|
|
|
|
|
} else if (quality > 100) {
|
|
|
|
|
|
quality = 100
|
|
|
|
|
|
}
|
|
|
|
|
|
this.config.quality = quality
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
|
|
|
|
|
isOn: function () {
|
2021-10-07 16:47:14 +08:00
|
|
|
|
return ((!this.vIsLocation && !this.vIsGroup) || this.config.isPrior) && this.config.isOn
|
2021-10-01 16:24:42 +08:00
|
|
|
|
},
|
|
|
|
|
|
changeExtensions: function (values) {
|
|
|
|
|
|
values.forEach(function (v, k) {
|
|
|
|
|
|
if (v.length > 0 && v[0] != ".") {
|
|
|
|
|
|
values[k] = "." + v
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
this.config.extensions = values
|
|
|
|
|
|
},
|
|
|
|
|
|
changeMimeTypes: function (values) {
|
|
|
|
|
|
this.config.mimeTypes = values
|
|
|
|
|
|
},
|
|
|
|
|
|
changeAdvancedVisible: function () {
|
|
|
|
|
|
this.moreOptionsVisible = !this.moreOptionsVisible
|
|
|
|
|
|
},
|
|
|
|
|
|
changeConds: function (conds) {
|
|
|
|
|
|
this.config.conds = conds
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
template: `<div>
|
|
|
|
|
|
<input type="hidden" name="webpJSON" :value="JSON.stringify(config)"/>
|
|
|
|
|
|
<table class="ui table definition selectable">
|
2021-10-07 16:47:14 +08:00
|
|
|
|
<prior-checkbox :v-config="config" v-if="vIsLocation || vIsGroup"></prior-checkbox>
|
|
|
|
|
|
<tbody v-show="(!vIsLocation && !vIsGroup) || config.isPrior">
|
2021-10-01 16:24:42 +08:00
|
|
|
|
<tr>
|
|
|
|
|
|
<td class="title">是否启用</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<div class="ui checkbox">
|
|
|
|
|
|
<input type="checkbox" value="1" v-model="config.isOn"/>
|
|
|
|
|
|
<label></label>
|
|
|
|
|
|
</div>
|
2021-10-03 13:09:49 +08:00
|
|
|
|
<p class="comment">选中后表示开启自动WebP压缩。</p>
|
2021-10-01 16:24:42 +08:00
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
</tbody>
|
|
|
|
|
|
<tbody v-show="isOn()">
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td>图片质量</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<div class="ui input right labeled">
|
|
|
|
|
|
<input type="text" v-model="quality" style="width: 5em" maxlength="4"/>
|
|
|
|
|
|
<span class="ui label">%</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<p class="comment">取值在0到100之间,数值越大生成的图像越清晰,同时文件尺寸也会越大。</p>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td>支持的扩展名</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<values-box :values="config.extensions" @change="changeExtensions" placeholder="比如 .html"></values-box>
|
|
|
|
|
|
<p class="comment">含有这些扩展名的URL将会被转成WebP,不区分大小写。</p>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td>支持的MimeType</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<values-box :values="config.mimeTypes" @change="changeMimeTypes" placeholder="比如 text/*"></values-box>
|
|
|
|
|
|
<p class="comment">响应的Content-Type里包含这些MimeType的内容将会被转成WebP。</p>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
</tbody>
|
|
|
|
|
|
<more-options-tbody @change="changeAdvancedVisible" v-if="isOn()"></more-options-tbody>
|
|
|
|
|
|
<tbody v-show="isOn() && moreOptionsVisible">
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td>内容最小长度</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<size-capacity-box :v-name="'minLength'" :v-value="config.minLength" :v-unit="'kb'"></size-capacity-box>
|
|
|
|
|
|
<p class="comment">0表示不限制,内容长度从文件尺寸或Content-Length中获取。</p>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td>内容最大长度</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<size-capacity-box :v-name="'maxLength'" :v-value="config.maxLength" :v-unit="'mb'"></size-capacity-box>
|
|
|
|
|
|
<p class="comment">0表示不限制,内容长度从文件尺寸或Content-Length中获取。</p>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
|
|
|
|
<td>匹配条件</td>
|
|
|
|
|
|
<td>
|
|
|
|
|
|
<http-request-conds-box :v-conds="config.conds" @change="changeConds"></http-request-conds-box>
|
|
|
|
|
|
</td>
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
</tbody>
|
|
|
|
|
|
</table>
|
|
|
|
|
|
<div class="ui margin"></div>
|
|
|
|
|
|
</div>`
|
|
|
|
|
|
})
|