From afe95ebda14507473e66d010e05fe70e2545ad30 Mon Sep 17 00:00:00 2001 From: winprn Date: Wed, 18 Oct 2023 16:40:05 +0700 Subject: [PATCH 1/7] add option to filter by university groups: HSG, Institution, Guest --- judge/jinja2/reference.py | 2 +- .../commands/batch_add_icpc_team.py | 9 +- judge/migrations/0199_auto_20231018_0702.py | 29 ++++++ judge/models/profile.py | 2 + judge/views/contests.py | 3 +- resources/contest.scss | 2 +- templates/contest/media-icpc-css.html | 10 ++ templates/contest/ranking.html | 98 +++++++++++++++++-- templates/user/base-users-table.html | 2 +- 9 files changed, 143 insertions(+), 14 deletions(-) mode change 100644 => 100755 judge/management/commands/batch_add_icpc_team.py create mode 100644 judge/migrations/0199_auto_20231018_0702.py diff --git a/judge/jinja2/reference.py b/judge/jinja2/reference.py index 4b5a99914..912f4c544 100644 --- a/judge/jinja2/reference.py +++ b/judge/jinja2/reference.py @@ -160,7 +160,7 @@ def link_user(user): else: display_badge_img = '' - return mark_safe(f'' + return mark_safe(f'' f'' f'{escape(profile.display_name)}{display_badge_img}') diff --git a/judge/management/commands/batch_add_icpc_team.py b/judge/management/commands/batch_add_icpc_team.py old mode 100644 new mode 100755 index 157557194..a8250f989 --- a/judge/management/commands/batch_add_icpc_team.py +++ b/judge/management/commands/batch_add_icpc_team.py @@ -18,7 +18,7 @@ def generate_password(): return ''.join(secrets.choice(ALPHABET) for _ in range(8)) -def add_user(username, teamname, password, org, internalid): +def add_user(username, teamname, password, org, org_group, internalid): usr = User(username=username, is_active=True) usr.set_password(password) usr.save() @@ -28,6 +28,7 @@ def add_user(username, teamname, password, org, internalid): profile.language = Language.objects.get(key=settings.DEFAULT_USER_LANGUAGE) profile.site_theme = 'light' profile.notes = internalid # save the internal id for later use. + profile.group = org_group profile.save() profile.organizations.set([org]) @@ -68,7 +69,7 @@ def handle(self, *args, **options): prefix = options['prefix'] reader = csv.DictReader(fin) - writer = csv.DictWriter(fout, fieldnames=['username', 'teamname', 'password']) + writer = csv.DictWriter(fout, fieldnames=['username', 'teamname', 'password', 'group']) writer.writeheader() for cnt, row in enumerate(reader, start=1): @@ -77,13 +78,15 @@ def handle(self, *args, **options): org = get_org(row['instName']) password = generate_password() internalid = row['id'] + org_group = row['group'] - add_user(username, teamname, password, org, internalid) + add_user(username, teamname, password, org, org_group, internalid) writer.writerow({ 'username': username, 'teamname': teamname, 'password': password, + 'group': org_group }) fin.close() diff --git a/judge/migrations/0199_auto_20231018_0702.py b/judge/migrations/0199_auto_20231018_0702.py new file mode 100644 index 000000000..6dd14b817 --- /dev/null +++ b/judge/migrations/0199_auto_20231018_0702.py @@ -0,0 +1,29 @@ +# Generated by Django 3.2.22 on 2023-10-18 07:02 + +from django.db import migrations, models +import judge.models.problem + + +class Migration(migrations.Migration): + + dependencies = [ + ('judge', '0198_add_ranking_stop_last_minutes'), + ] + + operations = [ + migrations.AddField( + model_name='profile', + name='group', + field=models.TextField(blank=True, null=True, verbose_name='uni group'), + ), + migrations.AlterField( + model_name='problem', + name='name', + field=models.CharField(db_index=True, help_text='The full name of the problem, as shown in the problem list.', max_length=100, validators=[judge.models.problem.disallowed_characters_validator], verbose_name='problem name'), + ), + migrations.AlterField( + model_name='profile', + name='timezone', + field=models.CharField(choices=[('Africa', [('Africa/Abidjan', 'Abidjan'), ('Africa/Accra', 'Accra'), ('Africa/Addis_Ababa', 'Addis_Ababa'), ('Africa/Algiers', 'Algiers'), ('Africa/Asmara', 'Asmara'), ('Africa/Asmera', 'Asmera'), ('Africa/Bamako', 'Bamako'), ('Africa/Bangui', 'Bangui'), ('Africa/Banjul', 'Banjul'), ('Africa/Bissau', 'Bissau'), ('Africa/Blantyre', 'Blantyre'), ('Africa/Brazzaville', 'Brazzaville'), ('Africa/Bujumbura', 'Bujumbura'), ('Africa/Cairo', 'Cairo'), ('Africa/Casablanca', 'Casablanca'), ('Africa/Ceuta', 'Ceuta'), ('Africa/Conakry', 'Conakry'), ('Africa/Dakar', 'Dakar'), ('Africa/Dar_es_Salaam', 'Dar_es_Salaam'), ('Africa/Djibouti', 'Djibouti'), ('Africa/Douala', 'Douala'), ('Africa/El_Aaiun', 'El_Aaiun'), ('Africa/Freetown', 'Freetown'), ('Africa/Gaborone', 'Gaborone'), ('Africa/Harare', 'Harare'), ('Africa/Johannesburg', 'Johannesburg'), ('Africa/Juba', 'Juba'), ('Africa/Kampala', 'Kampala'), ('Africa/Khartoum', 'Khartoum'), ('Africa/Kigali', 'Kigali'), ('Africa/Kinshasa', 'Kinshasa'), ('Africa/Lagos', 'Lagos'), ('Africa/Libreville', 'Libreville'), ('Africa/Lome', 'Lome'), ('Africa/Luanda', 'Luanda'), ('Africa/Lubumbashi', 'Lubumbashi'), ('Africa/Lusaka', 'Lusaka'), ('Africa/Malabo', 'Malabo'), ('Africa/Maputo', 'Maputo'), ('Africa/Maseru', 'Maseru'), ('Africa/Mbabane', 'Mbabane'), ('Africa/Mogadishu', 'Mogadishu'), ('Africa/Monrovia', 'Monrovia'), ('Africa/Nairobi', 'Nairobi'), ('Africa/Ndjamena', 'Ndjamena'), ('Africa/Niamey', 'Niamey'), ('Africa/Nouakchott', 'Nouakchott'), ('Africa/Ouagadougou', 'Ouagadougou'), ('Africa/Porto-Novo', 'Porto-Novo'), ('Africa/Sao_Tome', 'Sao_Tome'), ('Africa/Timbuktu', 'Timbuktu'), ('Africa/Tripoli', 'Tripoli'), ('Africa/Tunis', 'Tunis'), ('Africa/Windhoek', 'Windhoek')]), ('America', [('America/Adak', 'Adak'), ('America/Anchorage', 'Anchorage'), ('America/Anguilla', 'Anguilla'), ('America/Antigua', 'Antigua'), ('America/Araguaina', 'Araguaina'), ('America/Argentina/Buenos_Aires', 'Argentina/Buenos_Aires'), ('America/Argentina/Catamarca', 'Argentina/Catamarca'), ('America/Argentina/ComodRivadavia', 'Argentina/ComodRivadavia'), ('America/Argentina/Cordoba', 'Argentina/Cordoba'), ('America/Argentina/Jujuy', 'Argentina/Jujuy'), ('America/Argentina/La_Rioja', 'Argentina/La_Rioja'), ('America/Argentina/Mendoza', 'Argentina/Mendoza'), ('America/Argentina/Rio_Gallegos', 'Argentina/Rio_Gallegos'), ('America/Argentina/Salta', 'Argentina/Salta'), ('America/Argentina/San_Juan', 'Argentina/San_Juan'), ('America/Argentina/San_Luis', 'Argentina/San_Luis'), ('America/Argentina/Tucuman', 'Argentina/Tucuman'), ('America/Argentina/Ushuaia', 'Argentina/Ushuaia'), ('America/Aruba', 'Aruba'), ('America/Asuncion', 'Asuncion'), ('America/Atikokan', 'Atikokan'), ('America/Atka', 'Atka'), ('America/Bahia', 'Bahia'), ('America/Bahia_Banderas', 'Bahia_Banderas'), ('America/Barbados', 'Barbados'), ('America/Belem', 'Belem'), ('America/Belize', 'Belize'), ('America/Blanc-Sablon', 'Blanc-Sablon'), ('America/Boa_Vista', 'Boa_Vista'), ('America/Bogota', 'Bogota'), ('America/Boise', 'Boise'), ('America/Buenos_Aires', 'Buenos_Aires'), ('America/Cambridge_Bay', 'Cambridge_Bay'), ('America/Campo_Grande', 'Campo_Grande'), ('America/Cancun', 'Cancun'), ('America/Caracas', 'Caracas'), ('America/Catamarca', 'Catamarca'), ('America/Cayenne', 'Cayenne'), ('America/Cayman', 'Cayman'), ('America/Chicago', 'Chicago'), ('America/Chihuahua', 'Chihuahua'), ('America/Ciudad_Juarez', 'Ciudad_Juarez'), ('America/Coral_Harbour', 'Coral_Harbour'), ('America/Cordoba', 'Cordoba'), ('America/Costa_Rica', 'Costa_Rica'), ('America/Creston', 'Creston'), ('America/Cuiaba', 'Cuiaba'), ('America/Curacao', 'Curacao'), ('America/Danmarkshavn', 'Danmarkshavn'), ('America/Dawson', 'Dawson'), ('America/Dawson_Creek', 'Dawson_Creek'), ('America/Denver', 'Denver'), ('America/Detroit', 'Detroit'), ('America/Dominica', 'Dominica'), ('America/Edmonton', 'Edmonton'), ('America/Eirunepe', 'Eirunepe'), ('America/El_Salvador', 'El_Salvador'), ('America/Ensenada', 'Ensenada'), ('America/Fort_Nelson', 'Fort_Nelson'), ('America/Fort_Wayne', 'Fort_Wayne'), ('America/Fortaleza', 'Fortaleza'), ('America/Glace_Bay', 'Glace_Bay'), ('America/Godthab', 'Godthab'), ('America/Goose_Bay', 'Goose_Bay'), ('America/Grand_Turk', 'Grand_Turk'), ('America/Grenada', 'Grenada'), ('America/Guadeloupe', 'Guadeloupe'), ('America/Guatemala', 'Guatemala'), ('America/Guayaquil', 'Guayaquil'), ('America/Guyana', 'Guyana'), ('America/Halifax', 'Halifax'), ('America/Havana', 'Havana'), ('America/Hermosillo', 'Hermosillo'), ('America/Indiana/Indianapolis', 'Indiana/Indianapolis'), ('America/Indiana/Knox', 'Indiana/Knox'), ('America/Indiana/Marengo', 'Indiana/Marengo'), ('America/Indiana/Petersburg', 'Indiana/Petersburg'), ('America/Indiana/Tell_City', 'Indiana/Tell_City'), ('America/Indiana/Vevay', 'Indiana/Vevay'), ('America/Indiana/Vincennes', 'Indiana/Vincennes'), ('America/Indiana/Winamac', 'Indiana/Winamac'), ('America/Indianapolis', 'Indianapolis'), ('America/Inuvik', 'Inuvik'), ('America/Iqaluit', 'Iqaluit'), ('America/Jamaica', 'Jamaica'), ('America/Jujuy', 'Jujuy'), ('America/Juneau', 'Juneau'), ('America/Kentucky/Louisville', 'Kentucky/Louisville'), ('America/Kentucky/Monticello', 'Kentucky/Monticello'), ('America/Knox_IN', 'Knox_IN'), ('America/Kralendijk', 'Kralendijk'), ('America/La_Paz', 'La_Paz'), ('America/Lima', 'Lima'), ('America/Los_Angeles', 'Los_Angeles'), ('America/Louisville', 'Louisville'), ('America/Lower_Princes', 'Lower_Princes'), ('America/Maceio', 'Maceio'), ('America/Managua', 'Managua'), ('America/Manaus', 'Manaus'), ('America/Marigot', 'Marigot'), ('America/Martinique', 'Martinique'), ('America/Matamoros', 'Matamoros'), ('America/Mazatlan', 'Mazatlan'), ('America/Mendoza', 'Mendoza'), ('America/Menominee', 'Menominee'), ('America/Merida', 'Merida'), ('America/Metlakatla', 'Metlakatla'), ('America/Mexico_City', 'Mexico_City'), ('America/Miquelon', 'Miquelon'), ('America/Moncton', 'Moncton'), ('America/Monterrey', 'Monterrey'), ('America/Montevideo', 'Montevideo'), ('America/Montreal', 'Montreal'), ('America/Montserrat', 'Montserrat'), ('America/Nassau', 'Nassau'), ('America/New_York', 'New_York'), ('America/Nipigon', 'Nipigon'), ('America/Nome', 'Nome'), ('America/Noronha', 'Noronha'), ('America/North_Dakota/Beulah', 'North_Dakota/Beulah'), ('America/North_Dakota/Center', 'North_Dakota/Center'), ('America/North_Dakota/New_Salem', 'North_Dakota/New_Salem'), ('America/Nuuk', 'Nuuk'), ('America/Ojinaga', 'Ojinaga'), ('America/Panama', 'Panama'), ('America/Pangnirtung', 'Pangnirtung'), ('America/Paramaribo', 'Paramaribo'), ('America/Phoenix', 'Phoenix'), ('America/Port-au-Prince', 'Port-au-Prince'), ('America/Port_of_Spain', 'Port_of_Spain'), ('America/Porto_Acre', 'Porto_Acre'), ('America/Porto_Velho', 'Porto_Velho'), ('America/Puerto_Rico', 'Puerto_Rico'), ('America/Punta_Arenas', 'Punta_Arenas'), ('America/Rainy_River', 'Rainy_River'), ('America/Rankin_Inlet', 'Rankin_Inlet'), ('America/Recife', 'Recife'), ('America/Regina', 'Regina'), ('America/Resolute', 'Resolute'), ('America/Rio_Branco', 'Rio_Branco'), ('America/Rosario', 'Rosario'), ('America/Santa_Isabel', 'Santa_Isabel'), ('America/Santarem', 'Santarem'), ('America/Santiago', 'Santiago'), ('America/Santo_Domingo', 'Santo_Domingo'), ('America/Sao_Paulo', 'Sao_Paulo'), ('America/Scoresbysund', 'Scoresbysund'), ('America/Shiprock', 'Shiprock'), ('America/Sitka', 'Sitka'), ('America/St_Barthelemy', 'St_Barthelemy'), ('America/St_Johns', 'St_Johns'), ('America/St_Kitts', 'St_Kitts'), ('America/St_Lucia', 'St_Lucia'), ('America/St_Thomas', 'St_Thomas'), ('America/St_Vincent', 'St_Vincent'), ('America/Swift_Current', 'Swift_Current'), ('America/Tegucigalpa', 'Tegucigalpa'), ('America/Thule', 'Thule'), ('America/Thunder_Bay', 'Thunder_Bay'), ('America/Tijuana', 'Tijuana'), ('America/Toronto', 'Toronto'), ('America/Tortola', 'Tortola'), ('America/Vancouver', 'Vancouver'), ('America/Virgin', 'Virgin'), ('America/Whitehorse', 'Whitehorse'), ('America/Winnipeg', 'Winnipeg'), ('America/Yakutat', 'Yakutat'), ('America/Yellowknife', 'Yellowknife')]), ('Antarctica', [('Antarctica/Casey', 'Casey'), ('Antarctica/Davis', 'Davis'), ('Antarctica/DumontDUrville', 'DumontDUrville'), ('Antarctica/Macquarie', 'Macquarie'), ('Antarctica/Mawson', 'Mawson'), ('Antarctica/McMurdo', 'McMurdo'), ('Antarctica/Palmer', 'Palmer'), ('Antarctica/Rothera', 'Rothera'), ('Antarctica/South_Pole', 'South_Pole'), ('Antarctica/Syowa', 'Syowa'), ('Antarctica/Troll', 'Troll'), ('Antarctica/Vostok', 'Vostok')]), ('Arctic', [('Arctic/Longyearbyen', 'Longyearbyen')]), ('Asia', [('Asia/Aden', 'Aden'), ('Asia/Almaty', 'Almaty'), ('Asia/Amman', 'Amman'), ('Asia/Anadyr', 'Anadyr'), ('Asia/Aqtau', 'Aqtau'), ('Asia/Aqtobe', 'Aqtobe'), ('Asia/Ashgabat', 'Ashgabat'), ('Asia/Ashkhabad', 'Ashkhabad'), ('Asia/Atyrau', 'Atyrau'), ('Asia/Baghdad', 'Baghdad'), ('Asia/Bahrain', 'Bahrain'), ('Asia/Baku', 'Baku'), ('Asia/Bangkok', 'Bangkok'), ('Asia/Barnaul', 'Barnaul'), ('Asia/Beirut', 'Beirut'), ('Asia/Bishkek', 'Bishkek'), ('Asia/Brunei', 'Brunei'), ('Asia/Calcutta', 'Calcutta'), ('Asia/Chita', 'Chita'), ('Asia/Choibalsan', 'Choibalsan'), ('Asia/Chongqing', 'Chongqing'), ('Asia/Chungking', 'Chungking'), ('Asia/Colombo', 'Colombo'), ('Asia/Dacca', 'Dacca'), ('Asia/Damascus', 'Damascus'), ('Asia/Dhaka', 'Dhaka'), ('Asia/Dili', 'Dili'), ('Asia/Dubai', 'Dubai'), ('Asia/Dushanbe', 'Dushanbe'), ('Asia/Famagusta', 'Famagusta'), ('Asia/Gaza', 'Gaza'), ('Asia/Harbin', 'Harbin'), ('Asia/Hebron', 'Hebron'), ('Asia/Ho_Chi_Minh', 'Ho_Chi_Minh'), ('Asia/Hong_Kong', 'Hong_Kong'), ('Asia/Hovd', 'Hovd'), ('Asia/Irkutsk', 'Irkutsk'), ('Asia/Istanbul', 'Istanbul'), ('Asia/Jakarta', 'Jakarta'), ('Asia/Jayapura', 'Jayapura'), ('Asia/Jerusalem', 'Jerusalem'), ('Asia/Kabul', 'Kabul'), ('Asia/Kamchatka', 'Kamchatka'), ('Asia/Karachi', 'Karachi'), ('Asia/Kashgar', 'Kashgar'), ('Asia/Kathmandu', 'Kathmandu'), ('Asia/Katmandu', 'Katmandu'), ('Asia/Khandyga', 'Khandyga'), ('Asia/Kolkata', 'Kolkata'), ('Asia/Krasnoyarsk', 'Krasnoyarsk'), ('Asia/Kuala_Lumpur', 'Kuala_Lumpur'), ('Asia/Kuching', 'Kuching'), ('Asia/Kuwait', 'Kuwait'), ('Asia/Macao', 'Macao'), ('Asia/Macau', 'Macau'), ('Asia/Magadan', 'Magadan'), ('Asia/Makassar', 'Makassar'), ('Asia/Manila', 'Manila'), ('Asia/Muscat', 'Muscat'), ('Asia/Nicosia', 'Nicosia'), ('Asia/Novokuznetsk', 'Novokuznetsk'), ('Asia/Novosibirsk', 'Novosibirsk'), ('Asia/Omsk', 'Omsk'), ('Asia/Oral', 'Oral'), ('Asia/Phnom_Penh', 'Phnom_Penh'), ('Asia/Pontianak', 'Pontianak'), ('Asia/Pyongyang', 'Pyongyang'), ('Asia/Qatar', 'Qatar'), ('Asia/Qostanay', 'Qostanay'), ('Asia/Qyzylorda', 'Qyzylorda'), ('Asia/Rangoon', 'Rangoon'), ('Asia/Riyadh', 'Riyadh'), ('Asia/Saigon', 'Saigon'), ('Asia/Sakhalin', 'Sakhalin'), ('Asia/Samarkand', 'Samarkand'), ('Asia/Seoul', 'Seoul'), ('Asia/Shanghai', 'Shanghai'), ('Asia/Singapore', 'Singapore'), ('Asia/Srednekolymsk', 'Srednekolymsk'), ('Asia/Taipei', 'Taipei'), ('Asia/Tashkent', 'Tashkent'), ('Asia/Tbilisi', 'Tbilisi'), ('Asia/Tehran', 'Tehran'), ('Asia/Tel_Aviv', 'Tel_Aviv'), ('Asia/Thimbu', 'Thimbu'), ('Asia/Thimphu', 'Thimphu'), ('Asia/Tokyo', 'Tokyo'), ('Asia/Tomsk', 'Tomsk'), ('Asia/Ujung_Pandang', 'Ujung_Pandang'), ('Asia/Ulaanbaatar', 'Ulaanbaatar'), ('Asia/Ulan_Bator', 'Ulan_Bator'), ('Asia/Urumqi', 'Urumqi'), ('Asia/Ust-Nera', 'Ust-Nera'), ('Asia/Vientiane', 'Vientiane'), ('Asia/Vladivostok', 'Vladivostok'), ('Asia/Yakutsk', 'Yakutsk'), ('Asia/Yangon', 'Yangon'), ('Asia/Yekaterinburg', 'Yekaterinburg'), ('Asia/Yerevan', 'Yerevan')]), ('Atlantic', [('Atlantic/Azores', 'Azores'), ('Atlantic/Bermuda', 'Bermuda'), ('Atlantic/Canary', 'Canary'), ('Atlantic/Cape_Verde', 'Cape_Verde'), ('Atlantic/Faeroe', 'Faeroe'), ('Atlantic/Faroe', 'Faroe'), ('Atlantic/Jan_Mayen', 'Jan_Mayen'), ('Atlantic/Madeira', 'Madeira'), ('Atlantic/Reykjavik', 'Reykjavik'), ('Atlantic/South_Georgia', 'South_Georgia'), ('Atlantic/St_Helena', 'St_Helena'), ('Atlantic/Stanley', 'Stanley')]), ('Australia', [('Australia/ACT', 'ACT'), ('Australia/Adelaide', 'Adelaide'), ('Australia/Brisbane', 'Brisbane'), ('Australia/Broken_Hill', 'Broken_Hill'), ('Australia/Canberra', 'Canberra'), ('Australia/Currie', 'Currie'), ('Australia/Darwin', 'Darwin'), ('Australia/Eucla', 'Eucla'), ('Australia/Hobart', 'Hobart'), ('Australia/LHI', 'LHI'), ('Australia/Lindeman', 'Lindeman'), ('Australia/Lord_Howe', 'Lord_Howe'), ('Australia/Melbourne', 'Melbourne'), ('Australia/NSW', 'NSW'), ('Australia/North', 'North'), ('Australia/Perth', 'Perth'), ('Australia/Queensland', 'Queensland'), ('Australia/South', 'South'), ('Australia/Sydney', 'Sydney'), ('Australia/Tasmania', 'Tasmania'), ('Australia/Victoria', 'Victoria'), ('Australia/West', 'West'), ('Australia/Yancowinna', 'Yancowinna')]), ('Brazil', [('Brazil/Acre', 'Acre'), ('Brazil/DeNoronha', 'DeNoronha'), ('Brazil/East', 'East'), ('Brazil/West', 'West')]), ('Canada', [('Canada/Atlantic', 'Atlantic'), ('Canada/Central', 'Central'), ('Canada/Eastern', 'Eastern'), ('Canada/Mountain', 'Mountain'), ('Canada/Newfoundland', 'Newfoundland'), ('Canada/Pacific', 'Pacific'), ('Canada/Saskatchewan', 'Saskatchewan'), ('Canada/Yukon', 'Yukon')]), ('Chile', [('Chile/Continental', 'Continental'), ('Chile/EasterIsland', 'EasterIsland')]), ('Etc', [('Etc/Greenwich', 'Greenwich'), ('Etc/UCT', 'UCT'), ('Etc/UTC', 'UTC'), ('Etc/Universal', 'Universal'), ('Etc/Zulu', 'Zulu')]), ('Europe', [('Europe/Amsterdam', 'Amsterdam'), ('Europe/Andorra', 'Andorra'), ('Europe/Astrakhan', 'Astrakhan'), ('Europe/Athens', 'Athens'), ('Europe/Belfast', 'Belfast'), ('Europe/Belgrade', 'Belgrade'), ('Europe/Berlin', 'Berlin'), ('Europe/Bratislava', 'Bratislava'), ('Europe/Brussels', 'Brussels'), ('Europe/Bucharest', 'Bucharest'), ('Europe/Budapest', 'Budapest'), ('Europe/Busingen', 'Busingen'), ('Europe/Chisinau', 'Chisinau'), ('Europe/Copenhagen', 'Copenhagen'), ('Europe/Dublin', 'Dublin'), ('Europe/Gibraltar', 'Gibraltar'), ('Europe/Guernsey', 'Guernsey'), ('Europe/Helsinki', 'Helsinki'), ('Europe/Isle_of_Man', 'Isle_of_Man'), ('Europe/Istanbul', 'Istanbul'), ('Europe/Jersey', 'Jersey'), ('Europe/Kaliningrad', 'Kaliningrad'), ('Europe/Kiev', 'Kiev'), ('Europe/Kirov', 'Kirov'), ('Europe/Kyiv', 'Kyiv'), ('Europe/Lisbon', 'Lisbon'), ('Europe/Ljubljana', 'Ljubljana'), ('Europe/London', 'London'), ('Europe/Luxembourg', 'Luxembourg'), ('Europe/Madrid', 'Madrid'), ('Europe/Malta', 'Malta'), ('Europe/Mariehamn', 'Mariehamn'), ('Europe/Minsk', 'Minsk'), ('Europe/Monaco', 'Monaco'), ('Europe/Moscow', 'Moscow'), ('Europe/Nicosia', 'Nicosia'), ('Europe/Oslo', 'Oslo'), ('Europe/Paris', 'Paris'), ('Europe/Podgorica', 'Podgorica'), ('Europe/Prague', 'Prague'), ('Europe/Riga', 'Riga'), ('Europe/Rome', 'Rome'), ('Europe/Samara', 'Samara'), ('Europe/San_Marino', 'San_Marino'), ('Europe/Sarajevo', 'Sarajevo'), ('Europe/Saratov', 'Saratov'), ('Europe/Simferopol', 'Simferopol'), ('Europe/Skopje', 'Skopje'), ('Europe/Sofia', 'Sofia'), ('Europe/Stockholm', 'Stockholm'), ('Europe/Tallinn', 'Tallinn'), ('Europe/Tirane', 'Tirane'), ('Europe/Tiraspol', 'Tiraspol'), ('Europe/Ulyanovsk', 'Ulyanovsk'), ('Europe/Uzhgorod', 'Uzhgorod'), ('Europe/Vaduz', 'Vaduz'), ('Europe/Vatican', 'Vatican'), ('Europe/Vienna', 'Vienna'), ('Europe/Vilnius', 'Vilnius'), ('Europe/Volgograd', 'Volgograd'), ('Europe/Warsaw', 'Warsaw'), ('Europe/Zagreb', 'Zagreb'), ('Europe/Zaporozhye', 'Zaporozhye'), ('Europe/Zurich', 'Zurich')]), ('Indian', [('Indian/Antananarivo', 'Antananarivo'), ('Indian/Chagos', 'Chagos'), ('Indian/Christmas', 'Christmas'), ('Indian/Cocos', 'Cocos'), ('Indian/Comoro', 'Comoro'), ('Indian/Kerguelen', 'Kerguelen'), ('Indian/Mahe', 'Mahe'), ('Indian/Maldives', 'Maldives'), ('Indian/Mauritius', 'Mauritius'), ('Indian/Mayotte', 'Mayotte'), ('Indian/Reunion', 'Reunion')]), ('Mexico', [('Mexico/BajaNorte', 'BajaNorte'), ('Mexico/BajaSur', 'BajaSur'), ('Mexico/General', 'General')]), ('Other', [('CET', 'CET'), ('CST6CDT', 'CST6CDT'), ('Cuba', 'Cuba'), ('EET', 'EET'), ('EST', 'EST'), ('EST5EDT', 'EST5EDT'), ('Egypt', 'Egypt'), ('Eire', 'Eire'), ('GB', 'GB'), ('GB-Eire', 'GB-Eire'), ('Greenwich', 'Greenwich'), ('HST', 'HST'), ('Hongkong', 'Hongkong'), ('Iceland', 'Iceland'), ('Iran', 'Iran'), ('Israel', 'Israel'), ('Jamaica', 'Jamaica'), ('Japan', 'Japan'), ('Kwajalein', 'Kwajalein'), ('Libya', 'Libya'), ('MET', 'MET'), ('MST', 'MST'), ('MST7MDT', 'MST7MDT'), ('NZ', 'NZ'), ('NZ-CHAT', 'NZ-CHAT'), ('Navajo', 'Navajo'), ('PRC', 'PRC'), ('PST8PDT', 'PST8PDT'), ('Poland', 'Poland'), ('Portugal', 'Portugal'), ('ROC', 'ROC'), ('ROK', 'ROK'), ('Singapore', 'Singapore'), ('Turkey', 'Turkey'), ('UCT', 'UCT'), ('UTC', 'UTC'), ('Universal', 'Universal'), ('W-SU', 'W-SU'), ('WET', 'WET'), ('Zulu', 'Zulu')]), ('Pacific', [('Pacific/Apia', 'Apia'), ('Pacific/Auckland', 'Auckland'), ('Pacific/Bougainville', 'Bougainville'), ('Pacific/Chatham', 'Chatham'), ('Pacific/Chuuk', 'Chuuk'), ('Pacific/Easter', 'Easter'), ('Pacific/Efate', 'Efate'), ('Pacific/Enderbury', 'Enderbury'), ('Pacific/Fakaofo', 'Fakaofo'), ('Pacific/Fiji', 'Fiji'), ('Pacific/Funafuti', 'Funafuti'), ('Pacific/Galapagos', 'Galapagos'), ('Pacific/Gambier', 'Gambier'), ('Pacific/Guadalcanal', 'Guadalcanal'), ('Pacific/Guam', 'Guam'), ('Pacific/Honolulu', 'Honolulu'), ('Pacific/Johnston', 'Johnston'), ('Pacific/Kanton', 'Kanton'), ('Pacific/Kiritimati', 'Kiritimati'), ('Pacific/Kosrae', 'Kosrae'), ('Pacific/Kwajalein', 'Kwajalein'), ('Pacific/Majuro', 'Majuro'), ('Pacific/Marquesas', 'Marquesas'), ('Pacific/Midway', 'Midway'), ('Pacific/Nauru', 'Nauru'), ('Pacific/Niue', 'Niue'), ('Pacific/Norfolk', 'Norfolk'), ('Pacific/Noumea', 'Noumea'), ('Pacific/Pago_Pago', 'Pago_Pago'), ('Pacific/Palau', 'Palau'), ('Pacific/Pitcairn', 'Pitcairn'), ('Pacific/Pohnpei', 'Pohnpei'), ('Pacific/Ponape', 'Ponape'), ('Pacific/Port_Moresby', 'Port_Moresby'), ('Pacific/Rarotonga', 'Rarotonga'), ('Pacific/Saipan', 'Saipan'), ('Pacific/Samoa', 'Samoa'), ('Pacific/Tahiti', 'Tahiti'), ('Pacific/Tarawa', 'Tarawa'), ('Pacific/Tongatapu', 'Tongatapu'), ('Pacific/Truk', 'Truk'), ('Pacific/Wake', 'Wake'), ('Pacific/Wallis', 'Wallis'), ('Pacific/Yap', 'Yap')]), ('US', [('US/Alaska', 'Alaska'), ('US/Aleutian', 'Aleutian'), ('US/Arizona', 'Arizona'), ('US/Central', 'Central'), ('US/East-Indiana', 'East-Indiana'), ('US/Eastern', 'Eastern'), ('US/Hawaii', 'Hawaii'), ('US/Indiana-Starke', 'Indiana-Starke'), ('US/Michigan', 'Michigan'), ('US/Mountain', 'Mountain'), ('US/Pacific', 'Pacific'), ('US/Samoa', 'Samoa')])], default='America/Toronto', max_length=50, verbose_name='time zone'), + ), + ] diff --git a/judge/models/profile.py b/judge/models/profile.py index d30c98f51..fe25d4371 100644 --- a/judge/models/profile.py +++ b/judge/models/profile.py @@ -194,6 +194,8 @@ class Profile(models.Model): data_last_downloaded = models.DateTimeField(verbose_name=_('last data download time'), null=True, blank=True) username_display_override = models.CharField(max_length=100, blank=True, verbose_name=_('display name override'), help_text=_('Name displayed in place of username.')) + # For ICPC only + group = models.TextField(verbose_name=_('uni group'), null=True, blank=True) @cached_property def organization(self): diff --git a/judge/views/contests.py b/judge/views/contests.py index 5b1ec5d86..0666a0720 100644 --- a/judge/views/contests.py +++ b/judge/views/contests.py @@ -838,7 +838,7 @@ def get_context_data(self, **kwargs): ContestRankingProfile = namedtuple( 'ContestRankingProfile', - 'id user css_class username points cumtime tiebreaker organization participation ' + 'id user css_class username points cumtime tiebreaker organization participation group ' 'participation_rating problem_cells result_cell virtual display_name', ) @@ -870,6 +870,7 @@ def display_user_problem(contest_problem): participation=participation, virtual=participation.virtual, display_name=user.display_name, + group=user.group, ) diff --git a/resources/contest.scss b/resources/contest.scss index c8840910e..e624c1d1f 100644 --- a/resources/contest.scss +++ b/resources/contest.scss @@ -318,7 +318,7 @@ form.contest-join-pseudotab { } #org-dropdown-check-list { - display: inline-block; + display: flex; } #org-check-list-wrapper { diff --git a/templates/contest/media-icpc-css.html b/templates/contest/media-icpc-css.html index d15fc30d2..8401050a4 100644 --- a/templates/contest/media-icpc-css.html +++ b/templates/contest/media-icpc-css.html @@ -30,4 +30,14 @@ font-size: 1.25em; padding-bottom: -0.75em; } + + tr.top-team span.rating::after { + content: attr(data-user-group); + font-size: 0.75em; + padding: 0.25em; + margin-left: 0.5em; + background-color: #FFC008; + border-radius: 2px; + color: black; + } diff --git a/templates/contest/ranking.html b/templates/contest/ranking.html index 629536aa9..6f0f88426 100644 --- a/templates/contest/ranking.html +++ b/templates/contest/ranking.html @@ -39,6 +39,11 @@ .filter-checklist-button { float: right; } + + .select-container { + display: flex; + gap: 2em; + } {% endblock %} @@ -81,9 +86,10 @@ window.enableAdminOperations(); window.loadOrgLogo(); window.applyFavoriteUsers(); + window.applyTag(); }).always(function () { ranking_outdated = false; - setTimeout(update_ranking, 10000); + // setTimeout(update_ranking, 10000); }); } $(window).on('dmoj:window-visible', function () { @@ -91,7 +97,7 @@ update_ranking(); } }); - setTimeout(update_ranking, 10000); + // setTimeout(update_ranking, 10000); }); {% endif %} @@ -225,6 +231,48 @@ }); }); + $(function() { + $('#tag-check-list').select2({ + theme: '{{ DMOJ_SELECT2_THEME }}', + multiple: true, + closeOnSelect: false, + placeholder: '{{ _('Filter by group') }}', + }); + + const selection = $('#tag-check-list').data().select2.selection; + const results = $('#tag-check-list').data().select2.results; + + $('#tag-check-list').on('select2:selecting', function(e) { + let id = e.params.args.data.id; + let val = $(e.target).val().concat([id]); + $(e.target).val(val).trigger('change'); + + if (selection.$search.val() != '') { + selection.$search.val(''); + selection.trigger('query', {}); + } else { + results.setClasses(); + } + + return false; + }); + + $('#tag-check-list').on('select2:unselecting', function(e) { + const id = e.params.args.data.id; + const val = $(e.target).val().filter(function(v) { return v != id; }); + $(e.target).val(val).trigger('change'); + + if (selection.$search.val() != '') { + selection.$search.val(''); + selection.trigger('query', {}); + } else { + results.setClasses(); + } + + return false; + }); + }) + if (localStorage.getItem(`filter-cleared-${contest_key}`) === null) { localStorage.setItem(`filter-cleared-${contest_key}`, 'true'); } @@ -233,16 +281,23 @@ localStorage.setItem(`filter-selected-orgs-${contest_key}`, []); } + if (localStorage.getItem(`filter-selected-group-${contest_key}`) === null) { + localStorage.setItem(`filter-selected-group-${contest_key}`, ""); + } + $('#apply-organization-filter').click(function () { $('#org-check-list-wrapper').hide(); let selected_orgs = $('#org-check-list').val().map(x => x.trim()); + let selected_group = $('#tag-check-list').val().map(x => x.trim()); localStorage.setItem(`filter-selected-orgs-${contest_key}`, selected_orgs); + localStorage.setItem(`filter-selected-group-${contest_key}`, selected_group); window.applyRankingFilter(); }); $('#clear-organization-filter').click(function () { $('#org-check-list').val(null).trigger('change'); + $('#tag-check-list').val(null).trigger('change'); $('#apply-organization-filter').click(); }); @@ -256,7 +311,7 @@ return; } - if ($('#select2-org-check-list-results').has(e.target).length !== 0) { + if ($('#select2-org-check-list-results').has(e.target).length !== 0 || $('#select2-tag-check-list-results').has(e.target).length !== 0) { return; } @@ -264,6 +319,10 @@ return; } + if ($(e.target).attr('id') && $(e.target).attr('id').startsWith('select2-tag-check-list-result')) { + return; + } + // check if the clicked area is the checklist or not if ($('#org-dropdown-check-list').has(e.target).length === 0) { $('#apply-organization-filter').click(); @@ -324,8 +383,9 @@ let counter = 0; let previous_abs_rank = -1; let selected_orgs = localStorage.getItem(`filter-selected-orgs-${contest_key}`); + let selected_group = localStorage.getItem(`filter-selected-group-${contest_key}`); - if (!selected_orgs.length) { + if (!selected_orgs.length && !selected_group.length) { window.clearRankingFilter(); return; } @@ -336,7 +396,7 @@ let org_anchor = row.find("div > div > .personal-info > .organization > a")[0]; let org = org_anchor ? org_anchor.text : 'Other'; - if (!selected_orgs.includes(org.trim())) { + if (!selected_orgs.includes(org.trim()) && !selected_group.includes(row.data('user-group'))) { row.hide(); return; } @@ -454,6 +514,27 @@ }) } window.loadOrgLogo(); + + window.applyTag = function () { + const groups = []; + $('#ranking-table > tbody > tr[id]').each(function () { + let row = $(this); + + if (groups.findIndex(x => x == row.data('user-group')) == -1) { + row.addClass('top-team'); + groups.push(row.data('user-group')); + } + }); + + let tag_options = $('#tag-check-list'); + tag_options.empty(); + groups.forEach(function (group) { + tag_options.append( + `` + ); + }); + } + window.applyTag(); }); {% if tab == 'ranking' %} @@ -556,11 +637,14 @@
-
+
- +
+ + +
{% endif %} diff --git a/templates/user/base-users-table.html b/templates/user/base-users-table.html index 492738014..7dd23017a 100644 --- a/templates/user/base-users-table.html +++ b/templates/user/base-users-table.html @@ -19,7 +19,7 @@ {% for rank, user in users %} - + {{ rank }} {% block after_rank scoped %}{% endblock %} From acf20a3218a13987956ea9dd4029063317386e1a Mon Sep 17 00:00:00 2001 From: winprn Date: Sat, 21 Oct 2023 20:10:51 +0700 Subject: [PATCH 2/7] small fixes --- judge/migrations/0199_auto_20231018_0702.py | 10 ---------- templates/contest/ranking.html | 4 ++-- 2 files changed, 2 insertions(+), 12 deletions(-) diff --git a/judge/migrations/0199_auto_20231018_0702.py b/judge/migrations/0199_auto_20231018_0702.py index 6dd14b817..5c89dd808 100644 --- a/judge/migrations/0199_auto_20231018_0702.py +++ b/judge/migrations/0199_auto_20231018_0702.py @@ -16,14 +16,4 @@ class Migration(migrations.Migration): name='group', field=models.TextField(blank=True, null=True, verbose_name='uni group'), ), - migrations.AlterField( - model_name='problem', - name='name', - field=models.CharField(db_index=True, help_text='The full name of the problem, as shown in the problem list.', max_length=100, validators=[judge.models.problem.disallowed_characters_validator], verbose_name='problem name'), - ), - migrations.AlterField( - model_name='profile', - name='timezone', - field=models.CharField(choices=[('Africa', [('Africa/Abidjan', 'Abidjan'), ('Africa/Accra', 'Accra'), ('Africa/Addis_Ababa', 'Addis_Ababa'), ('Africa/Algiers', 'Algiers'), ('Africa/Asmara', 'Asmara'), ('Africa/Asmera', 'Asmera'), ('Africa/Bamako', 'Bamako'), ('Africa/Bangui', 'Bangui'), ('Africa/Banjul', 'Banjul'), ('Africa/Bissau', 'Bissau'), ('Africa/Blantyre', 'Blantyre'), ('Africa/Brazzaville', 'Brazzaville'), ('Africa/Bujumbura', 'Bujumbura'), ('Africa/Cairo', 'Cairo'), ('Africa/Casablanca', 'Casablanca'), ('Africa/Ceuta', 'Ceuta'), ('Africa/Conakry', 'Conakry'), ('Africa/Dakar', 'Dakar'), ('Africa/Dar_es_Salaam', 'Dar_es_Salaam'), ('Africa/Djibouti', 'Djibouti'), ('Africa/Douala', 'Douala'), ('Africa/El_Aaiun', 'El_Aaiun'), ('Africa/Freetown', 'Freetown'), ('Africa/Gaborone', 'Gaborone'), ('Africa/Harare', 'Harare'), ('Africa/Johannesburg', 'Johannesburg'), ('Africa/Juba', 'Juba'), ('Africa/Kampala', 'Kampala'), ('Africa/Khartoum', 'Khartoum'), ('Africa/Kigali', 'Kigali'), ('Africa/Kinshasa', 'Kinshasa'), ('Africa/Lagos', 'Lagos'), ('Africa/Libreville', 'Libreville'), ('Africa/Lome', 'Lome'), ('Africa/Luanda', 'Luanda'), ('Africa/Lubumbashi', 'Lubumbashi'), ('Africa/Lusaka', 'Lusaka'), ('Africa/Malabo', 'Malabo'), ('Africa/Maputo', 'Maputo'), ('Africa/Maseru', 'Maseru'), ('Africa/Mbabane', 'Mbabane'), ('Africa/Mogadishu', 'Mogadishu'), ('Africa/Monrovia', 'Monrovia'), ('Africa/Nairobi', 'Nairobi'), ('Africa/Ndjamena', 'Ndjamena'), ('Africa/Niamey', 'Niamey'), ('Africa/Nouakchott', 'Nouakchott'), ('Africa/Ouagadougou', 'Ouagadougou'), ('Africa/Porto-Novo', 'Porto-Novo'), ('Africa/Sao_Tome', 'Sao_Tome'), ('Africa/Timbuktu', 'Timbuktu'), ('Africa/Tripoli', 'Tripoli'), ('Africa/Tunis', 'Tunis'), ('Africa/Windhoek', 'Windhoek')]), ('America', [('America/Adak', 'Adak'), ('America/Anchorage', 'Anchorage'), ('America/Anguilla', 'Anguilla'), ('America/Antigua', 'Antigua'), ('America/Araguaina', 'Araguaina'), ('America/Argentina/Buenos_Aires', 'Argentina/Buenos_Aires'), ('America/Argentina/Catamarca', 'Argentina/Catamarca'), ('America/Argentina/ComodRivadavia', 'Argentina/ComodRivadavia'), ('America/Argentina/Cordoba', 'Argentina/Cordoba'), ('America/Argentina/Jujuy', 'Argentina/Jujuy'), ('America/Argentina/La_Rioja', 'Argentina/La_Rioja'), ('America/Argentina/Mendoza', 'Argentina/Mendoza'), ('America/Argentina/Rio_Gallegos', 'Argentina/Rio_Gallegos'), ('America/Argentina/Salta', 'Argentina/Salta'), ('America/Argentina/San_Juan', 'Argentina/San_Juan'), ('America/Argentina/San_Luis', 'Argentina/San_Luis'), ('America/Argentina/Tucuman', 'Argentina/Tucuman'), ('America/Argentina/Ushuaia', 'Argentina/Ushuaia'), ('America/Aruba', 'Aruba'), ('America/Asuncion', 'Asuncion'), ('America/Atikokan', 'Atikokan'), ('America/Atka', 'Atka'), ('America/Bahia', 'Bahia'), ('America/Bahia_Banderas', 'Bahia_Banderas'), ('America/Barbados', 'Barbados'), ('America/Belem', 'Belem'), ('America/Belize', 'Belize'), ('America/Blanc-Sablon', 'Blanc-Sablon'), ('America/Boa_Vista', 'Boa_Vista'), ('America/Bogota', 'Bogota'), ('America/Boise', 'Boise'), ('America/Buenos_Aires', 'Buenos_Aires'), ('America/Cambridge_Bay', 'Cambridge_Bay'), ('America/Campo_Grande', 'Campo_Grande'), ('America/Cancun', 'Cancun'), ('America/Caracas', 'Caracas'), ('America/Catamarca', 'Catamarca'), ('America/Cayenne', 'Cayenne'), ('America/Cayman', 'Cayman'), ('America/Chicago', 'Chicago'), ('America/Chihuahua', 'Chihuahua'), ('America/Ciudad_Juarez', 'Ciudad_Juarez'), ('America/Coral_Harbour', 'Coral_Harbour'), ('America/Cordoba', 'Cordoba'), ('America/Costa_Rica', 'Costa_Rica'), ('America/Creston', 'Creston'), ('America/Cuiaba', 'Cuiaba'), ('America/Curacao', 'Curacao'), ('America/Danmarkshavn', 'Danmarkshavn'), ('America/Dawson', 'Dawson'), ('America/Dawson_Creek', 'Dawson_Creek'), ('America/Denver', 'Denver'), ('America/Detroit', 'Detroit'), ('America/Dominica', 'Dominica'), ('America/Edmonton', 'Edmonton'), ('America/Eirunepe', 'Eirunepe'), ('America/El_Salvador', 'El_Salvador'), ('America/Ensenada', 'Ensenada'), ('America/Fort_Nelson', 'Fort_Nelson'), ('America/Fort_Wayne', 'Fort_Wayne'), ('America/Fortaleza', 'Fortaleza'), ('America/Glace_Bay', 'Glace_Bay'), ('America/Godthab', 'Godthab'), ('America/Goose_Bay', 'Goose_Bay'), ('America/Grand_Turk', 'Grand_Turk'), ('America/Grenada', 'Grenada'), ('America/Guadeloupe', 'Guadeloupe'), ('America/Guatemala', 'Guatemala'), ('America/Guayaquil', 'Guayaquil'), ('America/Guyana', 'Guyana'), ('America/Halifax', 'Halifax'), ('America/Havana', 'Havana'), ('America/Hermosillo', 'Hermosillo'), ('America/Indiana/Indianapolis', 'Indiana/Indianapolis'), ('America/Indiana/Knox', 'Indiana/Knox'), ('America/Indiana/Marengo', 'Indiana/Marengo'), ('America/Indiana/Petersburg', 'Indiana/Petersburg'), ('America/Indiana/Tell_City', 'Indiana/Tell_City'), ('America/Indiana/Vevay', 'Indiana/Vevay'), ('America/Indiana/Vincennes', 'Indiana/Vincennes'), ('America/Indiana/Winamac', 'Indiana/Winamac'), ('America/Indianapolis', 'Indianapolis'), ('America/Inuvik', 'Inuvik'), ('America/Iqaluit', 'Iqaluit'), ('America/Jamaica', 'Jamaica'), ('America/Jujuy', 'Jujuy'), ('America/Juneau', 'Juneau'), ('America/Kentucky/Louisville', 'Kentucky/Louisville'), ('America/Kentucky/Monticello', 'Kentucky/Monticello'), ('America/Knox_IN', 'Knox_IN'), ('America/Kralendijk', 'Kralendijk'), ('America/La_Paz', 'La_Paz'), ('America/Lima', 'Lima'), ('America/Los_Angeles', 'Los_Angeles'), ('America/Louisville', 'Louisville'), ('America/Lower_Princes', 'Lower_Princes'), ('America/Maceio', 'Maceio'), ('America/Managua', 'Managua'), ('America/Manaus', 'Manaus'), ('America/Marigot', 'Marigot'), ('America/Martinique', 'Martinique'), ('America/Matamoros', 'Matamoros'), ('America/Mazatlan', 'Mazatlan'), ('America/Mendoza', 'Mendoza'), ('America/Menominee', 'Menominee'), ('America/Merida', 'Merida'), ('America/Metlakatla', 'Metlakatla'), ('America/Mexico_City', 'Mexico_City'), ('America/Miquelon', 'Miquelon'), ('America/Moncton', 'Moncton'), ('America/Monterrey', 'Monterrey'), ('America/Montevideo', 'Montevideo'), ('America/Montreal', 'Montreal'), ('America/Montserrat', 'Montserrat'), ('America/Nassau', 'Nassau'), ('America/New_York', 'New_York'), ('America/Nipigon', 'Nipigon'), ('America/Nome', 'Nome'), ('America/Noronha', 'Noronha'), ('America/North_Dakota/Beulah', 'North_Dakota/Beulah'), ('America/North_Dakota/Center', 'North_Dakota/Center'), ('America/North_Dakota/New_Salem', 'North_Dakota/New_Salem'), ('America/Nuuk', 'Nuuk'), ('America/Ojinaga', 'Ojinaga'), ('America/Panama', 'Panama'), ('America/Pangnirtung', 'Pangnirtung'), ('America/Paramaribo', 'Paramaribo'), ('America/Phoenix', 'Phoenix'), ('America/Port-au-Prince', 'Port-au-Prince'), ('America/Port_of_Spain', 'Port_of_Spain'), ('America/Porto_Acre', 'Porto_Acre'), ('America/Porto_Velho', 'Porto_Velho'), ('America/Puerto_Rico', 'Puerto_Rico'), ('America/Punta_Arenas', 'Punta_Arenas'), ('America/Rainy_River', 'Rainy_River'), ('America/Rankin_Inlet', 'Rankin_Inlet'), ('America/Recife', 'Recife'), ('America/Regina', 'Regina'), ('America/Resolute', 'Resolute'), ('America/Rio_Branco', 'Rio_Branco'), ('America/Rosario', 'Rosario'), ('America/Santa_Isabel', 'Santa_Isabel'), ('America/Santarem', 'Santarem'), ('America/Santiago', 'Santiago'), ('America/Santo_Domingo', 'Santo_Domingo'), ('America/Sao_Paulo', 'Sao_Paulo'), ('America/Scoresbysund', 'Scoresbysund'), ('America/Shiprock', 'Shiprock'), ('America/Sitka', 'Sitka'), ('America/St_Barthelemy', 'St_Barthelemy'), ('America/St_Johns', 'St_Johns'), ('America/St_Kitts', 'St_Kitts'), ('America/St_Lucia', 'St_Lucia'), ('America/St_Thomas', 'St_Thomas'), ('America/St_Vincent', 'St_Vincent'), ('America/Swift_Current', 'Swift_Current'), ('America/Tegucigalpa', 'Tegucigalpa'), ('America/Thule', 'Thule'), ('America/Thunder_Bay', 'Thunder_Bay'), ('America/Tijuana', 'Tijuana'), ('America/Toronto', 'Toronto'), ('America/Tortola', 'Tortola'), ('America/Vancouver', 'Vancouver'), ('America/Virgin', 'Virgin'), ('America/Whitehorse', 'Whitehorse'), ('America/Winnipeg', 'Winnipeg'), ('America/Yakutat', 'Yakutat'), ('America/Yellowknife', 'Yellowknife')]), ('Antarctica', [('Antarctica/Casey', 'Casey'), ('Antarctica/Davis', 'Davis'), ('Antarctica/DumontDUrville', 'DumontDUrville'), ('Antarctica/Macquarie', 'Macquarie'), ('Antarctica/Mawson', 'Mawson'), ('Antarctica/McMurdo', 'McMurdo'), ('Antarctica/Palmer', 'Palmer'), ('Antarctica/Rothera', 'Rothera'), ('Antarctica/South_Pole', 'South_Pole'), ('Antarctica/Syowa', 'Syowa'), ('Antarctica/Troll', 'Troll'), ('Antarctica/Vostok', 'Vostok')]), ('Arctic', [('Arctic/Longyearbyen', 'Longyearbyen')]), ('Asia', [('Asia/Aden', 'Aden'), ('Asia/Almaty', 'Almaty'), ('Asia/Amman', 'Amman'), ('Asia/Anadyr', 'Anadyr'), ('Asia/Aqtau', 'Aqtau'), ('Asia/Aqtobe', 'Aqtobe'), ('Asia/Ashgabat', 'Ashgabat'), ('Asia/Ashkhabad', 'Ashkhabad'), ('Asia/Atyrau', 'Atyrau'), ('Asia/Baghdad', 'Baghdad'), ('Asia/Bahrain', 'Bahrain'), ('Asia/Baku', 'Baku'), ('Asia/Bangkok', 'Bangkok'), ('Asia/Barnaul', 'Barnaul'), ('Asia/Beirut', 'Beirut'), ('Asia/Bishkek', 'Bishkek'), ('Asia/Brunei', 'Brunei'), ('Asia/Calcutta', 'Calcutta'), ('Asia/Chita', 'Chita'), ('Asia/Choibalsan', 'Choibalsan'), ('Asia/Chongqing', 'Chongqing'), ('Asia/Chungking', 'Chungking'), ('Asia/Colombo', 'Colombo'), ('Asia/Dacca', 'Dacca'), ('Asia/Damascus', 'Damascus'), ('Asia/Dhaka', 'Dhaka'), ('Asia/Dili', 'Dili'), ('Asia/Dubai', 'Dubai'), ('Asia/Dushanbe', 'Dushanbe'), ('Asia/Famagusta', 'Famagusta'), ('Asia/Gaza', 'Gaza'), ('Asia/Harbin', 'Harbin'), ('Asia/Hebron', 'Hebron'), ('Asia/Ho_Chi_Minh', 'Ho_Chi_Minh'), ('Asia/Hong_Kong', 'Hong_Kong'), ('Asia/Hovd', 'Hovd'), ('Asia/Irkutsk', 'Irkutsk'), ('Asia/Istanbul', 'Istanbul'), ('Asia/Jakarta', 'Jakarta'), ('Asia/Jayapura', 'Jayapura'), ('Asia/Jerusalem', 'Jerusalem'), ('Asia/Kabul', 'Kabul'), ('Asia/Kamchatka', 'Kamchatka'), ('Asia/Karachi', 'Karachi'), ('Asia/Kashgar', 'Kashgar'), ('Asia/Kathmandu', 'Kathmandu'), ('Asia/Katmandu', 'Katmandu'), ('Asia/Khandyga', 'Khandyga'), ('Asia/Kolkata', 'Kolkata'), ('Asia/Krasnoyarsk', 'Krasnoyarsk'), ('Asia/Kuala_Lumpur', 'Kuala_Lumpur'), ('Asia/Kuching', 'Kuching'), ('Asia/Kuwait', 'Kuwait'), ('Asia/Macao', 'Macao'), ('Asia/Macau', 'Macau'), ('Asia/Magadan', 'Magadan'), ('Asia/Makassar', 'Makassar'), ('Asia/Manila', 'Manila'), ('Asia/Muscat', 'Muscat'), ('Asia/Nicosia', 'Nicosia'), ('Asia/Novokuznetsk', 'Novokuznetsk'), ('Asia/Novosibirsk', 'Novosibirsk'), ('Asia/Omsk', 'Omsk'), ('Asia/Oral', 'Oral'), ('Asia/Phnom_Penh', 'Phnom_Penh'), ('Asia/Pontianak', 'Pontianak'), ('Asia/Pyongyang', 'Pyongyang'), ('Asia/Qatar', 'Qatar'), ('Asia/Qostanay', 'Qostanay'), ('Asia/Qyzylorda', 'Qyzylorda'), ('Asia/Rangoon', 'Rangoon'), ('Asia/Riyadh', 'Riyadh'), ('Asia/Saigon', 'Saigon'), ('Asia/Sakhalin', 'Sakhalin'), ('Asia/Samarkand', 'Samarkand'), ('Asia/Seoul', 'Seoul'), ('Asia/Shanghai', 'Shanghai'), ('Asia/Singapore', 'Singapore'), ('Asia/Srednekolymsk', 'Srednekolymsk'), ('Asia/Taipei', 'Taipei'), ('Asia/Tashkent', 'Tashkent'), ('Asia/Tbilisi', 'Tbilisi'), ('Asia/Tehran', 'Tehran'), ('Asia/Tel_Aviv', 'Tel_Aviv'), ('Asia/Thimbu', 'Thimbu'), ('Asia/Thimphu', 'Thimphu'), ('Asia/Tokyo', 'Tokyo'), ('Asia/Tomsk', 'Tomsk'), ('Asia/Ujung_Pandang', 'Ujung_Pandang'), ('Asia/Ulaanbaatar', 'Ulaanbaatar'), ('Asia/Ulan_Bator', 'Ulan_Bator'), ('Asia/Urumqi', 'Urumqi'), ('Asia/Ust-Nera', 'Ust-Nera'), ('Asia/Vientiane', 'Vientiane'), ('Asia/Vladivostok', 'Vladivostok'), ('Asia/Yakutsk', 'Yakutsk'), ('Asia/Yangon', 'Yangon'), ('Asia/Yekaterinburg', 'Yekaterinburg'), ('Asia/Yerevan', 'Yerevan')]), ('Atlantic', [('Atlantic/Azores', 'Azores'), ('Atlantic/Bermuda', 'Bermuda'), ('Atlantic/Canary', 'Canary'), ('Atlantic/Cape_Verde', 'Cape_Verde'), ('Atlantic/Faeroe', 'Faeroe'), ('Atlantic/Faroe', 'Faroe'), ('Atlantic/Jan_Mayen', 'Jan_Mayen'), ('Atlantic/Madeira', 'Madeira'), ('Atlantic/Reykjavik', 'Reykjavik'), ('Atlantic/South_Georgia', 'South_Georgia'), ('Atlantic/St_Helena', 'St_Helena'), ('Atlantic/Stanley', 'Stanley')]), ('Australia', [('Australia/ACT', 'ACT'), ('Australia/Adelaide', 'Adelaide'), ('Australia/Brisbane', 'Brisbane'), ('Australia/Broken_Hill', 'Broken_Hill'), ('Australia/Canberra', 'Canberra'), ('Australia/Currie', 'Currie'), ('Australia/Darwin', 'Darwin'), ('Australia/Eucla', 'Eucla'), ('Australia/Hobart', 'Hobart'), ('Australia/LHI', 'LHI'), ('Australia/Lindeman', 'Lindeman'), ('Australia/Lord_Howe', 'Lord_Howe'), ('Australia/Melbourne', 'Melbourne'), ('Australia/NSW', 'NSW'), ('Australia/North', 'North'), ('Australia/Perth', 'Perth'), ('Australia/Queensland', 'Queensland'), ('Australia/South', 'South'), ('Australia/Sydney', 'Sydney'), ('Australia/Tasmania', 'Tasmania'), ('Australia/Victoria', 'Victoria'), ('Australia/West', 'West'), ('Australia/Yancowinna', 'Yancowinna')]), ('Brazil', [('Brazil/Acre', 'Acre'), ('Brazil/DeNoronha', 'DeNoronha'), ('Brazil/East', 'East'), ('Brazil/West', 'West')]), ('Canada', [('Canada/Atlantic', 'Atlantic'), ('Canada/Central', 'Central'), ('Canada/Eastern', 'Eastern'), ('Canada/Mountain', 'Mountain'), ('Canada/Newfoundland', 'Newfoundland'), ('Canada/Pacific', 'Pacific'), ('Canada/Saskatchewan', 'Saskatchewan'), ('Canada/Yukon', 'Yukon')]), ('Chile', [('Chile/Continental', 'Continental'), ('Chile/EasterIsland', 'EasterIsland')]), ('Etc', [('Etc/Greenwich', 'Greenwich'), ('Etc/UCT', 'UCT'), ('Etc/UTC', 'UTC'), ('Etc/Universal', 'Universal'), ('Etc/Zulu', 'Zulu')]), ('Europe', [('Europe/Amsterdam', 'Amsterdam'), ('Europe/Andorra', 'Andorra'), ('Europe/Astrakhan', 'Astrakhan'), ('Europe/Athens', 'Athens'), ('Europe/Belfast', 'Belfast'), ('Europe/Belgrade', 'Belgrade'), ('Europe/Berlin', 'Berlin'), ('Europe/Bratislava', 'Bratislava'), ('Europe/Brussels', 'Brussels'), ('Europe/Bucharest', 'Bucharest'), ('Europe/Budapest', 'Budapest'), ('Europe/Busingen', 'Busingen'), ('Europe/Chisinau', 'Chisinau'), ('Europe/Copenhagen', 'Copenhagen'), ('Europe/Dublin', 'Dublin'), ('Europe/Gibraltar', 'Gibraltar'), ('Europe/Guernsey', 'Guernsey'), ('Europe/Helsinki', 'Helsinki'), ('Europe/Isle_of_Man', 'Isle_of_Man'), ('Europe/Istanbul', 'Istanbul'), ('Europe/Jersey', 'Jersey'), ('Europe/Kaliningrad', 'Kaliningrad'), ('Europe/Kiev', 'Kiev'), ('Europe/Kirov', 'Kirov'), ('Europe/Kyiv', 'Kyiv'), ('Europe/Lisbon', 'Lisbon'), ('Europe/Ljubljana', 'Ljubljana'), ('Europe/London', 'London'), ('Europe/Luxembourg', 'Luxembourg'), ('Europe/Madrid', 'Madrid'), ('Europe/Malta', 'Malta'), ('Europe/Mariehamn', 'Mariehamn'), ('Europe/Minsk', 'Minsk'), ('Europe/Monaco', 'Monaco'), ('Europe/Moscow', 'Moscow'), ('Europe/Nicosia', 'Nicosia'), ('Europe/Oslo', 'Oslo'), ('Europe/Paris', 'Paris'), ('Europe/Podgorica', 'Podgorica'), ('Europe/Prague', 'Prague'), ('Europe/Riga', 'Riga'), ('Europe/Rome', 'Rome'), ('Europe/Samara', 'Samara'), ('Europe/San_Marino', 'San_Marino'), ('Europe/Sarajevo', 'Sarajevo'), ('Europe/Saratov', 'Saratov'), ('Europe/Simferopol', 'Simferopol'), ('Europe/Skopje', 'Skopje'), ('Europe/Sofia', 'Sofia'), ('Europe/Stockholm', 'Stockholm'), ('Europe/Tallinn', 'Tallinn'), ('Europe/Tirane', 'Tirane'), ('Europe/Tiraspol', 'Tiraspol'), ('Europe/Ulyanovsk', 'Ulyanovsk'), ('Europe/Uzhgorod', 'Uzhgorod'), ('Europe/Vaduz', 'Vaduz'), ('Europe/Vatican', 'Vatican'), ('Europe/Vienna', 'Vienna'), ('Europe/Vilnius', 'Vilnius'), ('Europe/Volgograd', 'Volgograd'), ('Europe/Warsaw', 'Warsaw'), ('Europe/Zagreb', 'Zagreb'), ('Europe/Zaporozhye', 'Zaporozhye'), ('Europe/Zurich', 'Zurich')]), ('Indian', [('Indian/Antananarivo', 'Antananarivo'), ('Indian/Chagos', 'Chagos'), ('Indian/Christmas', 'Christmas'), ('Indian/Cocos', 'Cocos'), ('Indian/Comoro', 'Comoro'), ('Indian/Kerguelen', 'Kerguelen'), ('Indian/Mahe', 'Mahe'), ('Indian/Maldives', 'Maldives'), ('Indian/Mauritius', 'Mauritius'), ('Indian/Mayotte', 'Mayotte'), ('Indian/Reunion', 'Reunion')]), ('Mexico', [('Mexico/BajaNorte', 'BajaNorte'), ('Mexico/BajaSur', 'BajaSur'), ('Mexico/General', 'General')]), ('Other', [('CET', 'CET'), ('CST6CDT', 'CST6CDT'), ('Cuba', 'Cuba'), ('EET', 'EET'), ('EST', 'EST'), ('EST5EDT', 'EST5EDT'), ('Egypt', 'Egypt'), ('Eire', 'Eire'), ('GB', 'GB'), ('GB-Eire', 'GB-Eire'), ('Greenwich', 'Greenwich'), ('HST', 'HST'), ('Hongkong', 'Hongkong'), ('Iceland', 'Iceland'), ('Iran', 'Iran'), ('Israel', 'Israel'), ('Jamaica', 'Jamaica'), ('Japan', 'Japan'), ('Kwajalein', 'Kwajalein'), ('Libya', 'Libya'), ('MET', 'MET'), ('MST', 'MST'), ('MST7MDT', 'MST7MDT'), ('NZ', 'NZ'), ('NZ-CHAT', 'NZ-CHAT'), ('Navajo', 'Navajo'), ('PRC', 'PRC'), ('PST8PDT', 'PST8PDT'), ('Poland', 'Poland'), ('Portugal', 'Portugal'), ('ROC', 'ROC'), ('ROK', 'ROK'), ('Singapore', 'Singapore'), ('Turkey', 'Turkey'), ('UCT', 'UCT'), ('UTC', 'UTC'), ('Universal', 'Universal'), ('W-SU', 'W-SU'), ('WET', 'WET'), ('Zulu', 'Zulu')]), ('Pacific', [('Pacific/Apia', 'Apia'), ('Pacific/Auckland', 'Auckland'), ('Pacific/Bougainville', 'Bougainville'), ('Pacific/Chatham', 'Chatham'), ('Pacific/Chuuk', 'Chuuk'), ('Pacific/Easter', 'Easter'), ('Pacific/Efate', 'Efate'), ('Pacific/Enderbury', 'Enderbury'), ('Pacific/Fakaofo', 'Fakaofo'), ('Pacific/Fiji', 'Fiji'), ('Pacific/Funafuti', 'Funafuti'), ('Pacific/Galapagos', 'Galapagos'), ('Pacific/Gambier', 'Gambier'), ('Pacific/Guadalcanal', 'Guadalcanal'), ('Pacific/Guam', 'Guam'), ('Pacific/Honolulu', 'Honolulu'), ('Pacific/Johnston', 'Johnston'), ('Pacific/Kanton', 'Kanton'), ('Pacific/Kiritimati', 'Kiritimati'), ('Pacific/Kosrae', 'Kosrae'), ('Pacific/Kwajalein', 'Kwajalein'), ('Pacific/Majuro', 'Majuro'), ('Pacific/Marquesas', 'Marquesas'), ('Pacific/Midway', 'Midway'), ('Pacific/Nauru', 'Nauru'), ('Pacific/Niue', 'Niue'), ('Pacific/Norfolk', 'Norfolk'), ('Pacific/Noumea', 'Noumea'), ('Pacific/Pago_Pago', 'Pago_Pago'), ('Pacific/Palau', 'Palau'), ('Pacific/Pitcairn', 'Pitcairn'), ('Pacific/Pohnpei', 'Pohnpei'), ('Pacific/Ponape', 'Ponape'), ('Pacific/Port_Moresby', 'Port_Moresby'), ('Pacific/Rarotonga', 'Rarotonga'), ('Pacific/Saipan', 'Saipan'), ('Pacific/Samoa', 'Samoa'), ('Pacific/Tahiti', 'Tahiti'), ('Pacific/Tarawa', 'Tarawa'), ('Pacific/Tongatapu', 'Tongatapu'), ('Pacific/Truk', 'Truk'), ('Pacific/Wake', 'Wake'), ('Pacific/Wallis', 'Wallis'), ('Pacific/Yap', 'Yap')]), ('US', [('US/Alaska', 'Alaska'), ('US/Aleutian', 'Aleutian'), ('US/Arizona', 'Arizona'), ('US/Central', 'Central'), ('US/East-Indiana', 'East-Indiana'), ('US/Eastern', 'Eastern'), ('US/Hawaii', 'Hawaii'), ('US/Indiana-Starke', 'Indiana-Starke'), ('US/Michigan', 'Michigan'), ('US/Mountain', 'Mountain'), ('US/Pacific', 'Pacific'), ('US/Samoa', 'Samoa')])], default='America/Toronto', max_length=50, verbose_name='time zone'), - ), ] diff --git a/templates/contest/ranking.html b/templates/contest/ranking.html index 6f0f88426..e992504bb 100644 --- a/templates/contest/ranking.html +++ b/templates/contest/ranking.html @@ -89,7 +89,7 @@ window.applyTag(); }).always(function () { ranking_outdated = false; - // setTimeout(update_ranking, 10000); + setTimeout(update_ranking, 10000); }); } $(window).on('dmoj:window-visible', function () { @@ -97,7 +97,7 @@ update_ranking(); } }); - // setTimeout(update_ranking, 10000); + setTimeout(update_ranking, 10000); }); {% endif %} From bf525a1215057c1ee532adab269f3ce388156db0 Mon Sep 17 00:00:00 2001 From: winprn Date: Sat, 21 Oct 2023 20:43:50 +0700 Subject: [PATCH 3/7] reduce backend query --- judge/jinja2/reference.py | 2 +- templates/contest/media-icpc-css.html | 2 +- templates/contest/ranking.html | 2 +- templates/user/base-users-table.html | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/judge/jinja2/reference.py b/judge/jinja2/reference.py index 912f4c544..acca1f0e9 100644 --- a/judge/jinja2/reference.py +++ b/judge/jinja2/reference.py @@ -160,7 +160,7 @@ def link_user(user): else: display_badge_img = '' - return mark_safe(f'' + return mark_safe(f'' f'' f'{escape(profile.display_name)}{display_badge_img}') diff --git a/templates/contest/media-icpc-css.html b/templates/contest/media-icpc-css.html index 8401050a4..294adb912 100644 --- a/templates/contest/media-icpc-css.html +++ b/templates/contest/media-icpc-css.html @@ -31,7 +31,7 @@ padding-bottom: -0.75em; } - tr.top-team span.rating::after { + span.rating.top-team::after { content: attr(data-user-group); font-size: 0.75em; padding: 0.25em; diff --git a/templates/contest/ranking.html b/templates/contest/ranking.html index b6dcb3de4..4ba3099d7 100644 --- a/templates/contest/ranking.html +++ b/templates/contest/ranking.html @@ -527,7 +527,7 @@ window.applyTag = function () { const groups = []; - $('#ranking-table > tbody > tr[id]').each(function () { + $('#ranking-table > tbody > tr[id] > td span').each(function () { let row = $(this); if (groups.findIndex(x => x == row.data('user-group')) == -1) { diff --git a/templates/user/base-users-table.html b/templates/user/base-users-table.html index 7dd23017a..492738014 100644 --- a/templates/user/base-users-table.html +++ b/templates/user/base-users-table.html @@ -19,7 +19,7 @@ {% for rank, user in users %} - + {{ rank }} {% block after_rank scoped %}{% endblock %} From 044b0a36c31344d26fcefc076aa0675532faa616 Mon Sep 17 00:00:00 2001 From: winprn Date: Sat, 21 Oct 2023 21:01:22 +0700 Subject: [PATCH 4/7] fix error when local storage is empty --- judge/jinja2/reference.py | 4 +++- .../{0199_auto_20231018_0702.py => 0199_add_user_group.py} | 0 judge/views/submission.py | 2 +- templates/contest/ranking.html | 4 ++-- 4 files changed, 6 insertions(+), 4 deletions(-) rename judge/migrations/{0199_auto_20231018_0702.py => 0199_add_user_group.py} (100%) diff --git a/judge/jinja2/reference.py b/judge/jinja2/reference.py index acca1f0e9..4e8bc7489 100644 --- a/judge/jinja2/reference.py +++ b/judge/jinja2/reference.py @@ -144,11 +144,13 @@ def item_title(item): @registry.function def link_user(user): + is_contest_ranking_profile = False if isinstance(user, Profile): user, profile = user.user, user elif isinstance(user, AbstractUser): profile = user.profile elif type(user).__name__ == 'ContestRankingProfile': + is_contest_ranking_profile = True user, profile = user.user, user else: raise ValueError('Expected profile or user, got %s' % (type(user),)) @@ -160,7 +162,7 @@ def link_user(user): else: display_badge_img = '' - return mark_safe(f'' + return mark_safe(f'' f'' f'{escape(profile.display_name)}{display_badge_img}') diff --git a/judge/migrations/0199_auto_20231018_0702.py b/judge/migrations/0199_add_user_group.py similarity index 100% rename from judge/migrations/0199_auto_20231018_0702.py rename to judge/migrations/0199_add_user_group.py diff --git a/judge/views/submission.py b/judge/views/submission.py index e1433a93a..6ec638622 100644 --- a/judge/views/submission.py +++ b/judge/views/submission.py @@ -40,7 +40,7 @@ def submission_related(queryset): 'problem__is_public', 'language__short_name', 'language__key', 'language__file_only', 'date', 'time', 'memory', 'points', 'result', 'status', 'case_points', 'case_total', 'current_testcase', 'contest_object', 'locked_after', 'problem__submission_source_visibility_mode', 'problem__testcase_result_visibility_mode', - 'user__username_display_override', 'user__display_badge__name', 'user__display_badge__mini') \ + 'user__username_display_override', 'user__display_badge__name', 'user__display_badge__mini', 'user__group') \ .prefetch_related('contest_object__authors', 'contest_object__curators') diff --git a/templates/contest/ranking.html b/templates/contest/ranking.html index 4ba3099d7..73a729f9d 100644 --- a/templates/contest/ranking.html +++ b/templates/contest/ranking.html @@ -277,8 +277,8 @@ localStorage.setItem(`filter-cleared-${contest_key}`, 'true'); } - if (localStorage.getItem(`filter-selected-orgs-${contest_key}`) === null) { - localStorage.setItem(`filter-selected-orgs-${contest_key}`, []); + if (localStorage.getItem(`filter-selected-orgs-${contest_key}`) === "") { + localStorage.setItem(`filter-selected-orgs-${contest_key}`, JSON.stringify([])); } if (localStorage.getItem(`filter-selected-group-${contest_key}`) === null) { From 991daa9c64a56fda74695b3bbe9cdc336b2341cf Mon Sep 17 00:00:00 2001 From: Le Duy Thuc Date: Sat, 21 Oct 2023 18:52:21 +0000 Subject: [PATCH 5/7] restore submission_related --- judge/views/submission.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/judge/views/submission.py b/judge/views/submission.py index 6ec638622..e1433a93a 100644 --- a/judge/views/submission.py +++ b/judge/views/submission.py @@ -40,7 +40,7 @@ def submission_related(queryset): 'problem__is_public', 'language__short_name', 'language__key', 'language__file_only', 'date', 'time', 'memory', 'points', 'result', 'status', 'case_points', 'case_total', 'current_testcase', 'contest_object', 'locked_after', 'problem__submission_source_visibility_mode', 'problem__testcase_result_visibility_mode', - 'user__username_display_override', 'user__display_badge__name', 'user__display_badge__mini', 'user__group') \ + 'user__username_display_override', 'user__display_badge__name', 'user__display_badge__mini') \ .prefetch_related('contest_object__authors', 'contest_object__curators') From 903641d67a98ebb639c8fd2c6ffdd1d8d735a6ff Mon Sep 17 00:00:00 2001 From: Le Duy Thuc Date: Sat, 21 Oct 2023 18:57:46 +0000 Subject: [PATCH 6/7] Refactor, rename group to tag --- judge/jinja2/reference.py | 2 +- templates/contest/media-icpc-css.html | 2 +- templates/contest/ranking.html | 81 ++++++++++++++++----------- 3 files changed, 50 insertions(+), 35 deletions(-) diff --git a/judge/jinja2/reference.py b/judge/jinja2/reference.py index 4e8bc7489..0700d7a45 100644 --- a/judge/jinja2/reference.py +++ b/judge/jinja2/reference.py @@ -162,7 +162,7 @@ def link_user(user): else: display_badge_img = '' - return mark_safe(f'' + return mark_safe(f'' f'' f'{escape(profile.display_name)}{display_badge_img}') diff --git a/templates/contest/media-icpc-css.html b/templates/contest/media-icpc-css.html index 294adb912..315189f6a 100644 --- a/templates/contest/media-icpc-css.html +++ b/templates/contest/media-icpc-css.html @@ -32,7 +32,7 @@ } span.rating.top-team::after { - content: attr(data-user-group); + content: attr(data-user-tag); font-size: 0.75em; padding: 0.25em; margin-left: 0.5em; diff --git a/templates/contest/ranking.html b/templates/contest/ranking.html index 73a729f9d..25fdf9b82 100644 --- a/templates/contest/ranking.html +++ b/templates/contest/ranking.html @@ -86,7 +86,7 @@ window.enableAdminOperations(); window.loadOrgLogo(); window.applyFavoriteUsers(); - window.applyTag(); + window.getTagNamesAndSetTopTag(); }).always(function () { ranking_outdated = false; setTimeout(update_ranking, 10000); @@ -236,7 +236,7 @@ theme: '{{ DMOJ_SELECT2_THEME }}', multiple: true, closeOnSelect: false, - placeholder: '{{ _('Filter by group') }}', + placeholder: '{{ _('Filter by tag') }}', }); const selection = $('#tag-check-list').data().select2.selection; @@ -277,12 +277,12 @@ localStorage.setItem(`filter-cleared-${contest_key}`, 'true'); } - if (localStorage.getItem(`filter-selected-orgs-${contest_key}`) === "") { + if (localStorage.getItem(`filter-selected-orgs-${contest_key}`) === null) { localStorage.setItem(`filter-selected-orgs-${contest_key}`, JSON.stringify([])); } - if (localStorage.getItem(`filter-selected-group-${contest_key}`) === null) { - localStorage.setItem(`filter-selected-group-${contest_key}`, ""); + if (localStorage.getItem(`filter-selected-tags-${contest_key}`) === null) { + localStorage.setItem(`filter-selected-tags-${contest_key}`, JSON.stringify([])); } $('#apply-organization-filter').click(function () { @@ -292,9 +292,9 @@ $('#org-check-list').val().forEach(function (el) { selected_orgs.push(el.trim()); }); - let selected_group = $('#tag-check-list').val().map(x => x.trim()); + let selected_tags = $('#tag-check-list').val().map(x => x.trim()); localStorage.setItem(`filter-selected-orgs-${contest_key}`, JSON.stringify(selected_orgs)); - localStorage.setItem(`filter-selected-group-${contest_key}`, selected_group); + localStorage.setItem(`filter-selected-tags-${contest_key}`, JSON.stringify(selected_tags)); window.applyRankingFilter(); }); @@ -360,6 +360,31 @@ window.getOrganizationCodes(); + window.getTagNamesAndSetTopTag = function () { + const tags = []; + $('#ranking-table > tbody > tr[id] > td span').each(function () { + let row = $(this); + + if (row.data('user-tag') == undefined) { + return; + } + + if (tags.findIndex(x => x == row.data('user-tag')) == -1) { + row.addClass('top-team'); + tags.push(row.data('user-tag')); + } + }); + + let tag_options = $('#tag-check-list'); + tag_options.empty(); + tags.forEach(function (tag) { + tag_options.append( + `` + ); + }); + } + window.getTagNamesAndSetTopTag(); + function extractCurrentAbsRank(row_text) { let paren_surround_text = row_text.match(/\(([^)]+)\)/); let current_abs_rank @@ -386,9 +411,9 @@ let counter = 0; let previous_abs_rank = -1; let selected_orgs = JSON.parse(localStorage.getItem(`filter-selected-orgs-${contest_key}`)); - let selected_group = localStorage.getItem(`filter-selected-group-${contest_key}`); + let selected_tags = JSON.parse(localStorage.getItem(`filter-selected-tags-${contest_key}`)); - if (!selected_orgs.length && !selected_group.length) { + if (!selected_orgs.length && !selected_tags.length) { window.clearRankingFilter(); return; } @@ -398,15 +423,24 @@ let org_anchor = row.find("div > div > .personal-info > .organization > a")[0]; let org = org_anchor ? org_anchor.text : 'Other'; + let tag_anchor = row.find("span")[0]; + let tag = tag_anchor ? tag_anchor.dataset.userTag : 'Other' - let should_show_org = false; + let should_show_org = selected_orgs.length == 0; selected_orgs.forEach(function (selected_org) { if (selected_org === org.trim()) { should_show_org = true; } }); + let should_show_tag = selected_tags.length == 0; + selected_tags.forEach(function (selected_tag) { + if (selected_tag === tag.trim()) { + should_show_tag = true; + } + }); + - if (!should_show_org) { + if (!should_show_org || !should_show_tag) { row.hide(); return; } @@ -430,8 +464,10 @@ window.applyRankingFilter(); window.restoreChecklistOptions = function () { - let selected_orgs = localStorage.getItem(`filter-selected-orgs-${contest_key}`).split(','); + let selected_orgs = JSON.parse(localStorage.getItem(`filter-selected-orgs-${contest_key}`)); $('#org-check-list').val(selected_orgs).trigger('change'); + let selected_tags = JSON.parse(localStorage.getItem(`filter-selected-tags-${contest_key}`)); + $('#tag-check-list').val(selected_tags).trigger('change'); }; window.restoreChecklistOptions(); @@ -524,27 +560,6 @@ }) } window.loadOrgLogo(); - - window.applyTag = function () { - const groups = []; - $('#ranking-table > tbody > tr[id] > td span').each(function () { - let row = $(this); - - if (groups.findIndex(x => x == row.data('user-group')) == -1) { - row.addClass('top-team'); - groups.push(row.data('user-group')); - } - }); - - let tag_options = $('#tag-check-list'); - tag_options.empty(); - groups.forEach(function (group) { - tag_options.append( - `` - ); - }); - } - window.applyTag(); }); {% if tab == 'ranking' %} From c60150c2621ebf5003e15a93de8ef01996b0575b Mon Sep 17 00:00:00 2001 From: Le Duy Thuc Date: Sat, 21 Oct 2023 19:07:20 +0000 Subject: [PATCH 7/7] Remove None option, sort --- templates/contest/ranking.html | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/templates/contest/ranking.html b/templates/contest/ranking.html index 25fdf9b82..61a0b8246 100644 --- a/templates/contest/ranking.html +++ b/templates/contest/ranking.html @@ -365,18 +365,21 @@ $('#ranking-table > tbody > tr[id] > td span').each(function () { let row = $(this); - if (row.data('user-tag') == undefined) { + const user_tag = row.data('user-tag'); + + if (user_tag == undefined || user_tag == 'None') { return; } - if (tags.findIndex(x => x == row.data('user-tag')) == -1) { + if (tags.findIndex(x => x == user_tag) == -1) { row.addClass('top-team'); - tags.push(row.data('user-tag')); + tags.push(user_tag); } }); let tag_options = $('#tag-check-list'); tag_options.empty(); + tags.sort(); tags.forEach(function (tag) { tag_options.append( ``