Skip to content

Commit

Permalink
User badges
Browse files Browse the repository at this point in the history
  • Loading branch information
Natsumi-sama committed Dec 5, 2024
1 parent 32a16eb commit ba63b80
Show file tree
Hide file tree
Showing 6 changed files with 133 additions and 8 deletions.
102 changes: 97 additions & 5 deletions html/src/app.js
Original file line number Diff line number Diff line change
Expand Up @@ -688,6 +688,22 @@ speechSynthesis.getVoices();
}
}
}
if (
ref.$isVRCPlus &&
ref.badges &&
ref.badges.every((x) => x.badgeName !== 'Supporter')
) {
// I doubt this will last long
ref.badges.unshift({
badgeId: 'bdg_system_supporter',
badgeName: 'Supporter',
badgeDescription: 'Supports VRChat through VRC+',
badgeImageUrl:
'https://assets.vrchat.com/badges/fa/bdgai_8c9cf371-ffd2-4177-9894-1093e2e34bf7.png',
hidden: true,
showcased: false
});
}
var friendCtx = $app.friends.get(ref.id);
if (friendCtx) {
friendCtx.ref = ref;
Expand Down Expand Up @@ -1373,6 +1389,10 @@ speechSynthesis.getVoices();

API.$on('FRIEND:LIST', function (args) {
for (var json of args.json) {
if (!json.displayName) {
console.error('/friends gave us garbage', json);
continue;
}
this.$emit('USER', {
json,
params: {
Expand Down Expand Up @@ -3905,6 +3925,7 @@ speechSynthesis.getVoices();
)}</strong>!`
}).show();
$app.$refs.menu.activeIndex = 'feed';
$app.updateStoredUser(this.currentUser);
});

API.$on('LOGOUT', async function () {
Expand Down Expand Up @@ -7036,7 +7057,11 @@ speechSynthesis.getVoices();
};

$app.methods.addFriendship = function (id) {
if (!this.friendLogInitStatus || this.friendLog.has(id) || id === API.currentUser.id) {
if (
!this.friendLogInitStatus ||
this.friendLog.has(id) ||
id === API.currentUser.id
) {
return;
}
var ref = API.cachedUsers.get(id);
Expand Down Expand Up @@ -7111,7 +7136,7 @@ speechSynthesis.getVoices();
created_at: new Date().toJSON(),
type: 'Unfriend',
userId: id,
displayName: ctx.displayName
displayName: ctx.displayName || id
};
this.friendLogTable.data.push(friendLogHistory);
database.addFriendLogHistory(friendLogHistory);
Expand Down Expand Up @@ -12671,6 +12696,14 @@ speechSynthesis.getVoices();
D.visible = true;
};

$app.methods.newInstanceTabClick = function (tab) {
if (tab === '1') {
this.buildInstance();
} else {
this.buildLegacyInstance();
}
};

$app.methods.makeHome = function (tag) {
this.$confirm('Continue? Make Home', 'Confirm', {
confirmButtonText: 'Confirm',
Expand Down Expand Up @@ -13318,7 +13351,9 @@ speechSynthesis.getVoices();
L.instanceType !== 'public' &&
L.groupAccessType !== 'public'
) {
args.push(`vrchat://launch?id=${location}&shortName=${shortName}`);
args.push(
`vrchat://launch?ref=vrcx.app&id=${location}&shortName=${shortName}`
);
} else {
// fetch shortName
var newShortName = '';
Expand All @@ -13335,10 +13370,10 @@ speechSynthesis.getVoices();
}
if (newShortName) {
args.push(
`vrchat://launch?id=${location}&shortName=${newShortName}`
`vrchat://launch?ref=vrcx.app&id=${location}&shortName=${newShortName}`
);
} else {
args.push(`vrchat://launch?id=${location}`);
args.push(`vrchat://launch?ref=vrcx.app&id=${location}`);
}
}
var { launchArguments, vrcLaunchPathOverride } =
Expand Down Expand Up @@ -22200,6 +22235,63 @@ speechSynthesis.getVoices();

$app.data.ossDialog = false;

// #region | App: Badges

API.updateBadge = function (params) {
return this.call(
`users/${API.currentUser.id}/badges/${params.badgeId}`,
{
method: 'PUT',
params: {
userId: API.currentUser.id,
badgeId: params.badgeId,
hidden: params.hidden,
showcased: params.showcased
}
}
).then((json) => {
var args = {
json,
params
};
this.$emit('BADGE:UPDATE', args);
return args;
});
};

API.$on('BADGE:UPDATE', function (args) {
if (args.json) {
$app.$message({
message: 'Badge updated',
type: 'success'
});
}
});

$app.methods.toggleBadgeVisibility = function (badge) {
if (badge.hidden) {
badge.showcased = false;
}
API.updateBadge({
badgeId: badge.badgeId,
hidden: badge.hidden,
showcased: badge.showcased
});
};

$app.methods.toggleBadgeShowcased = function (badge) {
if (badge.showcased) {
badge.hidden = false;
}
API.updateBadge({
badgeId: badge.badgeId,
hidden: badge.hidden,
showcased: badge.showcased
});
};

// #endregion

// "$app" is being replaced by Vue, update references inside all the classes
$app = new Vue($app);
window.$app = $app;
Expand Down
8 changes: 8 additions & 0 deletions html/src/app.scss
Original file line number Diff line number Diff line change
Expand Up @@ -408,6 +408,14 @@ img.friends-list-avatar {
filter: none;
}

.x-user-badge-hidden {
filter: grayscale(1);
}

.x-user-badge:hover {
filter: none;
}

.x-friend-item > .avatar.online.mobile > img,
.x-friend-item > .avatar.joinme.mobile > img,
.x-friend-item > .avatar.askme.mobile > img,
Expand Down
5 changes: 5 additions & 0 deletions html/src/localization/en/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -571,6 +571,11 @@
"friend_no": "Friend No.{number}",
"vrchat_team": "VRChat Team"
},
"badges": {
"assigned": "Assigned",
"hidden": "Hidden",
"showcased": "Showcased"
},
"actions": {
"favorite_tooltip": "Add to favorites",
"unfavorite_tooltip": "Remove from favorites",
Expand Down
2 changes: 1 addition & 1 deletion html/src/mixins/dialogs/newInstance.pug
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
mixin newInstance()
el-dialog.x-dialog(:before-close="beforeDialogClose" @mousedown.native="dialogMouseDown" @mouseup.native="dialogMouseUp" ref="newInstanceDialog" :visible.sync="newInstanceDialog.visible" :title="$t('dialog.new_instance.header')" width="650px")
el-tabs(type="card" v-model="newInstanceDialog.selectedTab")
el-tabs(type="card" v-model="newInstanceDialog.selectedTab" @tab-click="newInstanceTabClick")
el-tab-pane(:label="$t('dialog.new_instance.normal')")
el-form(v-if="newInstanceDialog.visible" :model="newInstanceDialog" label-width="150px")
el-form-item(:label="$t('dialog.new_instance.access_type')")
Expand Down
23 changes: 21 additions & 2 deletions html/src/mixins/dialogs/userDialog.pug
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ mixin userDialog()
el-popover(placement="top" trigger="click")
span.x-grey(slot="reference" v-text="API.currentUser.username" style="margin-right:10px;font-family:monospace;font-size:12px;cursor:pointer")
span(style="display:block;text-align:center;font-family:monospace") {{ API.currentUser.username | textToHex }}
div
div(style="margin-top:5px")
el-tag.name(type="info" effect="plain" size="mini" :class="userDialog.ref.$trustClass" v-text="userDialog.ref.$trustLevel" style="margin-right:5px;margin-top:5px")
el-tag.x-tag-friend(v-if="userDialog.isFriend && userDialog.friend" type="info" effect="plain" size="mini" style="margin-right:5px;margin-top:5px") {{ $t('dialog.user.tags.friend_no', { number: userDialog.friend.no }) }}
el-tag.x-tag-troll(v-if="userDialog.ref.$isTroll" type="info" effect="plain" size="mini" style="margin-right:5px;margin-top:5px") Nuisance
Expand All @@ -55,8 +55,27 @@ mixin userDialog()
el-tag.x-tag-platform-ios(v-else-if="userDialog.ref.last_platform === 'ios'" type="info" effect="plain" size="mini" style="margin-right:5px;margin-top:5px") iOS
el-tag.x-tag-platform-other(v-else-if="userDialog.ref.last_platform" type="info" effect="plain" size="mini" style="margin-right:5px;margin-top:5px") {{ userDialog.ref.last_platform }}
el-tag.x-tag-age-verification(v-if="userDialog.ref.ageVerificationStatus && userDialog.ref.ageVerificationStatus !== 'hidden'" type="info" effect="plain" size="mini" style="margin-right:5px;margin-top:5px") {{ userDialog.ref.ageVerificationStatus }}
el-tag.x-tag-vrcplus(v-if="userDialog.ref.$isVRCPlus" type="info" effect="plain" size="mini" style="margin-right:5px;margin-top:5px") VRC+
el-tag.name(v-if="userDialog.ref.$customTag" type="info" effect="plain" size="mini" v-text="userDialog.ref.$customTag" :style="{'color':userDialog.ref.$customTagColour, 'border-color':userDialog.ref.$customTagColour}" style="margin-right:5px;margin-top:5px")
br
template(v-for="badge in userDialog.ref.badges")
el-tooltip(placement="top")
template(#content)
span {{ badge.badgeName }}
span(v-if="badge.hidden") &nbsp;(Hidden)
el-popover(placement="right" width="300px" trigger="click")
img.x-link.x-user-badge(slot="reference" v-lazy="badge.badgeImageUrl" style="flex:none;height:32px;width:32px;border-radius:3px;object-fit:cover;margin-top:5px;margin-right:5px" :class="{'x-user-badge-hidden':badge.hidden}")
img.x-link(v-lazy="badge.badgeImageUrl" style="height:300px" @click="showFullscreenImageDialog(badge.badgeImageUrl)")
br
span {{ badge.badgeName }}
br
span.x-grey(style="font-size:12px") {{ badge.badgeDescription }}
br
span.x-grey(v-if="badge.assignedAt" style="font-family:monospace;font-size:12px") {{ $t('dialog.user.badges.assigned') }}: {{ badge.assignedAt | formatDate('long') }}
template(v-if="userDialog.id === API.currentUser.id")
br
el-checkbox(@change="toggleBadgeVisibility(badge)" v-model="badge.hidden" style="margin-top:5px") {{ $t('dialog.user.badges.hidden') }}
br
el-checkbox(@change="toggleBadgeShowcased(badge)" v-model="badge.showcased" style="margin-top:5px") {{ $t('dialog.user.badges.showcased') }}
div(style="margin-top:5px")
span(v-text="userDialog.ref.statusDescription" style="font-size:12px")
div(v-if="userDialog.ref.userIcon" style="flex:none;margin-right:10px")
Expand Down
1 change: 1 addition & 0 deletions html/src/theme.dark.scss
Original file line number Diff line number Diff line change
Expand Up @@ -258,6 +258,7 @@ button {
}

.el-popover {
color: #c8c8c8;
background-color: #333;
border-color: #5f5f5f;
}
Expand Down

0 comments on commit ba63b80

Please sign in to comment.