|
@@ -2,11 +2,11 @@
|
|
<div>
|
|
<div>
|
|
<textarea
|
|
<textarea
|
|
class="monospace-font"
|
|
class="monospace-font"
|
|
- :class="{'has-error': error}"
|
|
|
|
|
|
+ :class="{'has-error': parsedData.error}"
|
|
spellcheck="false"
|
|
spellcheck="false"
|
|
v-model="value"
|
|
v-model="value"
|
|
:disabled="disabled"
|
|
:disabled="disabled"
|
|
- :title="error"
|
|
|
|
|
|
+ :title="parsedData.error"
|
|
@change="onChange"
|
|
@change="onChange"
|
|
/>
|
|
/>
|
|
<button v-if="hasSave" v-text="i18n('buttonSave')" @click="onSave"
|
|
<button v-if="hasSave" v-text="i18n('buttonSave')" @click="onSave"
|
|
@@ -37,49 +37,52 @@ export default {
|
|
data() {
|
|
data() {
|
|
return {
|
|
return {
|
|
value: null,
|
|
value: null,
|
|
- jsonValue: null,
|
|
|
|
- error: null,
|
|
|
|
- canSave: null,
|
|
|
|
- canReset: null,
|
|
|
|
|
|
+ savedValue: null,
|
|
};
|
|
};
|
|
},
|
|
},
|
|
|
|
+ computed: {
|
|
|
|
+ parsedData() {
|
|
|
|
+ let value;
|
|
|
|
+ let error;
|
|
|
|
+ if (this.json) {
|
|
|
|
+ try {
|
|
|
|
+ value = JSON.parse(this.value);
|
|
|
|
+ } catch (e) {
|
|
|
|
+ error = e.message || e;
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ value = this.value;
|
|
|
|
+ }
|
|
|
|
+ return { value, error };
|
|
|
|
+ },
|
|
|
|
+ canSave() {
|
|
|
|
+ return !this.parsedData.error && !deepEqual(this.parsedData.value, this.savedValue || '');
|
|
|
|
+ },
|
|
|
|
+ canReset() {
|
|
|
|
+ return !deepEqual(this.parsedData.value, this.defaultValue || '');
|
|
|
|
+ },
|
|
|
|
+ },
|
|
created() {
|
|
created() {
|
|
const handle = this.json
|
|
const handle = this.json
|
|
? (value => JSON.stringify(value, null, ' '))
|
|
? (value => JSON.stringify(value, null, ' '))
|
|
// XXX compatible with old data format
|
|
// XXX compatible with old data format
|
|
: (value => (Array.isArray(value) ? value.join('\n') : value || ''));
|
|
: (value => (Array.isArray(value) ? value.join('\n') : value || ''));
|
|
this.revoke = hookSetting(this.name, val => {
|
|
this.revoke = hookSetting(this.name, val => {
|
|
- this.savedValue = val;
|
|
|
|
- val = handle(val);
|
|
|
|
- if (this.value !== val) this.value = val; // will call onInput
|
|
|
|
- else this.onInput(val);
|
|
|
|
|
|
+ this.savedValue = Object.seal(val);
|
|
|
|
+ this.value = handle(val);
|
|
});
|
|
});
|
|
this.defaultValue = objectGet(defaults, this.name);
|
|
this.defaultValue = objectGet(defaults, this.name);
|
|
- this.$watch('value', this.onInput);
|
|
|
|
},
|
|
},
|
|
beforeDestroy() {
|
|
beforeDestroy() {
|
|
this.revoke();
|
|
this.revoke();
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
- onInput(val) {
|
|
|
|
- if (this.json) {
|
|
|
|
- try {
|
|
|
|
- val = JSON.parse(val);
|
|
|
|
- this.jsonValue = val;
|
|
|
|
- this.error = null;
|
|
|
|
- } catch (e) {
|
|
|
|
- this.error = e.message || e;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- this.canSave = this.hasSave && !this.error && !deepEqual(val, this.savedValue || '');
|
|
|
|
- this.canReset = this.hasReset && !deepEqual(val, this.defaultValue || '');
|
|
|
|
- },
|
|
|
|
onChange() {
|
|
onChange() {
|
|
- if (!this.error) {
|
|
|
|
- options.set(this.name, this.json ? this.jsonValue : this.value);
|
|
|
|
- }
|
|
|
|
|
|
+ // Auto save if there is no `Save` button
|
|
|
|
+ if (!this.hasSave && this.canSave) this.onSave();
|
|
},
|
|
},
|
|
onSave() {
|
|
onSave() {
|
|
|
|
+ options.set(this.name, this.parsedData.value);
|
|
this.$emit('save');
|
|
this.$emit('save');
|
|
},
|
|
},
|
|
onReset() {
|
|
onReset() {
|