3.0.2 • Published 8 months ago

@bigbinary/neeto-themes-frontend v3.0.2

Weekly downloads
-
License
UNLICENSED
Repository
-
Last release
8 months ago

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

  1. Development with Host Application
  2. Instructions for Publishing

Development with Host Application

Engine

Installation

  1. Add this line to your application's Gemfile:

     source "NEETO_GEM_SERVER_URL" do
       # ..existing gems
    
       gem 'neeto-themes-engine'
     end
  2. And then execute:

    bundle install
  3. Add this line to your application's config/routes.rb file

     mount NeetoThemesEngine::Engine => "/neeto_themes_engine"
  4. 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
  5. Add the following line to models/organization.rb file.

    has_many :themes, class_name: "NeetoThemesEngine::Theme", as: :owner
  6. 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

  1. Create an engine initializer

    Create a file named neeto_themes_engine.rb in the config/initializers folder.

  2. 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.

  3. 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.

  4. 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"]
  5. 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

  1. Add the neeto-themes-frontend package to the package.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

  1. 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

  1. 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.

3.0.2

8 months ago

3.0.1

8 months ago

3.0.0

8 months ago

2.1.7

8 months ago

2.1.6

9 months ago

2.1.4

10 months ago

2.1.3

10 months ago

2.1.5

9 months ago

1.2.0

1 year ago

1.2.8

12 months ago

1.3.0-beta2

1 year ago

1.2.7

12 months ago

1.3.0-beta1

1 year ago

1.2.6

12 months ago

1.2.5

12 months ago

1.2.4

12 months ago

1.2.3

1 year ago

1.2.2

1 year ago

1.2.1

1 year ago

2.1.2

10 months ago

2.0.3

11 months ago

2.2.0

10 months ago

2.1.1

10 months ago

2.0.2

12 months ago

2.0.5

11 months ago

2.0.4

11 months ago

2.0.7

11 months ago

2.0.6

11 months ago

2.0.9

11 months ago

2.0.10

11 months ago

2.0.8

11 months ago

2.1.0

10 months ago

2.0.0

12 months ago

1.1.19

1 year ago

1.1.18

1 year ago

1.1.17

1 year ago

1.2.9

12 months ago

1.1.23

1 year ago

1.1.22

1 year ago

1.2.10

12 months ago

1.1.21

1 year ago

1.1.20

1 year ago

1.1.25

1 year ago

1.1.24

1 year ago

1.1.16

1 year ago

1.1.15

1 year ago

1.1.14

1 year ago

1.1.13

1 year ago

1.1.12

1 year ago

1.1.11

1 year ago