traxxx/assets/components/settings/summary.vue

328 lines
6.9 KiB
Vue

<template>
<div>
<div class="dialog-section">
<h3 class="form-heading">Summary format</h3>
<ul class="summary nolist">
<li
v-for="(group, groupIndex) in summaryFormat"
:key="groupIndex"
class="summary-group"
>
<div class="summary-options">
<label class="summary-option">Delimiter
<input
class="input summary-delimiter"
:value="group.delimiter"
@change="setSummaryGroupValue(groupIndex, 'delimiter', $event.target.value)"
>
</label>
<label class="summary-option">Brackets
<select
class="select summary-delimiter"
:value="group.bracket"
@change="setSummaryGroupValue(groupIndex, 'bracket', $event.target.value)"
>
<option
v-for="bracket in brackets"
:key="bracket"
>{{ bracket }}</option>
</select>
</label>
</div>
<ul class="summary-segments nolist">
<li
v-for="(segment, segmentIndex) in group.segments"
:key="segmentIndex"
class="summary-segment"
>
<select
class="select summary-prop"
:value="segment.prop"
@change="setSummarySegmentValue(groupIndex, segmentIndex, 'prop', $event.target.value)"
>
<option>channel</option>
<option>network</option>
<option>title</option>
<option>movie</option>
<option>tags</option>
<option>actors</option>
<option>date</option>
</select>
<input
v-if="delimitedProps.includes(segment.prop)"
class="input summary-delimiter"
:value="segment.delimiter"
@change="setSummarySegmentValue(groupIndex, segmentIndex, 'delimiter', $event.target.value)"
>
<select
v-if="segment.prop === 'date'"
class="select summary-format"
:value="segment.format"
@change="setSummarySegmentValue(groupIndex, segmentIndex, 'format', $event.target.value)"
>
<option>YYYY-MM-DD</option>
<option>DD-MM-YYYY</option>
<option>MM/DD/YYYY</option>
</select>
<Icon
icon="bin"
class="active"
@click="removeSummarySegment(groupIndex, segmentIndex)"
/>
</li>
<li class="summary-actions">
<button
type="button"
class="button button-secondary"
@click="addSummarySegment(groupIndex)"
>Add segment</button>
<button
type="button"
class="button button-secondary"
@click="removeSummaryGroup(groupIndex)"
>Remove group</button>
</li>
</ul>
</li>
<li class="summary summary-actions">
<button
type="button"
class="button button-secondary"
@click="addSummaryGroup"
>Add group</button>
<button
type="button"
class="button button-secondary"
@click="resetSummaryFormat"
>Reset to default</button>
</li>
</ul>
</div>
<div class="dialog-section">
<h3 class="form-heading">Preview</h3>
<input
class="input summary-preview"
:value="summary"
:title="summary"
disabled
>
</div>
</div>
</template>
<script>
import formatSummary from '../../js/utils/format-summary';
function summary() {
return formatSummary(this.scene, this.summaryFormat);
}
function summaryFormat() {
return this.$store.state.ui.summaryFormat;
}
function setSummaryGroupValue(targetGroupIndex, target, value) {
const newFormat = this.summaryFormat.map((group, groupIndex) => {
if (groupIndex === targetGroupIndex) {
return {
...group,
[target]: value,
};
}
return group;
});
this.$store.dispatch('setSummaryFormat', newFormat);
}
function setSummarySegmentValue(targetGroupIndex, targetSegmentIndex, target, value) {
const newFormat = this.summaryFormat.map((group, groupIndex) => {
if (groupIndex === targetGroupIndex) {
return {
...group,
segments: group.segments.map((segment, segmentIndex) => {
if (segmentIndex === targetSegmentIndex) {
return {
...segment,
[target]: value,
};
}
return segment;
}),
};
}
return group;
});
this.$store.dispatch('setSummaryFormat', newFormat);
}
function addSummarySegment(targetGroupIndex) {
const newFormat = this.summaryFormat.map((group, groupIndex) => {
if (groupIndex === targetGroupIndex) {
return {
...group,
segments: group.segments.concat({
prop: 'title',
delimiter: ',', // default delimiter for when prop is changed to iterabte like actors or tags
format: 'YYYY-MM-DD', // default format for when prop is changed to date
}),
};
}
return group;
});
this.$store.dispatch('setSummaryFormat', newFormat);
}
function addSummaryGroup() {
const newFormat = this.summaryFormat.concat({
delimiter: ' - ',
segments: [{ prop: 'title' }],
});
this.$store.dispatch('setSummaryFormat', newFormat);
}
function removeSummaryGroup(groupIndex) {
const newFormat = this.summaryFormat.filter((group, index) => index !== groupIndex);
this.$store.dispatch('setSummaryFormat', newFormat);
}
function removeSummarySegment(targetGroupIndex, targetSegmentIndex) {
const newFormat = this.summaryFormat.map((group, groupIndex) => ({
...group,
segments: groupIndex === targetGroupIndex
? group.segments.filter((segment, index) => index !== targetSegmentIndex)
: group.segments,
}));
this.$store.dispatch('setSummaryFormat', newFormat);
}
function resetSummaryFormat() {
this.$store.dispatch('setSummaryFormat', this.$store.state.ui.defaultSummaryFormat);
}
export default {
data() {
return {
delimiters: [null, '-', '_', ',', '.'],
brackets: [null, '()', '[]', '{}', '<>'],
delimitedProps: ['actors', 'tags'],
scene: {
channel: 'Channel',
network: 'Network',
title: 'Title',
movie: 'Movie',
scene: 1,
actors: ['Jane Doe', 'John Doe'],
date: new Date(),
},
};
},
computed: {
summary,
summaryFormat,
},
methods: {
addSummaryGroup,
setSummaryGroupValue,
addSummarySegment,
setSummarySegmentValue,
removeSummaryGroup,
removeSummarySegment,
resetSummaryFormat,
},
};
</script>
<style lang="scss" scoped>
.summary {
.icon {
padding: .5rem;
}
}
.summary-group,
.summary-segment {
display: flex;
}
.summary-group {
display: flex;
flex-direction: column;
margin-bottom: .5rem;
.button {
margin-top: .5rem;
}
&:not(:last-child) {
padding-bottom: .5rem;
border-bottom: solid 1px var(--shadow-hint);
margin-bottom: .5rem;
}
}
.summary-segments {
width: 100%;
display: flex;
flex-direction: column;
}
.summary-segment {
display: flex;
align-items: center;
margin-bottom: .25rem;
}
.summary-delimiter {
width: 5rem;
}
.summary-format {
width: 9rem;
}
.summary-prop {
flex-grow: 1;
}
.summary-options {
margin-bottom: .5rem;
}
.summary-option:not(:last-child) {
margin-right: 1rem;
}
.summary-actions {
display: flex;
justify-content: space-between;
align-items: center;
}
.summary-preview {
width: 100%;
margin-bottom: 1rem;
}
</style>