Skip to content

Commit

Permalink
QuickEdit: Add password field to the pages quick edit (WordPress#66567)
Browse files Browse the repository at this point in the history
Co-authored-by: louwie17 <louwie17@git.wordpress.org>
Co-authored-by: jameskoster <jameskoster@git.wordpress.org>
Co-authored-by: oandregal <oandregal@git.wordpress.org>
  • Loading branch information
4 people authored and karthick-murugan committed Nov 13, 2024
1 parent 66c541e commit 3d88e31
Show file tree
Hide file tree
Showing 8 changed files with 154 additions and 31 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,8 @@
&__field {
flex: 1 1 auto;
}

p.components-base-control__help:has(.components-checkbox-control__help) {
margin-top: $grid-unit-05;
}
}
68 changes: 38 additions & 30 deletions packages/edit-site/src/components/post-edit/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,14 @@ import { unlock } from '../../lock-unlock';

const { PostCardPanel } = unlock( editorPrivateApis );

const fieldsWithBulkEditSupport = [
'title',
'status',
'date',
'author',
'comment_status',
];

function PostEditForm( { postType, postId } ) {
const ids = useMemo( () => postId.split( ',' ), [ postId ] );
const { record } = useSelect(
Expand Down Expand Up @@ -58,27 +66,36 @@ function PostEditForm( { postType, postId } ) {
} ),
[ _fields ]
);
const form = {
type: 'panel',
fields: [
'featured_media',
'title',
'author',
'date',
'slug',
'parent',
'comment_status',
],
};

const fieldsWithBulkEditSupport = [
'title',
'status',
'date',
'author',
'comment_status',
];

const form = useMemo(
() => ( {
type: 'panel',
fields: [
'featured_media',
'title',
'status_and_visibility',
'author',
'date',
'slug',
'parent',
'comment_status',
].filter(
( field ) =>
ids.length === 1 ||
fieldsWithBulkEditSupport.includes( field )
),
combinedFields: [
{
id: 'status_and_visibility',
label: __( 'Status & Visibility' ),
children: [ 'status', 'password' ],
direction: 'vertical',
render: ( { item } ) => item.status,
},
],
} ),
[ ids ]
);
const onChange = ( edits ) => {
for ( const id of ids ) {
if (
Expand Down Expand Up @@ -117,16 +134,7 @@ function PostEditForm( { postType, postId } ) {
<DataForm
data={ ids.length === 1 ? record : multiEdits }
fields={ fields }
form={
ids.length === 1
? form
: {
...form,
fields: form.fields.filter( ( field ) =>
fieldsWithBulkEditSupport.includes( field )
),
}
}
form={ form }
onChange={ onChange }
/>
</VStack>
Expand Down
7 changes: 7 additions & 0 deletions packages/edit-site/src/components/post-edit/style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,10 @@
justify-content: center;
}
}

.dataforms-layouts-panel__field-dropdown {
.fields-controls__password {
border-top: $border-width solid $gray-200;
padding-top: $grid-unit-20;
}
}
8 changes: 7 additions & 1 deletion packages/edit-site/src/components/post-fields/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,12 @@ import clsx from 'clsx';
*/
import { __, sprintf } from '@wordpress/i18n';
import { decodeEntities } from '@wordpress/html-entities';
import { featuredImageField, slugField, parentField } from '@wordpress/fields';
import {
featuredImageField,
slugField,
parentField,
passwordField,
} from '@wordpress/fields';
import {
createInterpolateElement,
useMemo,
Expand Down Expand Up @@ -348,6 +353,7 @@ function usePostFields( viewType ) {
},
],
},
passwordField,
],
[ authors, viewType, frontPageId, postsPageId ]
);
Expand Down
4 changes: 4 additions & 0 deletions packages/fields/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,10 @@ Undocumented declaration.

This field is used to display the post parent.

### passwordField

This field is used to display the post password.

### permanentlyDeletePost

Undocumented declaration.
Expand Down
1 change: 1 addition & 0 deletions packages/fields/src/fields/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ export { default as titleField } from './title';
export { default as orderField } from './order';
export { default as featuredImageField } from './featured-image';
export { default as parentField } from './parent';
export { default as passwordField } from './password';
68 changes: 68 additions & 0 deletions packages/fields/src/fields/password/edit.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
/**
* WordPress dependencies
*/
import {
CheckboxControl,
__experimentalVStack as VStack,
TextControl,
} from '@wordpress/components';
import type { DataFormControlProps } from '@wordpress/dataviews';
import { useState } from '@wordpress/element';
import { __ } from '@wordpress/i18n';

/**
* Internal dependencies
*/
import type { BasePost } from '../../types';

function PasswordEdit( {
data,
onChange,
field,
}: DataFormControlProps< BasePost > ) {
const [ showPassword, setShowPassword ] = useState(
!! field.getValue( { item: data } )
);

const handleTogglePassword = ( value: boolean ) => {
setShowPassword( value );
if ( ! value ) {
onChange( { password: '' } );
}
};

return (
<VStack
as="fieldset"
spacing={ 4 }
className="fields-controls__password"
>
<CheckboxControl
__nextHasNoMarginBottom
label={ __( 'Password protected' ) }
help={ __( 'Only visible to those who know the password' ) }
checked={ showPassword }
onChange={ handleTogglePassword }
/>
{ showPassword && (
<div className="fields-controls__password-input">
<TextControl
label={ __( 'Password' ) }
onChange={ ( value ) =>
onChange( {
password: value,
} )
}
value={ field.getValue( { item: data } ) || '' }
placeholder={ __( 'Use a secure password' ) }
type="text"
__next40pxDefaultSize
__nextHasNoMarginBottom
maxLength={ 255 }
/>
</div>
) }
</VStack>
);
}
export default PasswordEdit;
25 changes: 25 additions & 0 deletions packages/fields/src/fields/password/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
/**
* WordPress dependencies
*/
import type { Field } from '@wordpress/dataviews';

/**
* Internal dependencies
*/
import type { BasePost } from '../../types';
import PasswordEdit from './edit';

const passwordField: Field< BasePost > = {
id: 'password',
type: 'text',
getValue: ( { item } ) => item.password,
Edit: PasswordEdit,
enableSorting: false,
enableHiding: false,
isVisible: ( item ) => item.status !== 'private',
};

/**
* This field is used to display the post password.
*/
export default passwordField;

0 comments on commit 3d88e31

Please sign in to comment.