Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

link prefetch new feature #26

Merged
merged 28 commits into from
Dec 14, 2024
Merged
Show file tree
Hide file tree
Changes from 27 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
c28ad8d
added link prefetch options component, LinkPrefetch class and js for …
geckod22 Oct 23, 2024
03256c3
added defer attribute to script tag
geckod22 Oct 25, 2024
4145534
phpcs on new class
geckod22 Oct 25, 2024
ba1198a
added copy text and changed toggle style
geckod22 Nov 4, 2024
3f90470
added restapi to manage the settings, adding bottom margin to fields
geckod22 Nov 4, 2024
fe39f82
removed console.log
geckod22 Nov 7, 2024
61fa41f
fixed check for mobile
geckod22 Nov 11, 2024
8374c5f
added fix for minified js
geckod22 Nov 11, 2024
49feb01
Update includes/RestApi/LinkPrefetchController.php
geckod22 Nov 18, 2024
24dff12
Update includes/RestApi/LinkPrefetchController.php
geckod22 Nov 18, 2024
ecbdb47
updated LinkPrefetchController with more fix
geckod22 Nov 18, 2024
f743bfe
adding suggested improvements to LinkPrefetchController.php
geckod22 Nov 18, 2024
b7f0abd
removed unused Permissions class and removed LinkPrefetch new and con…
geckod22 Nov 18, 2024
1427769
defaultText.js fix
geckod22 Nov 18, 2024
62999b1
Update assets/js/linkPrefetch.js
geckod22 Nov 18, 2024
b5a5284
Update components/linkPrefetch/index.js
geckod22 Nov 18, 2024
c9c5775
moved non-react scripts to scripts folder
geckod22 Nov 18, 2024
2202638
added RestApi.php
geckod22 Nov 18, 2024
5b5c22d
applied suggestion changes to component index.js
geckod22 Nov 18, 2024
5f18dca
other fixies for RestApi and LinkPrefetch Starting
geckod22 Nov 18, 2024
af2d843
moved inline styles to file and load it
geckod22 Nov 18, 2024
d29a258
some phpcs fixiews
geckod22 Nov 18, 2024
e010497
phpcs
geckod22 Nov 18, 2024
e2170d6
linkPrefetch.js lint
geckod22 Nov 18, 2024
96f9b80
Lint js files
arunshenoy99 Nov 20, 2024
a78673c
fix for mousedown event
geckod22 Nov 27, 2024
cd5d1d8
adding minified js
geckod22 Nov 27, 2024
9fc34ae
Merge branch 'release/v2.1.0' of https://github.com/newfold-labs/wp-m…
arunshenoy99 Dec 14, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
220 changes: 220 additions & 0 deletions components/linkPrefetch/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,220 @@
import {
Toggle,
TextField,
SelectField,
Container,
} from '@newfold/ui-component-library';

const LinkPrefetch = ( { methods, constants } ) => {
const [ settings, setSettings ] = methods.useState(
methods.NewfoldRuntime.sdk.linkPrefetch.settings
);
const [ isError, setIsError ] = methods.useState( false );
const apiUrl = methods.NewfoldRuntime.createApiUrl(
'/newfold-performance/v1/link-prefetch/settings'
);

const handleChangeOption = ( option, value ) => {
if ( ! ( option in settings ) ) return;
const updatedSettings = { ...settings, [ option ]: value };
methods
.apiFetch( {
url: apiUrl,
method: 'POST',
data: { settings: updatedSettings },
} )
.then( () => {
setSettings( ( prev ) => ( { ...prev, [ option ]: value } ) );
} )
.catch( ( error ) => {
setIsError( error.message );
} );
};

methods.useUpdateEffect( () => {
methods.setStore( {
...constants.store,
linkPrefetch: settings,
} );

methods.makeNotice(
'link-prefetch-change-notice',
constants.text.linkPrefetchTitle,
isError || constants.text.linkPrefetchNoticeTitle,
isError ? 'error' : 'success',
5000
);
}, [ settings, isError ] );

return (
<>
<Container.SettingsField
title={ constants.text.linkPrefetchTitle }
description={ constants.text.linkPrefetchDescription }
>
{ /* Desktop Settings */ }
<div className="nfd-toggle-field nfd-mb-6">
<div>
<label
className="nfd-label"
htmlFor="link-prefetch-active-desktop"
>
{
constants.text
.linkPrefetchActivateOnDesktopLabel
}
</label>
<div className="nfd-select-field__description">
{
constants.text
.linkPrefetchActivateOnDesktopDescription
}
</div>
</div>
<Toggle
id="link-prefetch-active-desktop"
screenReaderLabel={
constants.text.linkPrefetchActivateOnDesktopLabel
}
checked={ settings.activeOnDesktop }
onChange={ () =>
handleChangeOption(
'activeOnDesktop',
! settings.activeOnDesktop
)
}
/>
</div>
{ settings.activeOnDesktop && (
<SelectField
id="link-prefetch-behavior"
label={ constants.text.linkPrefetchBehaviorLabel }
value={ settings.behavior }
selectedLabel={
'mouseDown' === settings.behavior
? constants.text
.linkPrefetchBehaviorMouseDownLabel
: constants.text
.linkPrefetchBehaviorMouseHoverLabel
}
onChange={ ( v ) =>
handleChangeOption( 'behavior', v )
}
description={
'mouseDown' === settings.behavior
? constants.text
.linkPrefetchBehaviorMouseDownDescription
: constants.text
.linkPrefetchBehaviorMouseHoverDescription
}
className="nfd-mb-6"
>
<SelectField.Option
label={
constants.text
.linkPrefetchBehaviorMouseHoverLabel
}
value="mouseHover"
/>
<SelectField.Option
label={
constants.text
.linkPrefetchBehaviorMouseDownLabel
}
value="mouseDown"
/>
</SelectField>
) }
{ /* Mobile Settings */ }
<div className="nfd-toggle-field nfd-mb-6">
<div>
<label
className="nfd-label"
htmlFor="link-prefetch-active-mobile"
>
{ constants.text.linkPrefetchActivateOnMobileLabel }
</label>
<div className="nfd-select-field__description">
{
constants.text
.linkPrefetchActivateOnMobileDescription
}
</div>
</div>
<Toggle
id="link-prefetch-active-mobile"
screenReaderLabel={
constants.text.linkPrefetchActivateOnMobileLabel
}
checked={ settings.activeOnMobile }
onChange={ () =>
handleChangeOption(
'activeOnMobile',
! settings.activeOnMobile
)
}
/>
</div>
{ settings.activeOnMobile && (
<SelectField
id="link-prefetch-behavior-mobile"
label={ constants.text.linkPrefetchBehaviorLabel }
value={ settings.mobileBehavior }
selectedLabel={
'touchstart' === settings.mobileBehavior
? constants.text
.linkPrefetchBehaviorMobileTouchstartLabel
: constants.text
.linkPrefetchBehaviorMobileViewportLabel
}
onChange={ ( v ) =>
handleChangeOption( 'mobileBehavior', v )
}
description={
'touchstart' === settings.mobileBehavior
? constants.text
.linkPrefetchBehaviorMobileTouchstartDescription
: constants.text
.linkPrefetchBehaviorMobileViewportDescription
}
className="nfd-mb-6"
>
<SelectField.Option
label={
constants.text
.linkPrefetchBehaviorMobileTouchstartLabel
}
value="touchstart"
/>
<SelectField.Option
label={
constants.text
.linkPrefetchBehaviorMobileViewportLabel
}
value="viewport"
/>
</SelectField>
) }
{ /* Ignore Keywords */ }
{ ( settings.activeOnMobile || settings.activeOnDesktop ) && (
<TextField
id="link-prefetch-ignore-keywords"
label={ constants.text.linkPrefetchIgnoreKeywordsLabel }
description={
constants.text.linkPrefetchIgnoreKeywordsDescription
}
onChange={ ( e ) =>
handleChangeOption(
'ignoreKeywords',
e.target.value
)
}
value={ settings.ignoreKeywords }
/>
) }
</Container.SettingsField>
</>
);
};

export default LinkPrefetch;
162 changes: 138 additions & 24 deletions components/performance/defaultText.js
Original file line number Diff line number Diff line change
@@ -1,27 +1,141 @@
import { __ } from '@wordpress/i18n';

const defaultText = {
cacheLevel0Description: __('No cache enabled. Every page load is fresh. ', 'wp-module-performance'),
cacheLevel0Label: __('Disabled', 'wp-module-performance'),
cacheLevel0NoticeText: __('Caching disabled.', 'wp-module-performance'),
cacheLevel0Recommendation: __('Not recommended.', 'wp-module-performance'),
cacheLevel1Description: __('Cache static assets like images and the appearance of your site for 1 hour. ', 'wp-module-performance'),
cacheLevel1Label: __('Assets Only', 'wp-module-performance'),
cacheLevel1NoticeText: __('Cache enabled for assets only.', 'wp-module-performance'),
cacheLevel1Recommendation: __('Tuned for online stores and member sites that need to be fresh.', 'wp-module-performance'),
cacheLevel2Description: __('Cache static assets for 24 hours and web pages for 2 hours. ', 'wp-module-performance'),
cacheLevel2Label: __('Assets & Web Pages', 'wp-module-performance'),
cacheLevel2NoticeText: __('Cache enabled for assets and pages.', 'wp-module-performance'),
cacheLevel2Recommendation: __('Tuned for sites that change at least weekly.', 'wp-module-performance'),
cacheLevel3Description: __('Cache static assets for 1 week and web pages for 8 hours. ', 'wp-module-performance'),
cacheLevel3Label: __('Assets & Web Pages - Extended', 'wp-module-performance'),
cacheLevel3NoticeText: __('Cache enabled for assets and pages (extended).', 'wp-module-performance'),
cacheLevel3Recommendation: __('Tuned for sites that update a few times a month or less.', 'wp-module-performance'),
cacheLevelDescription: __('Boost speed and performance by storing a copy of your website content, files, and images online so the pages of your website load faster for your visitors.', 'wp-module-performance'),
cacheLevelNoticeTitle: __('Cache setting saved', 'wp-module-performance'),
cacheLevelTitle: __('Cache Level', 'wp-module-performance'),
clearCacheButton: __('Clear All Cache Now', 'wp-module-performance'),
clearCacheDescription: __('We automatically clear your cache as you work (creating content, changing settings, installing plugins and more). But you can manually clear it here to be confident it is fresh.', 'wp-module-performance'),
clearCacheNoticeTitle: __('Cache cleared', 'wp-module-performance'),
clearCacheTitle: __('Clear Cache', 'wp-module-performance'),
cacheLevel0Description: __(
'No cache enabled. Every page load is fresh. ',
'wp-module-performance'
),
cacheLevel0Label: __( 'Disabled', 'wp-module-performance' ),
cacheLevel0NoticeText: __( 'Caching disabled.', 'wp-module-performance' ),
cacheLevel0Recommendation: __(
'Not recommended.',
'wp-module-performance'
),
cacheLevel1Description: __(
'Cache static assets like images and the appearance of your site for 1 hour. ',
'wp-module-performance'
),
cacheLevel1Label: __( 'Assets Only', 'wp-module-performance' ),
cacheLevel1NoticeText: __(
'Cache enabled for assets only.',
'wp-module-performance'
),
cacheLevel1Recommendation: __(
'Tuned for online stores and member sites that need to be fresh.',
'wp-module-performance'
),
cacheLevel2Description: __(
'Cache static assets for 24 hours and web pages for 2 hours. ',
'wp-module-performance'
),
cacheLevel2Label: __( 'Assets & Web Pages', 'wp-module-performance' ),
cacheLevel2NoticeText: __(
'Cache enabled for assets and pages.',
'wp-module-performance'
),
cacheLevel2Recommendation: __(
'Tuned for sites that change at least weekly.',
'wp-module-performance'
),
cacheLevel3Description: __(
'Cache static assets for 1 week and web pages for 8 hours. ',
'wp-module-performance'
),
cacheLevel3Label: __(
'Assets & Web Pages - Extended',
'wp-module-performance'
),
cacheLevel3NoticeText: __(
'Cache enabled for assets and pages (extended).',
'wp-module-performance'
),
cacheLevel3Recommendation: __(
'Tuned for sites that update a few times a month or less.',
'wp-module-performance'
),
cacheLevelDescription: __(
'Boost speed and performance by storing a copy of your website content, files, and images online so the pages of your website load faster for your visitors.',
'wp-module-performance'
),
cacheLevelNoticeTitle: __( 'Cache setting saved', 'wp-module-performance' ),
cacheLevelTitle: __( 'Cache Level', 'wp-module-performance' ),
clearCacheButton: __( 'Clear All Cache Now', 'wp-module-performance' ),
clearCacheDescription: __(
'We automatically clear your cache as you work (creating content, changing settings, installing plugins and more). But you can manually clear it here to be confident it is fresh.',
'wp-module-performance'
),
clearCacheNoticeTitle: __( 'Cache cleared', 'wp-module-performance' ),
clearCacheTitle: __( 'Clear Cache', 'wp-module-performance' ),
linkPrefetchDescription: __(
'Asks the browser to download and cache links on the page ahead of them being clicked on, so that when they are clicked they load almost instantly. ',
'wp-module-performance'
),
linkPrefetchNoticeTitle: __(
'Link prefetching setting saved',
'wp-module-performance'
),
linkPrefetchTitle: __( 'Link Prefetch', 'wp-module-performance' ),
linkPrefetchActivateOnDesktopDescription: __(
'Enable link prefetching on desktop',
'wp-module-performance'
),
linkPrefetchActivateOnDesktopLabel: __(
'Activate on desktop',
'wp-module-performance'
),
linkPrefetchBehaviorDescription: __(
'Behavior of the prefetch',
'wp-module-performance'
),
linkPrefetchBehaviorLabel: __( 'Behavior', 'wp-module-performance' ),
linkPrefetchBehaviorMouseDownLabel: __(
'Prefetch on Mouse down',
'wp-module-performance'
),
linkPrefetchBehaviorMouseDownDescription: __(
'Prefetch on Mouse Down: Starts loading the page as soon as you click down, for faster response when you release the click.',
'wp-module-performance'
),
linkPrefetchBehaviorMouseHoverLabel: __(
'Prefetch on Mouse Hover (Recommended)',
'wp-module-performance'
),
linkPrefetchBehaviorMouseHoverDescription: __(
'Prefetch on Mouse Hover: Begins loading the page the moment your cursor hovers over a link',
'wp-module-performance'
),
linkPrefetchActivateOnMobileDescription: __(
'Enable link prefetching on Mobile',
'wp-module-performance'
),
linkPrefetchActivateOnMobileLabel: __(
'Activate on mobile',
'wp-module-performance'
),
linkPrefetchBehaviorMobileTouchstartLabel: __(
'Prefetch on Touchstart (Recommended)',
'wp-module-performance'
),
linkPrefetchBehaviorMobileTouchstartDescription: __(
'Prefetch on Touch Start: Instantly starts loading the page as soon as you tap the screen, ensuring a quicker response when you lift your finger.',
'wp-module-performance'
),
linkPrefetchBehaviorMobileViewportLabel: __(
'Prefetch Above the Fold',
'wp-module-performance'
),
linkPrefetchBehaviorMobileViewportDescription: __(
"Prefetch Above the Fold: Loads links in your current view instantly, ensuring they're ready when you need them.",
'wp-module-performance'
),
linkPrefetchIgnoreKeywordsDescription: __(
'Exclude Keywords: A comma separated list of words or strings that will exclude a link from being prefetched. For example, excluding "app" will prevent https://example.com/apple from being prefetched.',
'wp-module-performance'
),
linkPrefetchIgnoreKeywordsLabel: __(
'Exclude keywords',
'wp-module-performance'
),
};

export default defaultText;
export default defaultText;
Loading
Loading