Skip to content
This repository has been archived by the owner on Feb 25, 2024. It is now read-only.

Latest commit

 

History

History
108 lines (72 loc) · 2.85 KB

README.md

File metadata and controls

108 lines (72 loc) · 2.85 KB

this directory contains the data that is customizable for the different brands of the pegasus-app

usage

each brand is defined by a directory 'brands/[BRAND_NAME]'

in order to set the branding of the app, use the following command

npm run setbrand -- --brand=[BRAND_NAME] --platforms==[PLATFORMS]

where the flag 'platforms' is optional and may be set to 'ia', 'ai', 'i', 'a' or 'none'. accordingly, the script will add the (a)ndroid and (i)os platforms to the project. when set to 'none', the platforms are not altered in any way. the default value of the flag is 'ia'

the script './branding/set_brand.js' will set the customization and generate a log-file at './branding/set_brand.log'

structure for each brand

the following structure of directories and files must be provided for each brand

  • [BRAND_NAME]
  • [BRAND_NAME]/assets
  • [BRAND_NAME]/assets/stylesheets/theme.scss
  • [BRAND_NAME]/resources
  • [BRAND_NAME]/build.json
  • [BRAND_NAME]/config.json

config

the file '[BRAND_NAME]/config.json' contains information that is used by the hook-script './branding/set_brand.js'

template

{
  "ilias_installation_ids": [],
  "projectConfig": {
    "id": "",
    "name": "",
    "description": ""
  }
}

the array 'ilias_installation_ids' contains ids that correspond to ILIAS-installations, declared in './branding/common/config/server.config.json'

the strings 'id', 'name' and 'description' are used as the value for the fields 'widget/id', 'name' and 'description' in 'config.xml'

only the chosen entries will be available on the login-screen in the customized app, and the first id sets the default installation for the login

languages

the basis all brands is set in './branding/common/i18n'

if brand-specific translations are needed, they can be defined in '[BRAND_NAME]/assets/i18n', where a file with the same name as the one that should be modified must be placed

example usage

  • './branding/common/i18n/en.json'
{
  "0" : "apple",
  "1" : {
    "2" : "juice"
  }
}
  • '[BRAND_NAME]/assets/i18n/en.json'
{
  "1" : {
    "2" : "pie"
  },
  "3" : "new"
}
  • resulting './assets/i18n/en.json'
{
  "0" : "apple",
  1" : {
    "2" : "pie"
  },
  "3" : "new"
}

stylesheets and fonts

the file '[BRAND_NAME]/assets/stylesheets/theme.scss' is the only scss-file that will be imported by the app, it thus is responsible for all the styling

in addition, the variable '$ionicons-font-path' will be set to match the content of '[BRAND_NAME]/assets/fonts'

icons and images

the directories '[BRAND_NAME]/assets/icon' and '[BRAND_NAME]/assets/img' must contain the assets that are used by the app

resources

the directory '[BRAND_NAME]/resources' contains the splash screens and icons for android and ios, it will be placed at './resources'

release builds

the file [BRAND_NAME]/build.json contains information that is used for IOS release builds