atk14/color-field 问题修复 & 功能扩展

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

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

atk14/color-field

Composer 安装命令:

composer require atk14/color-field

包简介

ColorField is a form field for entering color in HEX, HEXA, RGB or RGBA format

README 文档

README

ColorField is a form field for entering color in HEX, HEXA, RGB or RGBA format.

Installation

Just use the Composer:

cd path/to/your/atk14/project/
composer require atk14/color-field

ln -s ../../vendor/atk14/color-field/src/app/fields/color_field.php app/fields/color_field.php

Integration with Pickr

By default, ColorField renders <input type="text"> in which values like #FFFFFF, rgb(22,33,44), rgba(100,150,170,0.8) can be written. Nothing interesting... But ColorField is meant to be integrated with a nice color picker called Pickr (see https://github.com/Simonwep/pickr).

Pickr can be installed using npm:

npm install --save npm install @simonwep/pickr

And a small js utility needs to be linked into the project:

ln -s ../../../vendor/atk14/color-field/src/public/scripts/utils/color_picker_initializer.js public/scripts/utils/color_picker_initializer.js

Now edit gulpfile-admin.js (or gulpfile.js):

var vendorStyles = [
  // ...

  // ColorPickr: Include one of the following themes
  "node_modules/@simonwep/pickr/dist/themes/classic.min.css"
  //"node_modules/@simonwep/pickr/dist/themes/monolith.min.css"
  //"node_modules/@simonwep/pickr/dist/themes/nano.min.css"
];

// ...

var vendorScripts = [
  // ...
  
  // ColorPickr: modern or es5 bundle (in here, the modern bundle fails)
  //"node_modules/@simonwep/pickr/dist/pickr.min.js"
  "node_modules/@simonwep/pickr/dist/pickr.es5.min.js"
];

// ...

var applicationScripts = [
  // ...

  "public/scripts/utils/color_picker_initializer.js",

  // ...
];

Finally place the following line into function common.init() in public/admin/scripts/application.js (or public/scripts/application.js).

UTILS.color_picker_initializer.init();

Usage in an ATK14 application

In a form:

<?php
// file: app/forms/pages/create_new_form.php
class CreateNewForm extends AdminForm {

  function set_up(){
    // ...
    $this->add_field("background_color", new ColorField([
      "label" => "Background color",
      "initial" => "#4455ff",
      "opacity" => false,
      "theme" => "classic", // "classic", "monolith" or "nano"
      "swatches" => ["#4455ff", "#3366ee", "#223388","rgb(122,233,77)"]
    ]));
  }
}

Swatches

If the configuration file config/theme/colors.json or config/theme/colors.yml exists, ColorField will use the colors from this file as default swatches. The contents of the file might look like this:

{
  "primary": "#e75a76",
  "secondary": "#6c757d",
  "success": "#32a555",
  "info": "#17a2b8",
  "warning": "#ccb11b",
  "danger": "#e70000",
  "light": "#f5f5f5",
  "dark": "#343a40",
  "brand": "#307fa5"
}

Testing

composer update --dev
cd test
../vendor/bin/run_unit_tests

License

ColorField is free software distributed under the terms of the MIT license

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 2
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-03-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固