From fb0b0c0600d4568eeee6e509e6bdbefa73820f61 Mon Sep 17 00:00:00 2001 From: Mia <49593536+mia-pi-git@users.noreply.github.com> Date: Mon, 23 Oct 2023 23:17:10 -0500 Subject: [PATCH] Overhaul the format selector to be more easily used (#2168) * Overhaul the format selector to be more easily used * Update js/client-mainmenu.js Co-authored-by: Kris Johnson <11083252+KrisXV@users.noreply.github.com> * Lower search pop open limit --------- Co-authored-by: Kris Johnson <11083252+KrisXV@users.noreply.github.com> --- js/client-mainmenu.js | 53 +++++++++++++++++++++++++++++++++++++++---- 1 file changed, 48 insertions(+), 5 deletions(-) diff --git a/js/client-mainmenu.js b/js/client-mainmenu.js index d83c7f88c4b..fa95111cc76 100644 --- a/js/client-mainmenu.js +++ b/js/client-mainmenu.js @@ -1224,16 +1224,42 @@ }); var FormatPopup = this.FormatPopup = this.Popup.extend({ + events: { + 'keyup input': 'updateSearch', + 'click details': 'updateOpen', + }, initialize: function (data) { - var curFormat = data.format; + this.data = data; + if (!this.open) { + // todo: maybe make this configurable? not sure since it will cache what users toggle. + // avoiding that decision for now because it requires either an ugly hack + // or an overhaul of BattleFormats. + this.open = Storage.prefs('openformats') || { + "S/V Singles": true, "S/V Doubles": true, "National Dex": true, "OM of the Month": true, + "Other Metagames": true, "Randomized Format Spotlight": true, "RoA Spotlight": true, + }; + } + if (!this.search) this.search = ""; this.onselect = data.onselect; + + var html = '
'; + html += this.renderFormats(); + html += ''; + this.$el.html(html); + }, + renderFormats: function () { + var data = this.data; + var curFormat = data.format; var selectType = data.selectType; if (!selectType) selectType = (this.sourceEl.closest('form').data('search') ? 'search' : 'challenge'); + var bufs = []; var curBuf = 0; if (selectType === 'watch') { bufs[1] = ''; } + var curSection = ''; for (var i in BattleFormats) { var format = BattleFormats[i]; @@ -1245,6 +1271,7 @@ } if (format.section && format.section !== curSection) { + if (curSection) bufs[curBuf] += ''; curSection = format.section; if (!app.supports['formatColumns']) { curBuf = (curSection === 'Doubles' || curSection === 'Past Generations') ? 2 : 1; @@ -1254,9 +1281,13 @@ if (!bufs[curBuf]) { bufs[curBuf] = ''; } - bufs[curBuf] += '';
+ bufs[curBuf] += BattleLog.escapeHTML(curSection) + '
';
}
var formatName = BattleLog.escapeFormat(format.id);
+ if (this.search && !format.id.includes(toID(this.search))) continue;
if (formatName.charAt(0) !== '[') formatName = '[Gen 6] ' + formatName;
formatName = formatName.replace('[Gen 9] ', '');
formatName = formatName.replace('[Gen 9 ', '[');
@@ -1264,7 +1295,6 @@
formatName = formatName.replace('[Gen 7 ', '[');
bufs[curBuf] += '';
}
-
var html = '';
for (var i = 1, l = bufs.length; i < l; i++) {
html += ' ';
}
- html += '';
- this.$el.html(html);
+ return html;
+ },
+ update: function () {
+ var $formatEl = this.$el.find('span[name=formats]');
+ $formatEl.empty();
+ $formatEl.html(this.renderFormats());
+ },
+ updateOpen: function (ev) {
+ var section = $(ev.currentTarget).attr('section');
+ this.open[section] = !this.open[section];
+ Storage.prefs('openformats', this.open);
+ },
+ updateSearch: function (event) {
+ this.search = $(event.currentTarget).val();
+ this.update();
},
selectFormat: function (format) {
if (this.onselect) {