hananils/kirby-choices 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

hananils/kirby-choices

Composer 安装命令:

composer require hananils/kirby-choices

包简介

For any list field offering options in the blueprint, like select, multiselect or checkboxlist, Choices will load and return the readable text values for the keys stored in the content file. It works with static options directly set in the blueprint as well as dynamic ones loaded via query or api se

README 文档

README

Kirby Choices

Choices is a plugin for Kirby 3 that provides methods to manage field options in the frontend. For any field – like select, multiselect or checkboxlist – that offers options settings in the blueprint, this plugin will load and return the readable text values for the keys stored in the content file. It works with static options directly set in the blueprint as well as dynamic ones loaded via query or api settings.

Note

Please check out the online documentation at kirby.hananils.de/plugins/choices for further information.

Example

Field

fields:
    fruits:
        label: Fruits
        type: select
        options:
            apple: Apple
            pear: Pear
            banana: Banana

Content

Title: Choices example

----

Fruits: apple, pear

Template

// Return selected fruits: "Apple Pear"
foreach ($page->fruits()->toChoices() as $fruit) {
    echo $fruit;
}

// Return selected fruits in flipped order: "Pear Apple"
foreach (
    $page
        ->fruits()
        ->toChoices()
        ->flip()
    as $fruit
) {
    echo $fruit;
}

Installation

Download

Download and copy this repository to /site/plugins/choices.

Git submodule

git submodule add https://github.com/hananils/kirby-choices.git site/plugins/choices

Composer

composer require hananils/kirby-choices

Field methods

toChoices()

Converts the field value to a Choices collection featuring the text values of the selected options:

$page->fruits()->toChoices();

If the method is passed an optional value of true, it will return text values for all options specified in the blueprint:

$page->fruits()->toChoices(true);

Choices collection

The Choices collection can be used to loop over all given options and return their values. It offers all methods known to the default Kirby collection like first(), last(), shuffle(), sort() and the like. Additionally, it provides three methods to simplify content output:

join($separator)

The join method concatenates all field value by a given separator.

  • $separator: optional separator, uses , as default.
// Will return: Apple, Pear
$page
    ->fruits()
    ->toChoices()
    ->join();

If you want to have more control on how to join values – e. g. to have the last item joined by and – have a look at the List methods plugin.

missing($required)

The missing method compare the current field values with an array of required values and return the missing ones.

  • $required: array of required values to be checked.
// Will return: Banana
$page
    ->fruits()
    ->toChoices()
    ->missing(['Apple', 'Banana']);

average($decimals)

The average method will calculate the average of all selected value, useful when handling numeric values.

  • $decimals: the number of decimals to return.

License

This plugin is provided freely under the MIT license by hana+nils · Büro für Gestaltung.
We create visual designs for digital and analog media.

统计信息

  • 总下载量: 22
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 18
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 18
  • Watchers: 3
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-01-20

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固