@bigbinary/neeto-themes-frontend
v3.1.2
Published
A repo acts as the source of truth for the new nano's structure, configs, data etc.
Downloads
4,171
Readme
neeto-themes-nano
The neeto-themes-nano
allows us to build and use themes within neeto
applications. This nano exports @bigbinary/neeto-themes-frontend
NPM package
and neeto-themes-engine
Rails engine.
Contents
Development with Host Application
Engine
Installation
Add this line to your application's Gemfile:
source "NEETO_GEM_SERVER_URL" do # ..existing gems gem 'neeto-themes-engine' end
And then execute:
bundle install
Add this line to your application's
config/routes.rb
filemount NeetoThemesEngine::Engine => "/neeto_themes_engine"
Add required migrations in the
db/migrate
folder. Run the following commands to copy the migrations from the engine to the host application.bundle exec rails neeto_themes_engine:install:migrations bundle exec rails db:migrate
Add the following line to
models/organization.rb
file.has_many :themes, class_name: "NeetoThemesEngine::Theme", as: :owner
Configure model to add below association to attach theme.
has_one :theme_entity, as: :themeable, class_name: "NeetoThemesEngine::ThemeEntity", dependent: :destroy has_one :theme, through: :theme_entity, class_name: "NeetoThemesEngine::Theme"
Usage
Create an engine initializer
Create a file named
neeto_themes_engine.rb
in theconfig/initializers
folder.Customize theme schema
The engine supports customizing theme schemas based on the needs of the host application. This schema will be used in the frontend to render the theme properties. Eg:
NeetoThemesEngine.theme_properties_schema = [ { kind: "color", key: "primary_color", default_value: "#2D36D4" }, { kind: "color", key: "secondary_color", default_value: "#ECF4FF" }, ]
Each object in the array should have the following keys:
key
: The unique identifier for the theme property.kind
: The kind of the theme property.
Optional keys that can be included:
default_value
: Sets a default value when creating a new theme.hidden
: This boolean prop helps to hide the property from the UI but allows to use it as CSS variable.depends_on
: Provides a dependency on other properties. If a key is provided, it will check for its value and only appear in the UI if the dependent property is present.parent_class
: This key needs to be added for custom css feature to work properly. See more on custom css feature.
Provide a css variable prefix
This value will be used to prefix all CSS variables. Eg:
NeetoThemesEngine.css_variable_prefix = "neeto-cal"
variable generated for the theme property
primary_color
will be--neeto-cal-primary-color
.Provide the entities to which the theme property is attached
This value will be used to determine the entity to which the theme property is attached. We can provide multiple entities. Eg:
NeetoThemesEngine.valid_themeable_types = ["Meeting", "Booking"]
Provide a default theme name (Optional)
This provided value will be used to identify the default theme. If not provided, the default theme will be named "Plain blue".
NeetoThemesEngine.default_theme_name = "My theme"
Frontend package
Installation
Add the
neeto-themes-frontend
package to thepackage.json
yarn add @bigbinary/neeto-themes-frontend
Instructions for development
Check the Frontend package development guide for step-by-step instructions to develop the frontend package.
Usage
Components
Import the
NeetoThemesBuilder
component from@bigbinary/neeto-themes-frontend
:import React from "react"; import { NeetoThemesBuilder } from "@bigbinary/neeto-themes-frontend"; const App = () => ( <NeetoThemesBuilder entityId={meeting?.id} entityType="Meeting" thumbnail={Thumbnail} > <Preview /> </NeetoThemesBuilder> ); export default App;
hooks
Import
useThemeUtils
hook from "@bigbinary/neeto-themes-frontend"import { useThemeUtils } from "@bigbinary/neeto-themes-frontend"; const { setTheme, previewingTheme, currentTheme } = useThemeUtils();
setTheme
: This method is used to set the theme for the entity.previewingTheme
: This object contains the currently previewing theme.currentTheme
: This object contains the current theme which is applied to the entity.
Custom CSS
neeto-themes-nano
will inject custom css into your application as part of a
theme. It requires the initializer to be set with the additional property
{ kind: "custom_css", key: "custom_css", default_value: "", parent_class: "neeto-form-eui" }
.
The parent_class
key will be used as a parent to inject styles and for CSS
nesting. This ensures that styles are not injected on pages where you do not
want it and also ensures that style rules targeting elements outside this class
will not be applied. Please ensure that the value provided to parent_class
is
present in your application as a wrapper CSS class. For example:
neeto-form-eui
in neetoForm is present in all external pages where theme needs
to be applied. It also provides a code editor with syntax highlighting which
depends on Monaco editor as a
peer dependency. Please install it in the host application for proper working.
Instructions for Publishing
Consult the building and releasing packages guide for details on how to publish.