Version 2.2.2-stable - Cleanup and improvements
This commit is contained in:
267
.ai-assistant.md
267
.ai-assistant.md
@ -2,25 +2,6 @@
|
|||||||
|
|
||||||
This guide helps AI assistants understand the project structure, workflows, and best practices for this repository.
|
This guide helps AI assistants understand the project structure, workflows, and best practices for this repository.
|
||||||
|
|
||||||
## AI IDE Configuration
|
|
||||||
|
|
||||||
This repository includes configuration files for various AI-powered development tools:
|
|
||||||
|
|
||||||
- `.aiconfig` - General AI configuration (model preferences, ignore patterns)
|
|
||||||
- `.augmentignore` - Ignore patterns for Augment
|
|
||||||
- `.cursorignore` - Ignore patterns for Cursor
|
|
||||||
- `.v0ignore` - Ignore patterns for v0
|
|
||||||
- `.windsurfignore` - Ignore patterns for Windsurf
|
|
||||||
- `.clinerc` - Configuration for Cline
|
|
||||||
- `.rooignore` - Ignore patterns for Roo
|
|
||||||
- `.geminiignore` - Ignore patterns for Gemini Code Assist
|
|
||||||
- `.loveablerc` - Configuration for Loveable
|
|
||||||
- `.boltignore` - Ignore patterns for Bolt
|
|
||||||
- `.codyignore` - Ignore patterns for Cody
|
|
||||||
- `.continuerc` - Configuration for Continue
|
|
||||||
|
|
||||||
All these files respect `.gitignore` patterns and only include additional tool-specific patterns. The `!` prefix can be used in these files to include files that are excluded by `.gitignore`.
|
|
||||||
|
|
||||||
## Project Overview
|
## Project Overview
|
||||||
|
|
||||||
- **Plugin Name**: Fix 'Plugin file does not exist' Notices
|
- **Plugin Name**: Fix 'Plugin file does not exist' Notices
|
||||||
@ -29,132 +10,39 @@ All these files respect `.gitignore` patterns and only include additional tool-s
|
|||||||
|
|
||||||
This plugin helps users clean up references to deleted plugins that cause "Plugin file does not exist" errors in the WordPress admin. It adds missing plugins to the plugins list with a "Remove Notice" link to safely remove invalid plugin entries.
|
This plugin helps users clean up references to deleted plugins that cause "Plugin file does not exist" errors in the WordPress admin. It adds missing plugins to the plugins list with a "Remove Notice" link to safely remove invalid plugin entries.
|
||||||
|
|
||||||
## Reference Plugins
|
## AI Workflows
|
||||||
|
|
||||||
The `reference-plugins/` directory contains plugins that can be used for reference or inspiration. When developing new features or improving existing ones, you should:
|
Detailed workflow documentation is available in the `.ai-workflows/` directory:
|
||||||
|
|
||||||
1. Examine these reference plugins for best practices in code structure, organization, and implementation
|
- **@.ai-workflows/bug-fixing.md**: Guidelines for identifying and fixing bugs
|
||||||
2. Look for patterns in how they handle similar functionality
|
- **@.ai-workflows/code-review.md**: Standards for reviewing code changes
|
||||||
3. Consider their approach to user interface design and user experience
|
- **@.ai-workflows/feature-development.md**: Process for developing new features
|
||||||
4. Study their documentation style and thoroughness
|
- **@.ai-workflows/local-env-vars.md**: Local development environment paths and URLs
|
||||||
|
- **@.ai-workflows/release-process.md**: Steps for preparing and publishing releases
|
||||||
These plugins are not part of the codebase and are ignored by Git, but they provide valuable examples of WordPress plugin development standards and techniques.
|
|
||||||
|
|
||||||
## Version Management
|
## Version Management
|
||||||
|
|
||||||
### Version Numbering Convention
|
|
||||||
|
|
||||||
We follow [Semantic Versioning](https://semver.org/):
|
We follow [Semantic Versioning](https://semver.org/):
|
||||||
- **MAJOR.MINOR.PATCH** (e.g., 1.6.0)
|
- **MAJOR.MINOR.PATCH** (e.g., 2.2.1)
|
||||||
- **MAJOR**: Breaking changes
|
- **MAJOR**: Breaking changes
|
||||||
- **MINOR**: New features, non-breaking
|
- **MINOR**: New features, non-breaking
|
||||||
- **PATCH**: Bug fixes, non-breaking
|
- **PATCH**: Bug fixes, non-breaking
|
||||||
|
|
||||||
### When to Increment Version Numbers
|
When updating version numbers, see **@.ai-workflows/release-process.md** for the complete checklist.
|
||||||
|
|
||||||
- **PATCH** (1.6.0 → 1.6.1):
|
|
||||||
- Bug fixes
|
|
||||||
- Small text changes
|
|
||||||
- Minor improvements that don't add new features
|
|
||||||
|
|
||||||
- **MINOR** (1.6.0 → 1.7.0):
|
|
||||||
- New features
|
|
||||||
- Significant improvements to existing functionality
|
|
||||||
- Deprecation of features (but not removal)
|
|
||||||
|
|
||||||
- **MAJOR** (1.6.0 → 2.0.0):
|
|
||||||
- Breaking changes
|
|
||||||
- Removal of features
|
|
||||||
- Major architectural changes
|
|
||||||
|
|
||||||
### Version Update Checklist
|
|
||||||
|
|
||||||
When updating the version number, always update these files:
|
|
||||||
1. `wp-fix-plugin-does-not-exist-notices.php` (Plugin header and version parameter in Plugin class initialization)
|
|
||||||
2. `CHANGELOG.md` (Add new version section)
|
|
||||||
3. `readme.txt` (Stable tag and Changelog section)
|
|
||||||
4. `README.md` (Update Changelog section to match readme.txt)
|
|
||||||
5. Update any JavaScript files that contain version constants (e.g., `admin/js/version-fix.js`)
|
|
||||||
6. Update `languages/wp-fix-plugin-does-not-exist-notices.pot` (Project-Id-Version and POT-Creation-Date)
|
|
||||||
|
|
||||||
**IMPORTANT**: Always ensure README.md is kept in sync with readme.txt for consistency across platforms.
|
|
||||||
|
|
||||||
## Git Workflow
|
## Git Workflow
|
||||||
|
|
||||||
### Branch Naming Convention
|
### Branch Naming Convention
|
||||||
|
|
||||||
- Feature branches: `feature/descriptive-name`
|
- Feature branches: `feature/descriptive-name`
|
||||||
- Bug fix branches: `fix/issue-description`
|
- Bug fix branches: `fix/issue-description`
|
||||||
- Release branches: `v{MAJOR}.{MINOR}.{PATCH}`
|
- Release branches: `v{MAJOR}.{MINOR}.{PATCH}`
|
||||||
|
|
||||||
### Commit Message Guidelines
|
### Commit Message Guidelines
|
||||||
|
|
||||||
- Use present tense ("Add feature" not "Added feature")
|
- Use present tense ("Add feature" not "Added feature")
|
||||||
- Start with a verb
|
- Start with a verb
|
||||||
- Keep the first line under 50 characters
|
- Keep the first line under 50 characters
|
||||||
- Reference issues when relevant: "Fix #123: Resolve plugin detection issue"
|
- Reference issues when relevant: "Fix #123: Resolve plugin detection issue"
|
||||||
|
|
||||||
### Pre-Release Checklist
|
|
||||||
|
|
||||||
Before creating a new release, verify the following:
|
|
||||||
|
|
||||||
- [ ] Determine the correct version increment (MAJOR, MINOR, or PATCH) based on the changes
|
|
||||||
- [ ] Ensure all changes are documented in CHANGELOG.md
|
|
||||||
- [ ] Verify all code changes are tested and working correctly
|
|
||||||
- [ ] Check that all files are properly formatted and follow WordPress coding standards
|
|
||||||
- [ ] Ensure Git Updater configuration is correct (if applicable)
|
|
||||||
|
|
||||||
### Release Process
|
|
||||||
|
|
||||||
1. Create a new branch for the version: `git checkout -b v{MAJOR}.{MINOR}.{PATCH}` or use an existing feature branch
|
|
||||||
2. Update version numbers in ALL required files:
|
|
||||||
- `wp-fix-plugin-does-not-exist-notices.php` (Plugin header and version parameter in Plugin class initialization)
|
|
||||||
- `readme.txt` (Stable tag and Changelog section)
|
|
||||||
- `CHANGELOG.md` (Add new version section at the top)
|
|
||||||
- Any JavaScript files with version constants (e.g., `admin/js/version-fix.js`)
|
|
||||||
- `languages/wp-fix-plugin-does-not-exist-notices.pot` (Project-Id-Version)
|
|
||||||
3. Run the build script to create the plugin ZIP file and deploy to local testing environment:
|
|
||||||
```
|
|
||||||
./build.sh {MAJOR}.{MINOR}.{PATCH}
|
|
||||||
```
|
|
||||||
4. Test the plugin thoroughly in the local WordPress environment
|
|
||||||
5. Commit changes: `git commit -m "Version {MAJOR}.{MINOR}.{PATCH} - Brief description of changes"`
|
|
||||||
6. Create a tag for the new version:
|
|
||||||
```
|
|
||||||
git tag -a v{MAJOR}.{MINOR}.{PATCH} -m "Version {MAJOR}.{MINOR}.{PATCH} - Brief description of changes"
|
|
||||||
```
|
|
||||||
7. Push the branch and tag to all remotes:
|
|
||||||
```
|
|
||||||
git push github feature/branch-name
|
|
||||||
git push gitea feature/branch-name
|
|
||||||
git push github v{MAJOR}.{MINOR}.{PATCH}
|
|
||||||
git push gitea v{MAJOR}.{MINOR}.{PATCH}
|
|
||||||
```
|
|
||||||
8. Verify the GitHub release is created with the ZIP file attached
|
|
||||||
9. When ready to merge to main, create a pull request or merge directly:
|
|
||||||
```
|
|
||||||
git checkout main
|
|
||||||
git merge feature/branch-name --no-ff
|
|
||||||
git push github main
|
|
||||||
git push gitea main
|
|
||||||
```
|
|
||||||
|
|
||||||
## Build Process
|
|
||||||
|
|
||||||
The build process is handled by `build.sh`:
|
|
||||||
1. Creates build directory
|
|
||||||
2. Installs composer dependencies
|
|
||||||
3. Copies required files to build directory
|
|
||||||
4. Creates ZIP file
|
|
||||||
5. Automatically deploys to local WordPress testing environment
|
|
||||||
|
|
||||||
To build the plugin and deploy to local testing:
|
|
||||||
```
|
|
||||||
./build.sh {MAJOR}.{MINOR}.{PATCH}
|
|
||||||
```
|
|
||||||
|
|
||||||
This will create a ZIP file named `wp-fix-plugin-does-not-exist-notices-{MAJOR}.{MINOR}.{PATCH}.zip` and deploy the plugin to your local WordPress testing environment.
|
|
||||||
|
|
||||||
## Remote Repositories
|
## Remote Repositories
|
||||||
|
|
||||||
The plugin is hosted on multiple repositories:
|
The plugin is hosted on multiple repositories:
|
||||||
@ -164,13 +52,15 @@ The plugin is hosted on multiple repositories:
|
|||||||
|
|
||||||
Always push changes to all remotes to keep them in sync.
|
Always push changes to all remotes to keep them in sync.
|
||||||
|
|
||||||
## GitHub Actions
|
## Git Updater Integration
|
||||||
|
|
||||||
The repository uses GitHub Actions for automated builds and deployments:
|
The plugin integrates with Git Updater to allow updates directly from GitHub or Gitea. Important notes:
|
||||||
- Triggered by tags matching the pattern `v*`
|
|
||||||
- Builds the plugin
|
1. Git Updater reads version information from the readme.txt file in the main branch, not from tags or releases
|
||||||
- Creates a GitHub release
|
2. Always merge release changes to the main branch immediately after creating a tag
|
||||||
- Deploys to WordPress.org
|
3. The plugin includes proper headers for Git Updater in the main plugin file
|
||||||
|
|
||||||
|
See **@.ai-workflows/release-process.md** for detailed Git Updater integration steps.
|
||||||
|
|
||||||
## Testing Guidelines
|
## Testing Guidelines
|
||||||
|
|
||||||
@ -180,125 +70,8 @@ Before releasing:
|
|||||||
3. Verify all features work as expected
|
3. Verify all features work as expected
|
||||||
4. Check for any PHP warnings or notices
|
4. Check for any PHP warnings or notices
|
||||||
|
|
||||||
### Local Testing Environment
|
Local environment variables and paths are documented in **@.ai-workflows/local-env-vars.md**.
|
||||||
|
|
||||||
Local environment variables and paths are documented in `.ai-workflows/local-env-vars.md`. This includes:
|
## Common Tasks
|
||||||
|
|
||||||
- Repository paths
|
For detailed instructions on common tasks like creating releases, adding features, fixing bugs, and testing previous versions, see **@.ai-workflows/release-process.md**.
|
||||||
- Local WordPress testing environment paths
|
|
||||||
- URLs for testing and development tools
|
|
||||||
- Build and deploy script locations
|
|
||||||
|
|
||||||
Refer to this file for the most up-to-date information about the local development environment.
|
|
||||||
|
|
||||||
### Using WP-CLI with LocalWP
|
|
||||||
|
|
||||||
WP-CLI can be used with LocalWP for various tasks:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
# Navigate to the WordPress directory
|
|
||||||
cd ~/Local/plugin-testing/app/public
|
|
||||||
|
|
||||||
# Run WP-CLI commands
|
|
||||||
~/Local/plugin-testing/app/bin/wp plugin list
|
|
||||||
~/Local/plugin-testing/app/bin/wp transient delete --all
|
|
||||||
~/Local/plugin-testing/app/bin/wp cache flush
|
|
||||||
```
|
|
||||||
|
|
||||||
## Common Tasks for AI Assistants
|
|
||||||
|
|
||||||
### Creating a New Release
|
|
||||||
|
|
||||||
```
|
|
||||||
# 1. Start from a feature branch or create a new branch
|
|
||||||
git checkout feature/branch-name
|
|
||||||
# or
|
|
||||||
git checkout -b feature/new-feature-name
|
|
||||||
|
|
||||||
# 2. Update version numbers in ALL required files
|
|
||||||
# - wp-fix-plugin-does-not-exist-notices.php (header and class initialization)
|
|
||||||
# - CHANGELOG.md
|
|
||||||
# - readme.txt (Stable tag and Changelog section)
|
|
||||||
# - Any JavaScript files with version constants
|
|
||||||
# - languages/wp-fix-plugin-does-not-exist-notices.pot
|
|
||||||
|
|
||||||
# 3. Build and test locally
|
|
||||||
./build.sh 1.7.0
|
|
||||||
# Test in local WordPress environment
|
|
||||||
|
|
||||||
# 4. Commit changes
|
|
||||||
git add .
|
|
||||||
git commit -m "Version 1.7.0 - Brief description of changes"
|
|
||||||
|
|
||||||
# 5. Create a tag
|
|
||||||
git tag -a v1.7.0 -m "Version 1.7.0 - Brief description of changes"
|
|
||||||
|
|
||||||
# 6. Push branch and tag to remotes
|
|
||||||
git push github feature/branch-name
|
|
||||||
git push gitea feature/branch-name
|
|
||||||
git push github v1.7.0
|
|
||||||
git push gitea v1.7.0
|
|
||||||
|
|
||||||
# 7. Verify GitHub release is created with ZIP file
|
|
||||||
# Check: https://github.com/wpallstars/wp-fix-plugin-does-not-exist-notices/releases
|
|
||||||
|
|
||||||
# 8. Merge to main when ready
|
|
||||||
git checkout main
|
|
||||||
git merge feature/branch-name --no-ff
|
|
||||||
git push github main
|
|
||||||
git push gitea main
|
|
||||||
```
|
|
||||||
|
|
||||||
### Adding a New Feature
|
|
||||||
|
|
||||||
```
|
|
||||||
# 1. Create feature branch from main
|
|
||||||
git checkout main
|
|
||||||
git checkout -b feature/new-feature-name
|
|
||||||
|
|
||||||
# 2. Make changes and commit
|
|
||||||
git add .
|
|
||||||
git commit -m "Add new feature"
|
|
||||||
|
|
||||||
# 3. Test locally
|
|
||||||
# (Run tests, verify functionality)
|
|
||||||
|
|
||||||
# 4. When ready for release, merge to a version branch
|
|
||||||
git checkout -b v1.7.0
|
|
||||||
git merge feature/new-feature-name --no-ff
|
|
||||||
|
|
||||||
# 5. Continue with the release process
|
|
||||||
# (Update version numbers, etc.)
|
|
||||||
```
|
|
||||||
|
|
||||||
### Fixing a Bug
|
|
||||||
|
|
||||||
```
|
|
||||||
# 1. Create bugfix branch from main
|
|
||||||
git checkout main
|
|
||||||
git checkout -b fix/bug-description
|
|
||||||
|
|
||||||
# 2. Make changes and commit
|
|
||||||
git add .
|
|
||||||
git commit -m "Fix #123: Fix bug description"
|
|
||||||
|
|
||||||
# 3. Test locally
|
|
||||||
# (Run tests, verify functionality)
|
|
||||||
|
|
||||||
# 4. When ready for release, merge to a version branch
|
|
||||||
git checkout -b v1.6.5
|
|
||||||
git merge fix/bug-description --no-ff
|
|
||||||
|
|
||||||
# 5. Continue with the release process
|
|
||||||
# (Update version numbers, etc.)
|
|
||||||
```
|
|
||||||
|
|
||||||
### Testing a Previous Version
|
|
||||||
|
|
||||||
```
|
|
||||||
# Checkout a specific tag for testing
|
|
||||||
git checkout v1.6.3
|
|
||||||
|
|
||||||
# Or create a test branch from a specific tag
|
|
||||||
git checkout v1.6.3 -b test/some-feature
|
|
||||||
```
|
|
||||||
|
@ -7,6 +7,7 @@ This directory contains workflow documentation for AI assistants working with th
|
|||||||
- **bug-fixing.md**: Guidelines for identifying and fixing bugs in the codebase
|
- **bug-fixing.md**: Guidelines for identifying and fixing bugs in the codebase
|
||||||
- **code-review.md**: Standards and procedures for reviewing code changes
|
- **code-review.md**: Standards and procedures for reviewing code changes
|
||||||
- **feature-development.md**: Process for developing new features
|
- **feature-development.md**: Process for developing new features
|
||||||
|
- **local-env-vars.md**: Local development environment paths and URLs
|
||||||
- **release-process.md**: Steps for preparing and publishing new releases
|
- **release-process.md**: Steps for preparing and publishing new releases
|
||||||
|
|
||||||
These documents help ensure consistent quality and approach when using AI tools to assist with development tasks.
|
These documents help ensure consistent quality and approach when using AI tools to assist with development tasks.
|
||||||
|
@ -63,13 +63,15 @@ new WPALLSTARS\FixPluginDoesNotExistNotices\Plugin(__FILE__, '{MAJOR}.{MINOR}.{P
|
|||||||
|
|
||||||
#### b. JavaScript Files with Version Constants
|
#### b. JavaScript Files with Version Constants
|
||||||
|
|
||||||
Check for any JavaScript files that contain version constants, such as `admin/js/version-fix.js`:
|
Check for any JavaScript files that might contain version constants:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
// Current plugin version - this should match the version in the main plugin file
|
// Current plugin version - this should match the version in the main plugin file
|
||||||
const CURRENT_VERSION = '{MAJOR}.{MINOR}.{PATCH}';
|
const CURRENT_VERSION = '{MAJOR}.{MINOR}.{PATCH}';
|
||||||
```
|
```
|
||||||
|
|
||||||
|
**Note**: As of version 2.2.1, we've removed redundant JavaScript files like `version-fix.js` since Git Updater now correctly detects the version from the main branch.
|
||||||
|
|
||||||
#### c. CHANGELOG.md
|
#### c. CHANGELOG.md
|
||||||
|
|
||||||
Add a new section at the top of the CHANGELOG.md file:
|
Add a new section at the top of the CHANGELOG.md file:
|
||||||
@ -170,9 +172,11 @@ https://github.com/wpallstars/wp-fix-plugin-does-not-exist-notices/releases
|
|||||||
If the release doesn't appear or doesn't have the ZIP file attached, check the GitHub Actions page:
|
If the release doesn't appear or doesn't have the ZIP file attached, check the GitHub Actions page:
|
||||||
https://github.com/wpallstars/wp-fix-plugin-does-not-exist-notices/actions
|
https://github.com/wpallstars/wp-fix-plugin-does-not-exist-notices/actions
|
||||||
|
|
||||||
### 8. Merge to Main (When Ready)
|
### 8. Merge to Main (CRITICAL STEP)
|
||||||
|
|
||||||
When you're satisfied with the release, merge the feature branch to main:
|
**IMPORTANT**: This step is critical for Git Updater to detect the new version. Git Updater reads the readme.txt file from the main branch, not from tags or releases.
|
||||||
|
|
||||||
|
Merge the feature branch to main immediately after pushing the tag:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
git checkout main
|
git checkout main
|
||||||
@ -183,6 +187,8 @@ git push gitea main
|
|||||||
|
|
||||||
The `--no-ff` flag creates a merge commit even if a fast-forward merge is possible, which helps preserve the branch history.
|
The `--no-ff` flag creates a merge commit even if a fast-forward merge is possible, which helps preserve the branch history.
|
||||||
|
|
||||||
|
**Note**: Only use named branches like feature/*, fix/*, etc. for development. Release branches (v*) should always be merged to main immediately after tagging to ensure Git Updater can detect the new version.
|
||||||
|
|
||||||
### 9. Verify Release
|
### 9. Verify Release
|
||||||
|
|
||||||
- [ ] Check that the GitHub release was created successfully with the ZIP file attached
|
- [ ] Check that the GitHub release was created successfully with the ZIP file attached
|
||||||
|
@ -1,5 +1,13 @@
|
|||||||
All notable changes to this project should be documented both here and in the main Readme files.
|
All notable changes to this project should be documented both here and in the main Readme files.
|
||||||
|
|
||||||
|
#### [2.2.2-stable] - 2025-04-14
|
||||||
|
#### Changed
|
||||||
|
- Renamed includes files to lowercase for consistency with the rest of the codebase
|
||||||
|
- Removed redundant Git Updater patches and version-fix.js as they're no longer needed
|
||||||
|
- Improved documentation for Git Updater integration and release process
|
||||||
|
- Fixed token-efficient documentation with references to .ai-workflows files
|
||||||
|
- Added comprehensive release process documentation with emphasis on merging to main branch
|
||||||
|
|
||||||
#### [2.2.1] - 2025-04-14
|
#### [2.2.1] - 2025-04-14
|
||||||
#### Changed
|
#### Changed
|
||||||
- Commented out version-fix.js script as it's no longer needed after refactoring
|
- Commented out version-fix.js script as it's no longer needed after refactoring
|
||||||
|
@ -1,75 +0,0 @@
|
|||||||
/**
|
|
||||||
* Fix Plugin Version Display
|
|
||||||
*
|
|
||||||
* This script directly modifies the plugin details popup to show the correct version
|
|
||||||
* when the popup is opened for our plugin.
|
|
||||||
*/
|
|
||||||
(function($) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
// Current plugin version - this should match the version in the main plugin file
|
|
||||||
const CURRENT_VERSION = '2.2.1';
|
|
||||||
|
|
||||||
// Plugin slugs to check for
|
|
||||||
const OUR_SLUGS = ['wp-fix-plugin-does-not-exist-notices', 'fix-plugin-does-not-exist-notices'];
|
|
||||||
|
|
||||||
// Function to fix the version in the plugin details popup
|
|
||||||
function fixPluginDetailsVersion() {
|
|
||||||
// Check if we're on the plugins page
|
|
||||||
if (window.location.href.indexOf('plugins.php') === -1) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Wait for the thickbox to be initialized
|
|
||||||
$(document).on('tb_init', function() {
|
|
||||||
// Set a timeout to allow the thickbox content to load
|
|
||||||
setTimeout(function() {
|
|
||||||
// Get the thickbox iframe
|
|
||||||
const $iframe = $('#TB_iframeContent');
|
|
||||||
if (!$iframe.length) return;
|
|
||||||
|
|
||||||
// Wait for iframe to load
|
|
||||||
$iframe.on('load', function() {
|
|
||||||
try {
|
|
||||||
const iframeDoc = this.contentDocument || this.contentWindow.document;
|
|
||||||
|
|
||||||
// Get the plugin title from the iframe
|
|
||||||
const $title = $(iframeDoc).find('h2.plugin-title');
|
|
||||||
if (!$title.length) return;
|
|
||||||
|
|
||||||
// Check if this is our plugin
|
|
||||||
const titleText = $title.text();
|
|
||||||
if (titleText.indexOf('Fix \'Plugin file does not exist\' Notices') !== -1) {
|
|
||||||
console.log('Found our plugin in the details popup, fixing version...');
|
|
||||||
|
|
||||||
// Find the version element
|
|
||||||
const $version = $(iframeDoc).find('.plugin-version-author-uri');
|
|
||||||
if ($version.length) {
|
|
||||||
// Update the version text
|
|
||||||
const versionText = $version.text();
|
|
||||||
const newVersionText = versionText.replace(/Version: [0-9.]+|Version: 0\.0\.0/, 'Version: ' + CURRENT_VERSION);
|
|
||||||
$version.text(newVersionText);
|
|
||||||
console.log('Updated version to: ' + CURRENT_VERSION);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Also update the version in the header if it exists
|
|
||||||
const $versionHeader = $(iframeDoc).find('.wrap h2:contains("Version:")');
|
|
||||||
if ($versionHeader.length) {
|
|
||||||
$versionHeader.text('Version: ' + CURRENT_VERSION);
|
|
||||||
console.log('Updated version header to: ' + CURRENT_VERSION);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
console.error('Error updating plugin version:', e);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}, 500);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize when the document is ready
|
|
||||||
$(document).ready(function() {
|
|
||||||
fixPluginDetailsVersion();
|
|
||||||
});
|
|
||||||
|
|
||||||
})(jQuery);
|
|
@ -142,159 +142,17 @@ class Plugin {
|
|||||||
/**
|
/**
|
||||||
* Initialize Git Updater fixes
|
* Initialize Git Updater fixes
|
||||||
*
|
*
|
||||||
* This function adds filters to fix Git Updater's handling of 'main' vs 'master' branches
|
* This function previously added filters to fix Git Updater's handling of 'main' vs 'master' branches.
|
||||||
* Note: This fix is commented out as we're now using the proper plugin headers instead.
|
* These fixes are no longer needed with proper plugin headers.
|
||||||
* See: https://git-updater.com/knowledge-base/required-headers/
|
* See: https://git-updater.com/knowledge-base/required-headers/
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
private function init_git_updater_fixes() {
|
private function init_git_updater_fixes() {
|
||||||
// These fixes are no longer needed with proper plugin headers
|
// No fixes needed - we're using the proper plugin headers
|
||||||
// Keeping the code commented for reference
|
// Git Updater reads version information from the readme.txt file in the main branch
|
||||||
|
|
||||||
/*
|
|
||||||
// Fix for Git Updater looking for 'master' branch instead of 'main'
|
|
||||||
add_filter('gu_get_repo_branch', array($this, 'override_branch'), 999, 3);
|
|
||||||
|
|
||||||
// Fix for Git Updater API URLs
|
|
||||||
add_filter('gu_get_repo_api', array($this, 'override_api_url'), 999, 3);
|
|
||||||
|
|
||||||
// Fix for Git Updater download URLs
|
|
||||||
add_filter('gu_download_link', array($this, 'override_download_link'), 999, 3);
|
|
||||||
|
|
||||||
// Fix for Git Updater repository metadata
|
|
||||||
add_filter('gu_get_repo_meta', array($this, 'override_repo_meta'), 999, 2);
|
|
||||||
|
|
||||||
// Fix for Git Updater API responses
|
|
||||||
add_filter('gu_api_repo_type_data', array($this, 'override_repo_type_data'), 999, 3);
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
// Git Updater override methods have been removed as they're no longer needed
|
||||||
* Override the branch name for our plugin
|
// We now use the proper plugin headers for Git Updater integration
|
||||||
*
|
|
||||||
* @param string $branch The current branch name
|
|
||||||
* @param string $git The git service (github, gitlab, etc.)
|
|
||||||
* @param object|null $repo The repository object (optional)
|
|
||||||
* @return string The modified branch name
|
|
||||||
*/
|
|
||||||
public function override_branch($branch, $git, $repo = null) {
|
|
||||||
// If repo is null or not an object, just return the branch unchanged
|
|
||||||
if (!is_object($repo)) {
|
|
||||||
return $branch;
|
|
||||||
}
|
|
||||||
if (isset($repo->slug) &&
|
|
||||||
(strpos($repo->slug, 'wp-fix-plugin-does-not-exist-notices') !== false ||
|
|
||||||
strpos($repo->slug, 'fix-plugin-does-not-exist-notices') !== false)) {
|
|
||||||
return 'main';
|
|
||||||
}
|
|
||||||
return $branch;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Override the API URL for our plugin
|
|
||||||
*
|
|
||||||
* @param mixed $api_url The current API URL (can be string or object)
|
|
||||||
* @param string $git The git service (github, gitlab, etc.)
|
|
||||||
* @param object|null $repo The repository object (optional)
|
|
||||||
* @return mixed The modified API URL (same type as input)
|
|
||||||
*/
|
|
||||||
public function override_api_url($api_url, $git, $repo = null) {
|
|
||||||
// If repo is null or not an object, just return the URL unchanged
|
|
||||||
if (!is_object($repo)) {
|
|
||||||
return $api_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if this is our plugin
|
|
||||||
if (isset($repo->slug) &&
|
|
||||||
(strpos($repo->slug, 'wp-fix-plugin-does-not-exist-notices') !== false ||
|
|
||||||
strpos($repo->slug, 'fix-plugin-does-not-exist-notices') !== false)) {
|
|
||||||
|
|
||||||
// Only apply str_replace if $api_url is a string
|
|
||||||
if (is_string($api_url)) {
|
|
||||||
return str_replace('/master/', '/main/', $api_url);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If $api_url is an object, just return it unchanged
|
|
||||||
// This handles the case where Git Updater passes a GitHub_API object
|
|
||||||
return $api_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return unchanged if not our plugin
|
|
||||||
return $api_url;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Override the download link for our plugin
|
|
||||||
*
|
|
||||||
* @param string $download_link The current download link
|
|
||||||
* @param string $git The git service (github, gitlab, etc.)
|
|
||||||
* @param object|null $repo The repository object (optional)
|
|
||||||
* @return string The modified download link
|
|
||||||
*/
|
|
||||||
public function override_download_link($download_link, $git, $repo = null) {
|
|
||||||
// If repo is null or not an object, just return the link unchanged
|
|
||||||
if (!is_object($repo)) {
|
|
||||||
return $download_link;
|
|
||||||
}
|
|
||||||
if (isset($repo->slug) &&
|
|
||||||
(strpos($repo->slug, 'wp-fix-plugin-does-not-exist-notices') !== false ||
|
|
||||||
strpos($repo->slug, 'fix-plugin-does-not-exist-notices') !== false)) {
|
|
||||||
return str_replace('/master.zip', '/main.zip', $download_link);
|
|
||||||
}
|
|
||||||
return $download_link;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Override repository metadata for our plugin
|
|
||||||
*
|
|
||||||
* @param array $repo_meta The repository metadata
|
|
||||||
* @param object $repo The repository object
|
|
||||||
* @return array The modified repository metadata
|
|
||||||
*/
|
|
||||||
public function override_repo_meta($repo_meta, $repo) {
|
|
||||||
if (isset($repo->slug) &&
|
|
||||||
(strpos($repo->slug, 'wp-fix-plugin-does-not-exist-notices') !== false ||
|
|
||||||
strpos($repo->slug, 'fix-plugin-does-not-exist-notices') !== false)) {
|
|
||||||
|
|
||||||
// Set the correct repository information
|
|
||||||
$repo_meta['github_updater_repo'] = 'wp-fix-plugin-does-not-exist-notices';
|
|
||||||
$repo_meta['github_updater_branch'] = 'main';
|
|
||||||
$repo_meta['github_updater_api'] = 'https://api.github.com';
|
|
||||||
$repo_meta['github_updater_raw'] = 'https://raw.githubusercontent.com/wpallstars/wp-fix-plugin-does-not-exist-notices/main';
|
|
||||||
}
|
|
||||||
return $repo_meta;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Override repository type data for our plugin
|
|
||||||
*
|
|
||||||
* @param array $data The repository data
|
|
||||||
* @param object $response The API response
|
|
||||||
* @param object|null $repo The repository object (optional)
|
|
||||||
* @return array The modified repository data
|
|
||||||
*/
|
|
||||||
public function override_repo_type_data($data, $response, $repo = null) {
|
|
||||||
// If repo is null or not an object, just return the data unchanged
|
|
||||||
if (!is_object($repo)) {
|
|
||||||
return $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if this is our plugin
|
|
||||||
if (isset($repo->slug) &&
|
|
||||||
(strpos($repo->slug, 'wp-fix-plugin-does-not-exist-notices') !== false ||
|
|
||||||
strpos($repo->slug, 'fix-plugin-does-not-exist-notices') !== false)) {
|
|
||||||
|
|
||||||
// Set the correct branch
|
|
||||||
if (isset($data['branch'])) {
|
|
||||||
$data['branch'] = 'main';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set the correct version
|
|
||||||
if (isset($data['version'])) {
|
|
||||||
$data['version'] = FPDEN_VERSION;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $data;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ Tags: plugins, missing plugins, cleanup, error fix, admin tools, plugin file doe
|
|||||||
Requires at least: 5.0
|
Requires at least: 5.0
|
||||||
Tested up to: 6.7.2
|
Tested up to: 6.7.2
|
||||||
Requires PHP: 7.0
|
Requires PHP: 7.0
|
||||||
Stable tag: 2.2.1
|
Stable tag: 2.2.2-stable
|
||||||
License: GPL-2.0+
|
License: GPL-2.0+
|
||||||
License URI: https://www.gnu.org/licenses/gpl-2.0.html
|
License URI: https://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
@ -179,6 +179,13 @@ Manually editing the WordPress database is risky and requires technical knowledg
|
|||||||
|
|
||||||
== Changelog ==
|
== Changelog ==
|
||||||
|
|
||||||
|
= 2.2.2-stable =
|
||||||
|
* Changed: Renamed includes files to lowercase for consistency with the rest of the codebase
|
||||||
|
* Removed: Redundant Git Updater patches and version-fix.js as they're no longer needed
|
||||||
|
* Improved: Documentation for Git Updater integration and release process
|
||||||
|
* Fixed: Token-efficient documentation with references to .ai-workflows files
|
||||||
|
* Added: Comprehensive release process documentation with emphasis on merging to main branch
|
||||||
|
|
||||||
= 2.2.1 =
|
= 2.2.1 =
|
||||||
* Changed: Commented out version-fix.js script as it's no longer needed after refactoring
|
* Changed: Commented out version-fix.js script as it's no longer needed after refactoring
|
||||||
* Fixed: Version consistency across all files
|
* Fixed: Version consistency across all files
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
* Plugin Name: Fix 'Plugin file does not exist' Notices
|
* Plugin Name: Fix 'Plugin file does not exist' Notices
|
||||||
* Plugin URI: https://www.wpallstars.com
|
* Plugin URI: https://www.wpallstars.com
|
||||||
* Description: Adds missing plugins to your plugins list with a "Remove Notice" action link, allowing you to safely clean up invalid plugin references.
|
* Description: Adds missing plugins to your plugins list with a "Remove Notice" action link, allowing you to safely clean up invalid plugin references.
|
||||||
* Version: 2.2.1
|
* Version: 2.2.2-stable
|
||||||
* Author: Marcus Quinn & The WPALLSTARS Team
|
* Author: Marcus Quinn & The WPALLSTARS Team
|
||||||
* Author URI: https://www.wpallstars.com
|
* Author URI: https://www.wpallstars.com
|
||||||
* License: GPL-2.0+
|
* License: GPL-2.0+
|
||||||
@ -35,4 +35,4 @@ if (!defined('WPINC')) {
|
|||||||
require_once plugin_dir_path(__FILE__) . 'includes/Plugin.php';
|
require_once plugin_dir_path(__FILE__) . 'includes/Plugin.php';
|
||||||
|
|
||||||
// Initialize the plugin
|
// Initialize the plugin
|
||||||
new WPALLSTARS\FixPluginDoesNotExistNotices\Plugin(__FILE__, '2.2.1');
|
new WPALLSTARS\FixPluginDoesNotExistNotices\Plugin(__FILE__, '2.2.2-stable');
|
||||||
|
@ -1,32 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Plugin Name: Fix 'Plugin file does not exist' Notices
|
|
||||||
* Plugin URI: https://www.wpallstars.com
|
|
||||||
* Description: Adds missing plugins to your plugins list with a "Remove Notice" action link, allowing you to safely clean up invalid plugin references.
|
|
||||||
* Version: 2.2.0
|
|
||||||
* Author: Marcus Quinn & The WPALLSTARS Team
|
|
||||||
* Author URI: https://www.wpallstars.com
|
|
||||||
* License: GPL-2.0+
|
|
||||||
* License URI: http://www.gnu.org/licenses/gpl-2.0.txt
|
|
||||||
* Text Domain: wp-fix-plugin-does-not-exist-notices
|
|
||||||
* Domain Path: /languages
|
|
||||||
* GitHub Plugin URI: wpallstars/wp-fix-plugin-does-not-exist-notices
|
|
||||||
* GitHub Branch: main
|
|
||||||
* Primary Branch: main
|
|
||||||
* Release Branch: main
|
|
||||||
* Release Asset: true
|
|
||||||
* Update URI: https://github.com/wpallstars/wp-fix-plugin-does-not-exist-notices
|
|
||||||
*
|
|
||||||
* @package WPALLSTARS\FixPluginDoesNotExistNotices
|
|
||||||
*/
|
|
||||||
|
|
||||||
// If this file is called directly, abort.
|
|
||||||
if (!defined('WPINC')) {
|
|
||||||
die;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Load the main plugin class
|
|
||||||
require_once plugin_dir_path(__FILE__) . 'includes/Plugin.php';
|
|
||||||
|
|
||||||
// Initialize the plugin
|
|
||||||
new WPALLSTARS\FixPluginDoesNotExistNotices\Plugin(__FILE__, '2.2.0');
|
|
Reference in New Issue
Block a user