1.6.3 版本

完全重写了 wpavatar 插件,全新功能
This commit is contained in:
文派备案 2025-05-16 10:15:45 +08:00
parent fc6d3c00f4
commit de331d95f0
12 changed files with 2213 additions and 26 deletions

341
assets/css/admin.css Normal file
View file

@ -0,0 +1,341 @@
.wpavatar-settings .form-table th {
width: 220px;
}
.wpavatar-settings .description {
font-size: 13px;
margin: 2px 0 5px;
color: #666;
}
.wpavatar-tabs-wrapper {
margin-bottom: 20px;
}
.wpavatar-sync-tabs {
display: flex;
flex-wrap: wrap;
gap: 5px;
border-bottom: 1px solid #c3c4c7;
margin-bottom: 20px;
}
.wpavatar-tab {
padding: 8px 16px;
border: none;
background: none;
cursor: pointer;
font-size: 14px;
border-bottom: 2px solid transparent;
}
.wpavatar-tab.active {
border-bottom: 2px solid #007cba;
font-weight: 600;
background: #f0f0f1;
}
.wpavatar-tab:hover:not(.active) {
background: #f0f0f1;
border-bottom-color: #dcdcde;
}
.wpavatar-card {
background: #fff;
border: 1px solid #ccd0d4;
border-radius: 4px;
margin-top: 20px;
padding: 20px;
}
.wpavatar-card h2 {
margin-top: 0;
padding-bottom: 10px;
border-bottom: 1px solid #f0f0f1;
}
.wpavatar-section-desc {
color: #666;
margin-bottom: 20px;
}
.wpavatar-stats-card {
background: #f9f9f9;
border-radius: 4px;
padding: 15px;
margin-bottom: 20px;
}
.wpavatar-stats-card h3 {
margin-top: 0;
margin-bottom: 15px;
}
.cache-stats-wrapper {
margin-top: 15px;
border-left: 4px solid #2271b1;
background: #f0f6fc;
padding: 12px;
margin-bottom: 15px;
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.04);
}
.cache-stats p {
margin: 0.5em 0;
}
.cache-stats .error {
background: #ffebee;
padding: 10px;
border-left: 4px solid #d32f2f;
}
.wpavatar-action-buttons {
display: flex;
gap: 10px;
margin-top: 15px;
}
.wpavatar-submit-wrapper {
margin-top: 20px;
padding-top: 15px;
border-top: 1px solid #f0f0f1;
}
.wpavatar-switch {
position: relative;
display: inline-flex;
align-items: center;
cursor: pointer;
}
.wpavatar-switch input {
opacity: 0;
width: 0px;
height: 0;
min-width: 0;
margin: -.25rem -0.15rem 0 0;
}
.wpavatar-slider {
position: relative;
display: inline-block;
width: 40px;
height: 20px;
background-color: #ccc;
border-radius: 34px;
transition: .4s;
}
.wpavatar-slider:before {
position: absolute;
content: "";
height: 16px;
width: 16px;
left: 2px;
bottom: 2px;
background-color: white;
border-radius: 50%;
transition: .4s;
}
.wpavatar-switch input:checked + .wpavatar-slider {
background-color: #2196F3;
}
.wpavatar-switch input:focus + .wpavatar-slider {
box-shadow: 0 0 1px #2196F3;
}
.wpavatar-switch input:checked + .wpavatar-slider:before {
transform: translateX(20px);
}
.wpavatar-switch-label {
margin-left: 10px;
}
.wpavatar-radio {
display: inline-flex;
align-items: center;
margin-bottom: 8px;
}
.wpavatar-radio-label {
margin-left: 8px;
}
.wpavatar-input {
border: 1px solid #ddd;
padding: 6px 10px;
border-radius: 4px;
}
.wpavatar-input:focus {
border-color: #2271b1;
box-shadow: 0 0 0 1px #2271b1;
outline: none;
}
.wpavatar-select {
border: 1px solid #ddd;
padding: 6px 10px;
border-radius: 4px;
height: 36px;
min-width: 240px;
}
.wpavatar-select:focus {
border-color: #2271b1;
box-shadow: 0 0 0 1px #2271b1;
outline: none;
}
.shortcode-docs {
margin-top: 20px;
background: #f9f9f9;
border: none;
border-radius: 4px;
}
.wpavatar-table-wrapper {
overflow-x: auto;
}
.wpavatar-table {
border-collapse: collapse;
width: 100%;
margin-bottom: 20px;
border: 1px solid #e2e4e7!important;
}
.wpavatar-table th {
background-color: #f6f7f7;
text-align: left;
padding: 10px;
border-bottom: 1px solid #e2e4e7;
}
.wpavatar-table td {
padding: 10px;
vertical-align: top;
border-bottom: 1px solid #f0f0f1;
}
.wpavatar-table code {
background: #f0f0f1;
padding: 3px 5px;
border-radius: 3px;
font-size: 13px;
}
.wpavatar-table ul {
margin: 0;
padding-left: 20px;
}
.notice {
padding: 8px 12px;
border-radius: 3px;
}
.notice-success {
background-color: #dff0d8;
border-left: 4px solid #46b450;
padding: 1px 12px;
}
.notice-error {
background-color: #f2dede;
border-left: 4px solid #dc3232;
}
.wpavatar-preview-container {
background: #f9f9f9;
border-radius: 4px;
padding: 15px;
margin-bottom: 20px;
}
.wpavatar-preview-wrapper {
display: flex;
flex-wrap: wrap;
gap: 30px;
margin: 15px 0;
}
.wpavatar-preview-item {
text-align: center;
}
.wpavatar-preview-item h4 {
margin-bottom: 10px;
font-weight: normal;
}
.avatar-circle {
border-radius: 50% !important;
overflow: hidden;
}
.avatar-rounded {
border-radius: 8px !important;
overflow: hidden;
}
.default-avatar-options {
display: flex;
flex-wrap: wrap;
gap: 15px;
margin-bottom: 15px;
}
.default-avatar-options label {
display: flex;
flex-direction: column;
align-items: center;
cursor: pointer;
padding: 8px;
border: 2px solid transparent;
border-radius: 5px;
width: 80px;
text-align: center;
}
.default-avatar-options label:hover {
background-color: #f0f0f1;
}
.default-avatar-options input[type="radio"] {
margin-bottom: 8px;
}
.default-avatar-options input[type="radio"]:checked + img {
border: 2px solid #2271b1;
border-radius: 50%;
}
.avatar-option-name {
margin-top: 5px;
font-size: 12px;
line-height: 1.3;
}
@media (max-width: 782px) {
.wpavatar-settings .form-table th {
width: 100%;
}
.wpavatar-action-buttons {
flex-direction: column;
}
.default-avatar-options {
gap: 10px;
}
.wpavatar-preview-wrapper {
justify-content: center;
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 MiB

BIN
assets/images/wapuu.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 28 KiB

234
assets/js/admin.js Normal file
View file

@ -0,0 +1,234 @@
jQuery(document).ready(function($) {
if (typeof wpavatar === 'undefined') {
console.error('WPAvatar admin script error: wpavatar object not defined');
return;
}
if (typeof wpavatar_l10n === 'undefined') {
console.error('WPAvatar admin script error: wpavatar_l10n object not defined');
return;
}
$('.wpavatar-tab').on('click', function() {
var tab = $(this).data('tab');
if (!tab) return;
$('.wpavatar-tab').removeClass('active');
$(this).addClass('active');
$('.wpavatar-section').hide();
$('#wpavatar-section-' + tab).show();
if (tab === 'cache' && $('#cache-stats').is(':empty')) {
setTimeout(function() {
$('#check-cache').trigger('click');
}, 300);
}
if (window.history && window.history.pushState) {
var url = new URL(window.location.href);
url.searchParams.set('tab', tab);
window.history.pushState({}, '', url);
}
});
function updateCdnOptions() {
var selectedType = $('input[name="wpavatar_cdn_type"]:checked').val();
$('.cdn-option').hide();
if (selectedType === 'cravatar_route') {
$('.cravatar-route-option').show();
forceMd5HashMethod(true);
} else if (selectedType === 'third_party') {
$('.third-party-option').show();
checkIfCravatarRelated($('select[name="wpavatar_third_party_mirror"]').val());
} else if (selectedType === 'custom') {
$('.custom-cdn-option').show();
checkIfCravatarRelated($('input[name="wpavatar_custom_cdn"]').val());
}
}
function checkIfCravatarRelated(value) {
if (value && value.toLowerCase().indexOf('cravatar') !== -1) {
forceMd5HashMethod(true);
} else {
// 非Cravatar服务默认选择SHA256但不强制
var currentHashMethod = $('input[name="wpavatar_hash_method"]:checked').val();
if (!currentHashMethod) {
$('input[name="wpavatar_hash_method"][value="sha256"]').prop('checked', true);
}
forceMd5HashMethod(false);
}
}
function forceMd5HashMethod(force) {
if (force) {
$('input[name="wpavatar_hash_method"][value="md5"]').prop('checked', true);
$('input[name="wpavatar_hash_method"][value="sha256"]').prop('disabled', true);
$('.hash-method-notice').show();
} else {
$('input[name="wpavatar_hash_method"][value="sha256"]').prop('disabled', false);
$('.hash-method-notice').hide();
}
}
$('input[name="wpavatar_cdn_type"]').on('change', updateCdnOptions);
updateCdnOptions();
$('select[name="wpavatar_third_party_mirror"]').on('change', function() {
checkIfCravatarRelated($(this).val());
});
$('input[name="wpavatar_custom_cdn"]').on('input', function() {
checkIfCravatarRelated($(this).val());
});
$('#check-cache').on('click', function() {
var $button = $(this);
var $stats = $('#cache-stats');
$button.prop('disabled', true).text(wpavatar_l10n.checking);
$stats.html('<p>' + wpavatar_l10n.checking_status + '</p>');
$.ajax({
type: 'POST',
url: wpavatar.ajaxurl,
data: {
action: 'wpavatar_check_cache',
nonce: wpavatar.nonce
},
success: function(response) {
if (response.success) {
$stats.html(response.data);
} else {
$stats.html('<div class="error"><p>' + (response.data || wpavatar_l10n.check_failed) + '</p></div>');
}
},
error: function() {
$stats.html('<div class="error"><p>' + wpavatar_l10n.request_failed + '</p></div>');
},
complete: function() {
$button.prop('disabled', false).text(wpavatar_l10n.check_cache);
}
});
});
$('#purge-cache').on('click', function() {
var $button = $(this);
var $stats = $('#cache-stats');
var $status = $('#wpavatar-status');
if (!confirm(wpavatar_l10n.confirm_purge)) {
return;
}
$button.prop('disabled', true).text(wpavatar_l10n.purging);
$stats.html('<p>' + wpavatar_l10n.purging_cache + '</p>');
$.ajax({
type: 'POST',
url: wpavatar.ajaxurl,
data: {
action: 'wpavatar_purge_cache',
nonce: wpavatar.nonce
},
success: function(response) {
if (response.success) {
$status.removeClass('notice-error')
.addClass('notice-success')
.text(response.data)
.show()
.delay(3000)
.fadeOut();
setTimeout(function() {
$('#check-cache').trigger('click');
}, 1000);
} else {
$status.removeClass('notice-success')
.addClass('notice-error')
.text(response.data || wpavatar_l10n.purge_failed)
.show();
}
},
error: function() {
$status.removeClass('notice-success')
.addClass('notice-error')
.text(wpavatar_l10n.request_failed)
.show();
},
complete: function() {
$button.prop('disabled', false).text(wpavatar_l10n.purge_cache);
}
});
});
$('#wpavatar-basic-form, #wpavatar-cache-form, #wpavatar-advanced-form, #wpavatar-shortcodes-form').on('submit', function(e) {
var formId = $(this).attr('id');
var $status = $('#wpavatar-status');
var isValid = true;
if (formId === 'wpavatar-basic-form' && $('input[name="wpavatar_cdn_type"]:checked').val() === 'custom') {
var customCdn = $('input[name="wpavatar_custom_cdn"]').val().trim();
if (!customCdn) {
$status.removeClass('notice-success')
.addClass('notice-error')
.text(wpavatar_l10n.enter_custom_cdn)
.show();
$('input[name="wpavatar_custom_cdn"]').focus();
isValid = false;
}
}
if (formId === 'wpavatar-cache-form' && $('input[name="wpavatar_enable_cache"]:checked').length > 0) {
var cachePath = $('input[name="wpavatar_cache_path"]').val().trim();
if (!cachePath) {
$status.removeClass('notice-success')
.addClass('notice-error')
.text(wpavatar_l10n.enter_cache_path)
.show();
$('input[name="wpavatar_cache_path"]').focus();
isValid = false;
}
}
if (!isValid) {
e.preventDefault();
return false;
}
return true;
});
if (window.location.search.indexOf('settings-updated=true') > -1) {
$('#wpavatar-status')
.removeClass('notice-error')
.addClass('notice-success')
.text(wpavatar_l10n.settings_saved)
.show()
.delay(3000)
.fadeOut();
}
var currentTab = '';
if (window.location.search.indexOf('tab=') > -1) {
var urlParams = new URLSearchParams(window.location.search);
currentTab = urlParams.get('tab');
}
if (!currentTab) {
var $activeTab = $('.wpavatar-tab.active');
if ($activeTab.length) {
currentTab = $activeTab.data('tab');
}
}
if (currentTab) {
$('.wpavatar-tab[data-tab="' + currentTab + '"]').trigger('click');
} else {
$('.wpavatar-tab:first').trigger('click');
}
});