From 584e3482bd2e5a9cd9ce47865e8f4a51755f57f7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C4=90=C4=83ng=20T=C3=BA?= <68631458+ngdangtu-vn@users.noreply.github.com> Date: Tue, 8 Aug 2023 16:13:20 +0700 Subject: [PATCH] feat(StringControl.js): add prefix/suffix - wrap the input in 2 Div elements with custom CSS - add example with both prefix & suffix --- dev-test/config.yml | 2 +- .../src/StringControl.js | 43 +++++++++++++------ 2 files changed, 31 insertions(+), 14 deletions(-) diff --git a/dev-test/config.yml b/dev-test/config.yml index b3cf7660e91d..eab888e83c13 100644 --- a/dev-test/config.yml +++ b/dev-test/config.yml @@ -117,7 +117,7 @@ collections: # A list of collections the CMS should be able to edit display_fields: ['title', 'date'] search_fields: ['title', 'body'] value_field: 'title' - - { label: 'Title', name: 'title', widget: 'string' } + - { label: 'Title', name: 'title', widget: 'string', prefix: 'This string:', suffix: 'is a title' } - { label: 'Boolean', name: 'boolean', widget: 'boolean', prefix: 'Toggle this to switch on/off:', hint: 'Toggle this to switch on/off', default: true } - { label: 'Map', name: 'map', widget: 'map' } - { label: 'Text', name: 'text', widget: 'text', hint: 'Plain text, not markdown' } diff --git a/packages/netlify-cms-widget-string/src/StringControl.js b/packages/netlify-cms-widget-string/src/StringControl.js index bcb8dd14c2b0..28b3f54d7ab0 100644 --- a/packages/netlify-cms-widget-string/src/StringControl.js +++ b/packages/netlify-cms-widget-string/src/StringControl.js @@ -1,8 +1,16 @@ import React from 'react'; import PropTypes from 'prop-types'; +import ImmutablePropTypes from 'react-immutable-proptypes'; +import { css } from '@emotion/core'; + +const innerWrapper = css` + display: flex; + align-items: baseline; +` export default class StringControl extends React.Component { static propTypes = { + field: ImmutablePropTypes.map.isRequired, onChange: PropTypes.func.isRequired, forID: PropTypes.string, value: PropTypes.node, @@ -41,21 +49,30 @@ export default class StringControl extends React.Component { }; render() { - const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle } = this.props; + const { field, forID, value, classNameWrapper, setActiveStyle, setInactiveStyle } = this.props; + + const prefix = field.get('prefix', false); + const suffix = field.get('suffix', false); return ( - { - this._el = el; - }} - type="text" - id={forID} - className={classNameWrapper} - value={value || ''} - onChange={this.handleChange} - onFocus={setActiveStyle} - onBlur={setInactiveStyle} - /> +