diff --git a/src/store/modules/normalizers.js b/src/store/modules/normalizers.js index 9a097ffd..5b7f6ff1 100644 --- a/src/store/modules/normalizers.js +++ b/src/store/modules/normalizers.js @@ -24,6 +24,8 @@ export const parseTuples = (tuples, key) => { return { key: name, value: icon[name], id: `f${(~~(Math.random() * 1e8)).toString(16)}` } }) }, []) + } else if (item.tuple[0] === ':proxy_url') { + accum[item.tuple[0]] = parseProxyUrl(item.tuple[1]) } else if ((item.tuple[0] === ':sslopts' && item.tuple[1].length === 0) || // should be removed (item.tuple[0] === ':tlsopts' && item.tuple[1].length === 0)) { accum[item.tuple[0]] = {} @@ -70,6 +72,17 @@ const parseObject = object => { }, {}) } +const parseProxyUrl = value => { + if (!Array.isArray(value) && typeof value === 'object' && value.tuple.length === 3 && value.tuple[0] === ':socks5') { + const [, host, port] = value.tuple + return { socks5: true, host, port } + } else if (typeof value === 'string') { + const [host, port] = value.split(':') + return { socks5: false, host, port } + } + return { socks5: false, host: null, port: null } +} + export const partialUpdate = (group, key) => { if ((group === ':pleroma' && key === ':ecto_repos') || (group === ':quack' && key === ':meta') || @@ -109,6 +122,8 @@ const wrapValues = settings => { return { 'tuple': [setting, wrapValues(value)] } } else if (type === 'atom') { return { 'tuple': [setting, `:${value}`] } + } else if (type.includes('tuple') && Array.isArray(value)) { + return { 'tuple': [setting, { 'tuple': value }] } } else if (type === 'map') { const objectValue = Object.keys(value).reduce((acc, key) => { acc[key] = value[key][1] diff --git a/src/views/settings/components/Inputs.vue b/src/views/settings/components/Inputs.vue index 91686720..b93f7894 100644 --- a/src/views/settings/components/Inputs.vue +++ b/src/views/settings/components/Inputs.vue @@ -104,19 +104,12 @@ -
- Socks5 - -
+

{{ setting.description }}

@@ -126,7 +119,7 @@ import AceEditor from 'vue2-ace-editor' import 'brace/mode/elixir' import 'default-passive-events' -import { AutoLinkerInput, EditableKeywordInput, IconsInput, MascotsInput } from './inputComponents' +import { AutoLinkerInput, EditableKeywordInput, IconsInput, MascotsInput, ProxyUrlInput } from './inputComponents' export default { name: 'Inputs', @@ -135,7 +128,8 @@ export default { AutoLinkerInput, EditableKeywordInput, IconsInput, - MascotsInput + MascotsInput, + ProxyUrlInput }, props: { customLabelWidth: { @@ -203,18 +197,6 @@ export default { labelWidth() { return this.isMobile ? '100px' : '240px' }, - proxyUrlData() { - if (!this.data[this.setting.key]) { - return null - } else { - return typeof this.data[this.setting.key] === 'string' - ? this.data[this.setting.key] - : `${this.data[this.setting.key][1]}:${this.data[this.setting.key][2]}` - } - }, - proxyUrlTypeSocks5() { - return Array.isArray(this.data[this.setting.key]) && this.data[this.setting.key][0] === 'socks5' - }, prune() { return this.data[this.setting.key] === ':disabled' ? ':disabled' diff --git a/src/views/settings/components/inputComponents/ProxyUrlInput.vue b/src/views/settings/components/inputComponents/ProxyUrlInput.vue new file mode 100644 index 00000000..11335e4a --- /dev/null +++ b/src/views/settings/components/inputComponents/ProxyUrlInput.vue @@ -0,0 +1,66 @@ + + + + + diff --git a/src/views/settings/components/inputComponents/index.js b/src/views/settings/components/inputComponents/index.js index a505d73d..7793db17 100644 --- a/src/views/settings/components/inputComponents/index.js +++ b/src/views/settings/components/inputComponents/index.js @@ -2,3 +2,4 @@ export { default as AutoLinkerInput } from './AutoLinkerInput' export { default as MascotsInput } from './MascotsInput' export { default as EditableKeywordInput } from './EditableKeywordInput' export { default as IconsInput } from './IconsInput' +export { default as ProxyUrlInput } from './ProxyUrlInput' diff --git a/src/views/settings/styles/main.scss b/src/views/settings/styles/main.scss index 15e62342..41599bda 100644 --- a/src/views/settings/styles/main.scss +++ b/src/views/settings/styles/main.scss @@ -147,7 +147,7 @@ align-items: baseline; } .value-input { - width: 70%; + width: 35%; margin-left: 8px; margin-right: 10px }