Skip to content

Commit

Permalink
Merge branch 'main' into enhance/PRESS7-77-skip-404
Browse files Browse the repository at this point in the history
  • Loading branch information
AleTorrisi committed Dec 30, 2024
2 parents 835ab32 + 2a21b50 commit d459a0a
Show file tree
Hide file tree
Showing 24 changed files with 3,140 additions and 2,713 deletions.
14 changes: 7 additions & 7 deletions .github/workflows/lint.yml
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
name: Lint
name: 'Lint Checker: PHP'

on:
push:
branches:
- '**'
paths:
- '**.php'
pull_request:
Expand All @@ -24,25 +23,26 @@ jobs:
- name: Checkout
uses: actions/checkout@v3

# User PHP 7.4 here for compatibility with the WordPress codesniffer rules.
- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: '7.4'
php-version: '8.2'
coverage: none
tools: composer, cs2pr

- uses: technote-space/get-diff-action@v6
with:
SUFFIX_FILTER: .php
PATTERNS: |
**/*.php
!build/**/*.php
- name: Get Composer cache directory
id: composer-cache
run: echo "dir=$(composer config cache-files-dir)" >> $GITHUB_OUTPUT
if: "!! env.GIT_DIFF"

- name: Cache Composer vendor directory
uses: actions/cache@v3
uses: actions/cache@v4
with:
path: ${{ steps.composer-cache.outputs.dir }}
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
// WordPress
import { useState } from '@wordpress/element';

// Newfold
import { Spinner } from '@newfold/ui-component-library';
import { NewfoldRuntime } from '@newfold-labs/wp-module-runtime';

const InstallActivatePluginButton = ( {
methods,
constants,
setModuleStatus,
} ) => {
const [ isLoading, setIsLoading ] = useState( false );
const [ isActive, setIsActive ] = useState( false );
const [ message, setMessage ] = useState( null );

const handleInstallActivate = async () => {
setIsLoading( true );
setMessage( constants.text.jetpackBoostInstalling );

const apiUrl = methods.NewfoldRuntime.createApiUrl(
'/newfold-installer/v1/plugins/install'
);
const INSTALL_TOKEN = NewfoldRuntime.sdk.performance.install_token;
const plugin = 'jetpack-boost';

try {
await methods.apiFetch( {
url: apiUrl,
method: 'POST',
headers: { 'X-NFD-INSTALLER': INSTALL_TOKEN },
data: { plugin, activate: true, queue: false },
} );
setIsActive( true );
setModuleStatus( true );
setMessage( constants.text.jetpackBoostInstalling );
} catch ( error ) {
setMessage( constants.text.jetpackBoostActivationFailed );
} finally {
setIsLoading( false );
}
};

return (
<div className="nfd-performance-jetpack-boost-container-install-activate-button">
<button
className="nfd-button--upsell"
onClick={ handleInstallActivate }
>
{ isLoading ? (
<>
<Spinner />
<p>{ message }</p>
</>
) : (
! isActive && (
<>
<span>
<svg
xmlns="http://www.w3.org/2000/svg"
fill="none"
viewBox="0 0 24 24"
strokeWidth="2"
stroke="currentColor"
aria-hidden="true"
className="nfd-w-5 nfd-h-5 nfd--ml-1 nfd-shrink-0"
role="img"
>
<path
strokeLinecap="round"
strokeLinejoin="round"
d="M8 11V7a4 4 0 118 0m-4 8v2m-6 4h12a2 2 0 002-2v-6a2 2 0 00-2-2H6a2 2 0 00-2 2v6a2 2 0 002 2z"
></path>
</svg>
</span>
<span>{ constants.text.jetpackBoostCtaText }</span>
</>
)
) }
</button>
</div>
);
};

export default InstallActivatePluginButton;
184 changes: 184 additions & 0 deletions components/advancedSettings/JetpackBoost/SingleOption.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,184 @@
// WordPress
import apiFetch from '@wordpress/api-fetch';
import { useRef, useState } from '@wordpress/element';

// Newfold
import {
ToggleField,
Textarea,
FeatureUpsell,
} from '@newfold/ui-component-library';
import { NewfoldRuntime } from '@newfold-labs/wp-module-runtime';

// Third-parts
import parse from 'html-react-parser';

const SingleOption = ( { params, isChild, methods, constants } ) => {
const [ optionDetails, setOptionDetails ] = useState( {
id: params.id,
label: params.label,
description: params.description,
value: params.value ? String( params.value ) : '',
type: params.type,
externalText: params.externalText,
premiumUrl: params.premiumUrl ?? '',
children: params.children,
} );

const [ isShown, setIsShown ] = useState( false );

const debounceTimeout = useRef( null ); // Mantiene il timeout tra i render

const handleChangeOption = ( value, id ) => {
if ( typeof value === 'object' ) {
value = value.target.value;
}

setOptionDetails( { ...optionDetails, value } );

// Clear the previous timeout if user types again.
if ( debounceTimeout.current ) {
clearTimeout( debounceTimeout.current );
}

// Set a new timeout of 2 seconds.
debounceTimeout.current = setTimeout( () => {
apiFetch( {
path: 'newfold-performance/v1/jetpack/settings',
method: 'POST',
data: {
field: {
id,
value,
},
},
} )
.then( () => {
methods.makeNotice(
'cache-level-change-notice',
constants.text.optionSet,
'',
'success',
5000
);
} )
.catch( () => {
methods.makeNotice(
'cache-level-change-notice',
constants.text.optionNotSet,
'',
'error',
5000
);
} );
}, 1000 );
};

const displayOption = ( option ) => {
switch ( option.type ) {
case 'toggle':
return (
<>
{ option.premiumUrl &&
! NewfoldRuntime.sdk.performance
.jetpack_boost_premium_is_active && (
<FeatureUpsell
cardText="Upgrade to Unlock"
cardLink={ option.premiumUrl }
>
<ToggleField
id={ option.id }
label={ option.label }
description={ parse(
option.description
) }
checked={ !! option.value }
onChange={ ( value ) =>
handleChangeOption(
value,
option.id
)
}
/>
{ option.externalText ? (
<p
style={ {
textDecoration: 'underline',
margin: '10px 0',
} }
>
{ parse( option.externalText ) }
</p>
) : null }
</FeatureUpsell>
) }
{ ( ! option.premiumUrl ||
NewfoldRuntime.sdk.performance
.jetpack_boost_premium_is_active ) && (
<>
<ToggleField
id={ option.id }
label={ option.label }
description={ option.description }
checked={ !! option.value }
onChange={ ( value ) =>
handleChangeOption( value, option.id )
}
/>
{ option.externalText ? (
<p
style={ {
textDecoration: 'underline',
margin: '10px 0',
} }
>
{ parse( option.externalText ) }
</p>
) : null }
</>
) }
</>
);

case 'textarea':
return (
<>
<p className="field-label">{ option.label }</p>
<Textarea
id={ option.id }
description={ option.description }
value={ option.value ?? '' }
onChange={ ( value ) => {
handleChangeOption( value, option.id );
} }
/>
</>
);
default:
return null;
}
};

return (
<>
{ isChild && (
<div className="child-field">
<div
className="wrap-button"
style={ { textAlign: 'right' } }
>
<button onClick={ () => setIsShown( ! isShown ) }>
{ isShown
? constants.text.jetpackBoostShowLess
: constants.text.jetpackBoostShowMore }
</button>
</div>
{ isShown && displayOption( optionDetails ) }
</div>
) }
{ ! isChild && displayOption( optionDetails ) }
</>
);
};

export default SingleOption;
Loading

0 comments on commit d459a0a

Please sign in to comment.