@47nordmedia/k2-systems-ui-library 中文文档教程

发布于 3年前 浏览 18 项目主页 更新于 3年前

K2 Systems library

Publish to NPM

Description

这个库在整个 K2 Systems 的数字服务中用作 UI 元素的单一来源。

Setup

Prerequisites

  • Tailwind.css >= 3

Add package

npm install --save @47nordmedia/k2-systems-ui-library

yarn add @47nordmedia/k2-systems-ui-library

tailwind.config.js

将 ui-library 的配置文件添加到您的 tailwind.config.js

module.exports = {
  presets: [require('@47nordmedia/k2-systems-ui-library/dist/tailwind.config.js')],
  // config specific to this project would go here
  // ...
};

HTML / PHP

将自定义类添加到您现有的 css 文件。

@import "tailwindcss/base";
@import "@47nordmedia/k2-systems-ui-library/dist/customBase.css";

@import "tailwindcss/components";
@import "@47nordmedia/k2-systems-ui-library/dist/customComponents.css";
@import '@47nordmedia/k2-systems-ui-library/dist/main.css';

@import "tailwindcss/utilities";
@import "@47nordmedia/k2-systems-ui-library/dist/customUtilities.css";

Usage

Styleguide

使用 npx serve dist -l 8081 在浏览器中查看样式指南。

Icon Library

ICON LIBRARY

Example (HTML, PHP)

<div class="button ...">Hello World!</div>

JS Framework

todo …

Example (react.js)

import uiClasses from '@47nordmedia/k2-systems-ui-library';

export default function Button() {
  return <div className={`${uiClasses.button} ...`}>Hello World!</div>;
}

Workflow for adding new components

  • Open new issue via 'new ui component' template.
  • Set the issue to 'approved' once its tested and reviewed.
  • Open new pull request and link the created issue.
  • Merge pull request to main.
  • Check build workflow for potential errors.
  • Update ui library in you project to latest version.

Multiple issues for nested components

  • to do…

Examples

为了构造嵌套的相关组件,我们使用改编的 BEM 命名约定。 CSS 部分将是标准的 BEM 约定。

然而,JS 部分将替换 dash-case 命名约定,并将其替换为 camelCase 命名约定。

所有 CSS 类都将从 JavaScript 文件中生成。 您可以在下面看到类名是如何转换的。

navMenu (js) --> nav-menu (css)
navMenu__item (js) --> nav-menu__item (css)
<nav class="nav-menu">
  <li class="nav-menu__item"></li>
  <li class="nav-menu__item"></li>
  <li class="nav-menu__item active"></li>
</nav>
// navMenu.ts
export default 'flex align-center justify-between';

// navMenu__item.ts
export default 'p-2 bg-gray-100 rounded-xl hover:bg-gray-200';

// index.ts
import navMenu from './classes/navMenu';
import navMenu__item from './classes/navMenu__item';

export default {
  navMenu: navMenu,
  navMenu__item: navMenu__item,
};

CLI Interface & CI/CD usage

CLI

要将新类添加到 classes 列表,只需运行:

yarn run build:js -c '<new-class-name>' -l '<tailwind classes>'

例如

yarn run build:js -c 'button' -l 'bg-gray-100 rounded-xl hover:bg-gray-200'

,要生成相应的 CSS 文件,请运行:

yarn run build:css

CI/CD

完全自动化的过程即将推出……

  • Creation of a new branch based on the component name.
  • Fetching of the ui-component issue content.
  • Execution of the CLI with the content of the issue.
  • Creation of an pull request.
  • Publishing the updated code to a private NPM package.

K2 Systems library

Publish to NPM

Description

This library is used as a single source for UI elements throughout the K2 Systems' digital services.

Setup

Prerequisites

  • Tailwind.css >= 3

Add package

npm install --save @47nordmedia/k2-systems-ui-library

or

yarn add @47nordmedia/k2-systems-ui-library

tailwind.config.js

Add the config file of the ui-library to your tailwind.config.js

module.exports = {
  presets: [require('@47nordmedia/k2-systems-ui-library/dist/tailwind.config.js')],
  // config specific to this project would go here
  // ...
};

HTML / PHP

Add the custom classes to your existing css files.

@import "tailwindcss/base";
@import "@47nordmedia/k2-systems-ui-library/dist/customBase.css";

@import "tailwindcss/components";
@import "@47nordmedia/k2-systems-ui-library/dist/customComponents.css";
@import '@47nordmedia/k2-systems-ui-library/dist/main.css';

@import "tailwindcss/utilities";
@import "@47nordmedia/k2-systems-ui-library/dist/customUtilities.css";

Usage

Styleguide

use npx serve dist -l 8081 to see the styleguide in the browser.

Icon Library

ICON LIBRARY

Example (HTML, PHP)

<div class="button ...">Hello World!</div>

JS Framework

todo …

Example (react.js)

import uiClasses from '@47nordmedia/k2-systems-ui-library';

export default function Button() {
  return <div className={`${uiClasses.button} ...`}>Hello World!</div>;
}

Workflow for adding new components

  • Open new issue via 'new ui component' template.
  • Set the issue to 'approved' once its tested and reviewed.
  • Open new pull request and link the created issue.
  • Merge pull request to main.
  • Check build workflow for potential errors.
  • Update ui library in you project to latest version.

Multiple issues for nested components

  • to do…

Examples

To structure nested related components we use an adapted BEM naming convention. The CSS part will be the standard BEM convention.

The JS part however will replace the dash-case naming convention and replace it with the camelCase naming convention.

All the CSS classes will be generated out of the JavaScript files. Below you can see how the classnames are being converted.

navMenu (js) --> nav-menu (css)
navMenu__item (js) --> nav-menu__item (css)
<nav class="nav-menu">
  <li class="nav-menu__item"></li>
  <li class="nav-menu__item"></li>
  <li class="nav-menu__item active"></li>
</nav>
// navMenu.ts
export default 'flex align-center justify-between';

// navMenu__item.ts
export default 'p-2 bg-gray-100 rounded-xl hover:bg-gray-200';

// index.ts
import navMenu from './classes/navMenu';
import navMenu__item from './classes/navMenu__item';

export default {
  navMenu: navMenu,
  navMenu__item: navMenu__item,
};

CLI Interface & CI/CD usage

CLI

To add a new class to the classes list, simply run:

yarn run build:js -c '<new-class-name>' -l '<tailwind classes>'

e.g.

yarn run build:js -c 'button' -l 'bg-gray-100 rounded-xl hover:bg-gray-200'

To generate a corresponding CSS file run:

yarn run build:css

CI/CD

fully automated process coming soon…

  • Creation of a new branch based on the component name.
  • Fetching of the ui-component issue content.
  • Execution of the CLI with the content of the issue.
  • Creation of an pull request.
  • Publishing the updated code to a private NPM package.
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文