diff --git a/chat/CharacterSearch.vue b/chat/CharacterSearch.vue index ac9e380..615fbd7 100644 --- a/chat/CharacterSearch.vue +++ b/chat/CharacterSearch.vue @@ -44,6 +44,7 @@ import l from './localize'; import UserView from './UserView.vue'; import * as _ from 'lodash'; + import {EventBus} from './event-bus'; type Options = { kinks: Kink[], @@ -57,6 +58,26 @@ function sort(x: Character, y: Character): number { if(x.status === 'looking' && y.status !== 'looking') return -1; if(x.status !== 'looking' && y.status === 'looking') return 1; + + const xc = core.cache.profileCache.getSync(x.name); + const yc = core.cache.profileCache.getSync(y.name); + + if (xc && !yc) { + return -1; + } + + if (!xc && yc) { + return 1; + } + + if (xc && yc) { + if (xc.matchScore > yc.matchScore) + return -1; + + if (xc.matchScore < yc.matchScore) + return 1; + } + if(x.name < y.name) return -1; if(x.name > y.name) return 1; return 0; @@ -87,6 +108,10 @@ searchString = ''; + // tslint:disable-next-line no-any + scoreWatcher: ((event: any) => void) | null = null; + + @Hook('created') async created(): Promise { if(options === undefined) @@ -121,6 +146,43 @@ this.results = data.characters.map((x) => core.characters.get(x)) .filter((x) => core.state.hiddenUsers.indexOf(x.name) === -1 && !x.isIgnored).sort(sort); }); + + if (this.scoreWatcher) { + EventBus.$off('character-score', this.scoreWatcher); + } + + // tslint:disable-next-line no-unsafe-any no-any + this.scoreWatcher = (event: any): void => { + // console.log('scoreWatcher', event); + + if ( + (this.results) + // tslint:disable-next-line no-unsafe-any no-any + && (event.character) + // tslint:disable-next-line no-unsafe-any no-any + && (_.find(this.results, (c: Character) => c.name === event.character.character.name)) + ) { + this.results = this.results.sort(sort); + } + }; + + EventBus.$on( + 'character-score', + this.scoreWatcher + ); + } + + + @Hook('beforeDestroy') + beforeDestroy(): void { + if (this.scoreWatcher) { + EventBus.$off( + 'character-score', + this.scoreWatcher + ); + + delete this.scoreWatcher; + } } @@ -128,10 +190,10 @@ onDataChange(): void { this.searchString = _.join( _.map( + // tslint:disable-next-line no-unsafe-any no-any _.flatten(_.map(this.data as any)), - (v) => { - return _.get(v, 'name', v); - } + // tslint:disable-next-line no-unsafe-any no-any + (v) => _.get(v, 'name', v) ), ', ' ); diff --git a/chat/ConversationView.vue b/chat/ConversationView.vue index 5846c82..c166021 100644 --- a/chat/ConversationView.vue +++ b/chat/ConversationView.vue @@ -693,13 +693,15 @@ border-bottom: 1px solid rgba(255, 255, 255, 0.1); &.match { - border-left: 12px solid #027b02; - background-color: rgba(1, 115, 1, 0.45); + border-left: 12px solid #048a04; + background-color: rgba(0, 110, 0, 0.47); + // border-left: 12px solid #027b02; + // background-color: rgba(1, 115, 1, 0.45); } &.weak-match { - border-left: 12px solid #015a01; - background-color: rgba(0, 70, 0, 0.4); + border-left: 12px solid #014a01; + background-color: rgba(0, 79, 0, 0.4); .bbcode { filter: grayscale(0.25); diff --git a/learn/cache-manager.ts b/learn/cache-manager.ts index 8a03ccb..d820120 100644 --- a/learn/cache-manager.ts +++ b/learn/cache-manager.ts @@ -141,7 +141,7 @@ export class CacheManager { this.queue = _.sortBy(this.queue, 'score'); - console.log('QUEUE', _.map(this.queue, (q) => `${q.name}: ${q.score}`)); + // console.log('QUEUE', _.map(this.queue, (q) => `${q.name}: ${q.score}`)); const entry = this.queue.pop() as ProfileCacheQueueEntry; diff --git a/learn/character-profiler.ts b/learn/character-profiler.ts index 80d79c7..aa14f6b 100644 --- a/learn/character-profiler.ts +++ b/learn/character-profiler.ts @@ -30,9 +30,9 @@ export class CharacterProfiler { const friendlyScore = this.getInterestScoreForFriendlies(c); // tslint:disable-next-line: number-literal-format binary-expression-operand-order - const score = ((1.0 * genderScore) + (1.0 * statusScore) + (1.0 * adScore) + (1.0 * friendlyScore)); + // tslint:disable-next-line: number-literal-format binary-expression-operand-order return (c.status === 'looking') ? score + 10.0 : score; } diff --git a/scss/_chat.scss b/scss/_chat.scss index cdcc64d..cb09a13 100644 --- a/scss/_chat.scss +++ b/scss/_chat.scss @@ -189,7 +189,7 @@ } .messages-both { - .message-ad { + .message-ad:not(.message-score) { background-color: theme-color-level("info", -4); padding: 0 2px 2px 2px; box-shadow: $gray-500 -2px -2px 2px inset;