Customize your widget
How to get permission to the git repository (coming soon)
Folder Structure (coming soon)
Default styles
The widget components don't import style files. You need to import vars.less and index.module.less from core package if you need them. You can find the theme color information in vars.less.
How to write a plugin
Plugin system provides developers with the full capabilities in widget core. It allows developers to enrich Widget functionality or implement complex business logic by calling core's apis and data.
a widget plugin mainly include:
- A function that can receive configuration information
- This function returns a function that receives an instance of widget core
- Listen to or emit events to complete the business logic
The following is an example of a plugin that inserts a "Hello World" message during initialization:
// A function that can receive configuration information
export default function myPlugin(config: any) {
  const formatedConfig = Object.assign({
    createdTime: Date.now()
  }, config)
  // This function returns a function that receives an instance of widget core
  return function (context: ContextModel) {
    // Listen to or emit events to complete the business logic
    context.on('didInitial', function(context: ContextModel, payload: any) {
      // e.g:
      context.appendUserMessage({
        _id: 'myPluginFirstMessage',
        comp: ({text}) => <div>{text}</div>,
        content: { text: 'hello world!' }
      })
      
      context.emit('myPluginGotInitialed', { foo: 'bar', formatedConfig })
      
      // do something else 
    })
  }
}
For more information, please refer to:
- API document: Implement the business with more functions and data
- Plugin document: Enhance the functionality provided by widgets by loading more plug-ins.
- ChatUI document: learn more about UI lab.
How to custom a project
To custom a project, you can choose from existing templates that are suitable for transformation, or you can redevelop one using the base components.
Choose from existing templates
Fork an existing template and custom it.
- Initialize
yarn
- Local debugging
yarn dev
- Build project. Files will be in the dist folder and they will be published to the address required by the project.
yarn build
note
Typically, private deployment projects are placed in the customer's OSS or backend project and it's up to you and your customer.
Custom project using only widget Core
1. Create a project:
You can use an existing project or create a project using Yarn Create. The following uses the Vite template as an example:
# Create the project using Vite's React-TS template
yarn create vite --template react-ts
# Enter the project, whose default name is vite-project
cd ./vite-project
# Installing Dependencies
yarn
# add Widget Core
yarn add lc-widget-core
See more Settings Create your first Vite project.
2. Import Widget Core:
You can use "model.init" to initialize the model and its data, exposing reusable initialization methods to different users or channels, etc.
import { model } from 'lc-widget-core'
function initMyWidget({userInfo}) {
  model.init({userInfo})
}
window.initMyWidget = initMyWidget
// init when you want it
initMyWidget({
  name: 'ready_player_one'
})
3. Load the preset dialog box
import { SDKComp } from 'lc-widget-core'
export default function() {
  return <SDKComp />
}
4. Build and publish
Give the files in dist to the place where the business needs them.
yarn build
Preset templates
The first template

- Preview: Laiye Chatbot
The second template (Default locale: Chinese)

- Preview: Laiye Chatbot