Skip to content

Commit

Permalink
Move colours from the store to the utils helper (FreeTubeApp#2710)
Browse files Browse the repository at this point in the history
* Move colours from the store to the utils helper

* Use a single array for colours
  • Loading branch information
absidue authored Oct 12, 2022
1 parent f12b9e1 commit bc8261d
Show file tree
Hide file tree
Showing 10 changed files with 86 additions and 145 deletions.
11 changes: 5 additions & 6 deletions src/renderer/components/data-settings/data-settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { MAIN_PROFILE_ID } from '../../../constants'
import fs from 'fs'
import { opmlToJSON } from 'opml-to-json'
import ytch from 'yt-channel-info'
import { calculateColorLuminance } from '../../helpers/utils'
import { calculateColorLuminance, getRandomColor } from '../../helpers/utils'

// FIXME: Missing web logic branching

Expand Down Expand Up @@ -129,15 +129,15 @@ export default Vue.extend({
})
},

importFreeTubeSubscriptions: async function (textDecode) {
importFreeTubeSubscriptions: function (textDecode) {
textDecode = textDecode.split('\n')
textDecode.pop()
textDecode = textDecode.map(data => JSON.parse(data))

const firstEntry = textDecode[0]
if (firstEntry.channelId && firstEntry.channelName && firstEntry.channelThumbnail && firstEntry._id && firstEntry.profile) {
// Old FreeTube subscriptions format detected, so convert it to the new one:
textDecode = await this.convertOldFreeTubeFormatToNew(textDecode)
textDecode = this.convertOldFreeTubeFormatToNew(textDecode)
}

textDecode.forEach((profileData) => {
Expand Down Expand Up @@ -1085,14 +1085,14 @@ export default Vue.extend({
})
},

async convertOldFreeTubeFormatToNew(oldData) {
convertOldFreeTubeFormatToNew(oldData) {
const convertedData = []
for (const channel of oldData) {
const listOfProfilesAlreadyAdded = []
for (const profile of channel.profile) {
let index = convertedData.findIndex(p => p.name === profile.value)
if (index === -1) { // profile doesn't exist yet
const randomBgColor = await this.getRandomColor()
const randomBgColor = getRandomColor()
const contrastyTextColor = calculateColorLuminance(randomBgColor)
convertedData.push({
name: profile.value,
Expand Down Expand Up @@ -1241,7 +1241,6 @@ export default Vue.extend({
'updateHistory',
'compactHistory',
'showToast',
'getRandomColor',
'showOpenDialog',
'readFileFromDialog',
'showSaveDialog',
Expand Down
4 changes: 2 additions & 2 deletions src/renderer/components/ft-profile-edit/ft-profile-edit.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import FtFlexBox from '../../components/ft-flex-box/ft-flex-box.vue'
import FtInput from '../../components/ft-input/ft-input.vue'
import FtButton from '../../components/ft-button/ft-button.vue'
import { MAIN_PROFILE_ID } from '../../../constants'
import { calculateColorLuminance } from '../../helpers/utils'
import { calculateColorLuminance, colors } from '../../helpers/utils'

export default Vue.extend({
name: 'FtProfileEdit',
Expand Down Expand Up @@ -46,7 +46,7 @@ export default Vue.extend({
return this.profileId === MAIN_PROFILE_ID
},
colorValues: function () {
return this.$store.getters.getColorValues
return colors.map(color => color.value)
},
profileInitial: function () {
return this?.profileName?.length > 0 ? Array.from(this.profileName)[0].toUpperCase() : ''
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import Vue from 'vue'
import { mapActions } from 'vuex'
import { colors } from '../../helpers/utils'
import FtSelect from '../ft-select/ft-select.vue'

export default Vue.extend({
Expand Down Expand Up @@ -27,7 +28,7 @@ export default Vue.extend({
},
computed: {
colorValues: function () {
return this.$store.getters.getColorNames
return colors.map(color => color.name)
},

colorNames: function () {
Expand Down
10 changes: 3 additions & 7 deletions src/renderer/components/ft-video-player/ft-video-player.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import 'videojs-http-source-selector'

import { IpcChannels } from '../../../constants'
import { sponsorBlockSkipSegments } from '../../helpers/sponsorblock'
import { calculateColorLuminance } from '../../helpers/utils'
import { calculateColorLuminance, colors } from '../../helpers/utils'

export default Vue.extend({
name: 'FtVideoPlayer',
Expand Down Expand Up @@ -1181,14 +1181,10 @@ export default Vue.extend({

if (!this.player.loop()) {
const currentTheme = this.$store.state.settings.mainColor
const colorNames = this.$store.state.utils.colorNames
const colorValues = this.$store.state.utils.colorValues

const nameIndex = colorNames.findIndex((color) => {
return color === currentTheme
})
const colorValue = colors.find(color => color.name === currentTheme).value

const themeTextColor = calculateColorLuminance(colorValues[nameIndex])
const themeTextColor = calculateColorLuminance(colorValue)

loopButton.classList.add('vjs-icon-loop-active')

Expand Down
3 changes: 2 additions & 1 deletion src/renderer/components/theme-settings/theme-settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import FtToggleSwitch from '../ft-toggle-switch/ft-toggle-switch.vue'
import FtSlider from '../ft-slider/ft-slider.vue'
import FtFlexBox from '../ft-flex-box/ft-flex-box.vue'
import FtPrompt from '../ft-prompt/ft-prompt.vue'
import { colors } from '../../helpers/utils'

export default Vue.extend({
name: 'ThemeSettings',
Expand Down Expand Up @@ -100,7 +101,7 @@ export default Vue.extend({
},

colorValues: function () {
return this.$store.getters.getColorNames
return colors.map(color => color.name)
},

colorNames: function () {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import Vue from 'vue'
import { mapActions } from 'vuex'
import FtLoader from '../ft-loader/ft-loader.vue'
import FtCard from '../ft-card/ft-card.vue'
import FtButton from '../ft-button/ft-button.vue'
import FtListVideo from '../ft-list-video/ft-list-video.vue'

import autolinker from 'autolinker'
import { LiveChat } from '@freetube/youtube-chat'
import { getRandomColorClass } from '../../helpers/utils'

export default Vue.extend({
name: 'WatchVideoLiveChat',
Expand Down Expand Up @@ -178,30 +178,26 @@ export default Vue.extend({
this.comments.push(comment)

if (typeof (comment.superchat) !== 'undefined') {
this.getRandomColorClass().then((data) => {
comment.superchat.colorClass = data
comment.superchat.colorClass = getRandomColorClass()

this.superChatComments.unshift(comment)
this.superChatComments.unshift(comment)

setTimeout(() => {
this.removeFromSuperChat(comment.id)
}, 120000)
})
setTimeout(() => {
this.removeFromSuperChat(comment.id)
}, 120000)
}

if (comment.author.name[0] === 'Ge' || comment.author.name[0] === 'Ne') {
this.getRandomColorClass().then((data) => {
comment.superChat = {
amount: '$5.00',
colorClass: data
}
comment.superChat = {
amount: '$5.00',
colorClass: getRandomColorClass()
}

this.superChatComments.unshift(comment)
this.superChatComments.unshift(comment)

setTimeout(() => {
this.removeFromSuperChat(comment.id)
}, 120000)
})
setTimeout(() => {
this.removeFromSuperChat(comment.id)
}, 120000)
}

if (this.stayAtBottom) {
Expand Down Expand Up @@ -260,10 +256,6 @@ export default Vue.extend({
preventDefault: function (event) {
event.stopPropagation()
event.preventDefault()
},

...mapActions([
'getRandomColorClass'
])
}
}
})
50 changes: 50 additions & 0 deletions src/renderer/helpers/utils.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,53 @@
export const colors = [
{ name: 'Red', value: '#d50000' },
{ name: 'Pink', value: '#C51162' },
{ name: 'Purple', value: '#AA00FF' },
{ name: 'DeepPurple', value: '#6200EA' },
{ name: 'Indigo', value: '#304FFE' },
{ name: 'Blue', value: '#2962FF' },
{ name: 'LightBlue', value: '#0091EA' },
{ name: 'Cyan', value: '#00B8D4' },
{ name: 'Teal', value: '#00BFA5' },
{ name: 'Green', value: '#00C853' },
{ name: 'LightGreen', value: '#64DD17' },
{ name: 'Lime', value: '#AEEA00' },
{ name: 'Yellow', value: '#FFD600' },
{ name: 'Amber', value: '#FFAB00' },
{ name: 'Orange', value: '#FF6D00' },
{ name: 'DeepOrange', value: '#DD2C00' },
{ name: 'DraculaCyan', value: '#8BE9FD' },
{ name: 'DraculaGreen', value: '#50FA7B' },
{ name: 'DraculaOrange', value: '#FFB86C' },
{ name: 'DraculaPink', value: '#FF79C6' },
{ name: 'DraculaPurple', value: '#BD93F9' },
{ name: 'DraculaRed', value: '#FF5555' },
{ name: 'DraculaYellow', value: '#F1FA8C' },
{ name: 'CatppuccinMochaRosewater', value: '#F5E0DC' },
{ name: 'CatppuccinMochaFlamingo', value: '#F2CDCD' },
{ name: 'CatppuccinMochaPink', value: '#F5C2E7' },
{ name: 'CatppuccinMochaMauve', value: '#CBA6F7' },
{ name: 'CatppuccinMochaRed', value: '#F38BA8' },
{ name: 'CatppuccinMochaMaroon', value: '#EBA0AC' },
{ name: 'CatppuccinMochaPeach', value: '#FAB387' },
{ name: 'CatppuccinMochaYellow', value: '#F9E2AF' },
{ name: 'CatppuccinMochaGreen', value: '#A6E3A1' },
{ name: 'CatppuccinMochaTeal', value: '#94E2D5' },
{ name: 'CatppuccinMochaSky', value: '#89DCEB' },
{ name: 'CatppuccinMochaSapphire', value: '#74C7EC' },
{ name: 'CatppuccinMochaBlue', value: '#89B4FA' },
{ name: 'CatppuccinMochaLavender', value: '#B4BEFE' }
]

export function getRandomColorClass() {
const randomInt = Math.floor(Math.random() * colors.length)
return 'main' + colors[randomInt].name
}

export function getRandomColor() {
const randomInt = Math.floor(Math.random() * colors.length)
return colors[randomInt].value
}

export function calculateColorLuminance(colorValue) {
const cutHex = colorValue.substring(1, 7)
const colorValueR = parseInt(cutHex.substring(0, 2), 16)
Expand Down
6 changes: 3 additions & 3 deletions src/renderer/store/modules/profiles.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { MAIN_PROFILE_ID } from '../../../constants'
import { DBProfileHandlers } from '../../../datastores/handlers/index'
import { calculateColorLuminance } from '../../helpers/utils'
import { calculateColorLuminance, getRandomColor } from '../../helpers/utils'

const state = {
profileList: [{
Expand Down Expand Up @@ -40,7 +40,7 @@ function profileSort(a, b) {
}

const actions = {
async grabAllProfiles({ rootState, dispatch, commit }, defaultName = null) {
async grabAllProfiles({ rootState, commit }, defaultName = null) {
let profiles
try {
profiles = await DBProfileHandlers.find()
Expand All @@ -53,7 +53,7 @@ const actions = {

if (profiles.length === 0) {
// Create a default profile and persist it
const randomColor = await dispatch('getRandomColor')
const randomColor = getRandomColor()
const textColor = calculateColorLuminance(randomColor)
const defaultProfile = {
_id: MAIN_PROFILE_ID,
Expand Down
97 changes: 0 additions & 97 deletions src/renderer/store/modules/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,85 +27,6 @@ const state = {
type: 'all',
duration: ''
},
colorNames: [
'Red',
'Pink',
'Purple',
'DeepPurple',
'Indigo',
'Blue',
'LightBlue',
'Cyan',
'Teal',
'Green',
'LightGreen',
'Lime',
'Yellow',
'Amber',
'Orange',
'DeepOrange',
'DraculaCyan',
'DraculaGreen',
'DraculaOrange',
'DraculaPink',
'DraculaPurple',
'DraculaRed',
'DraculaYellow',
'CatppuccinMochaRosewater',
'CatppuccinMochaFlamingo',
'CatppuccinMochaPink',
'CatppuccinMochaMauve',
'CatppuccinMochaRed',
'CatppuccinMochaMaroon',
'CatppuccinMochaPeach',
'CatppuccinMochaYellow',
'CatppuccinMochaGreen',
'CatppuccinMochaTeal',
'CatppuccinMochaSky',
'CatppuccinMochaSapphire',
'CatppuccinMochaBlue',
'CatppuccinMochaLavender'

],
colorValues: [
'#d50000',
'#C51162',
'#AA00FF',
'#6200EA',
'#304FFE',
'#2962FF',
'#0091EA',
'#00B8D4',
'#00BFA5',
'#00C853',
'#64DD17',
'#AEEA00',
'#FFD600',
'#FFAB00',
'#FF6D00',
'#DD2C00',
'#8BE9FD',
'#50FA7B',
'#FFB86C',
'#FF79C6',
'#BD93F9',
'#FF5555',
'#F1FA8C',
'#F5E0DC',
'#F2CDCD',
'#F5C2E7',
'#CBA6F7',
'#F38BA8',
'#EBA0AC',
'#FAB387',
'#F9E2AF',
'#A6E3A1',
'#94E2D5',
'#89DCEB',
'#74C7EC',
'#89B4FA',
'#B4BEFE'
],
externalPlayerNames: [],
externalPlayerNameTranslationKeys: [],
externalPlayerValues: [],
Expand Down Expand Up @@ -137,14 +58,6 @@ const getters = {
return state.searchSettings
},

getColorNames () {
return state.colorNames
},

getColorValues () {
return state.colorValues
},

getShowProgressBar () {
return state.showProgressBar
},
Expand Down Expand Up @@ -534,16 +447,6 @@ const actions = {
commit('setShowProgressBar', value)
},

getRandomColorClass () {
const randomInt = Math.floor(Math.random() * state.colorNames.length)
return 'main' + state.colorNames[randomInt]
},

getRandomColor () {
const randomInt = Math.floor(Math.random() * state.colorValues.length)
return state.colorValues[randomInt]
},

getRegionData ({ commit }, payload) {
let fileData
/* eslint-disable-next-line */
Expand Down
Loading

0 comments on commit bc8261d

Please sign in to comment.