Skip to content

Latest commit

 

History

History
311 lines (254 loc) · 5.59 KB

README.md

File metadata and controls

311 lines (254 loc) · 5.59 KB

Guten Block Fields

WordPress Gutenberg development tool.

NPM version npm GitHub stars

When you creating blocks in Gutenberg, You may want more fields to manage the block's content. Gutenberg has a section called Inspector Controller which appears on the right side of the block when you click on particular block on editor. This package will help you to create those field in more easy way.

Install

$ npm install guten-block-fields

Usage

$ guten-block-fields make 

Documentation

Click Here to see documentation.

Video Demo

Click Here To watch the video demo.

Create fields

To create or manage block's field you'll need to create a block-fields.json file in your plugin's root folder.

A block-fields.json file:

  • list the block's field and manage them anytime.
  • makes your field reproducible, and therefore much easier to share with another block.

"block-fields.json" options

name

Type: string

Name of your component.

output

Type: string

The path where you want to land of the generated files.

toggles

Type: object

List of the toggle

Example:

"toggles": {
        "bio": {
            "title": "Bio data",
            "isOpen": true,
        },
        "occuption": {
            "title":"Occuption",
            "isOpen":false
        }
    }

fields

Type: array

Pass the list of the field which needs to be required generated.

Options:
  • title Title or label of the field.
  • id id of the field.
  • type Type of the field.
  • value Default value of the field.
  • toggle Toggle id in which this field should be appear. See "toggle" option above.
  • baseControl Whether field should wrapper inside the or not.

Supported fields

text

Render

example:
{
    "title": "Your Name",
    "id": "your-name",
    "type": "text",
    "value": "john doe",
    "toggle": "bio",
    "baseControl": true
}

checkbox

Render

Additional option:

  • checked <true|false>
example:
{
    "title": "Accept t&c",
    "label": "Sample",
    "id": "sample",
    "toggle": "bio",
    "checked": true,
    "type": "checkbox"
},

button

Render <Button />

example:
{
    "title": "Save Changes",
    "type": "button",
    "id": "save-change",
    "toggle": "occuption",
    "default": false,
    "class": "save"
},

button-group

Render <ButtonGroup />

example:
{
    "title": "Button Group",
    "type": "button-group",
    "id": "button-group",
    "toggle": "occuption",
    "buttons": [
        {
            "isPrimary": true,
            "class": "red",
            "label": "Red",
            "id": "red"
        },
        {
            "isPrimary": false,
            "class": "blue",
            "label": "Blue",
            "id": "blue"
        }
    ]
},

select

Render <Select />

example
{
    "type": "select",
    "value": "india",
    "id": "country",
    "title": "Country",
    "options": [
        {
            "label": "India",
            "value": "india"
        },
        {
            "label": "USA",
            "value": "usa"
        }
    ]
},

radio

Render <RadioControl />

example:
{
    "type": "radio",
    "title": "Gender",
    "id": "gender",
    "value": "male",
    "options": [
        {
            "label": "Male",
            "value": "male"
        },
        {
            "label": "Female",
            "value": "female"
        }
    ]
},

range

Render <RangeControl />

Example
{
    "type": "range",
    "title": "Volume",
    "id": "volume",
    "min": 1,
    "max": 100,
    "value": 40
}

color

Render <ColorPalette />

Example
{
    "type": "color",
    "title": "Background Color",
    "id": "bg-color",
    "value": '#fff',
    "colors": [
        {
            "name": "red",
            "color": "#f00"
        },
        {
            "name": "blue",
            "color": "#00f"
        },
        {
            "name": "black",
            "color": "#000"
        }
    ]
}

tree

Render <TreeSelect />

Example
{
    "title": "Select Post",
    "type" : "tree",
    "optionlabel": "Select option",
    "selectedId": "p211",
    "tree":[
        {
            name: 'Post 1',
            id: 'p1',
            children: [
                { name: 'Descend 1 of post 1', id: 'p11' },
                { name: 'Descend 2 of post 1', id: 'p12' },
            ],
        },
        {
            name: 'post 2',
            id: 'p2',
            children: [
                {
                    name: 'Descend 1 of post 2',
                    id: 'p21',
                    children: [
                        {
                            name: 'Descend 1 of Descend 1 of post 2',
                            id: 'p211',
                        },
                    ],
                },
            ],
        },
    ]     
}

datetime

Render <DateTime />

Example
{
    "title": "Select Date and Time",
    "id": "date-posting",
    "type": "datetime",
    "is12hours": true,
    "locale": ""
}

Thanks! ;)