Skip to content

MapGIS/MapGIS-Pan-Spatial-Map-Theme-Frame

Repository files navigation

主题开发

  • 安装依赖

    yarn
    
  • 执行快速添加主题脚本命令

    为了节省开发者开发时的重复工作,脚手架新增快速添加主题的脚本命令,让开发者专注于代码的编写

    yarn add:theme
    
  • 根据提示输入信息

    img

  • 通过向导生成目录结构

    根据向导操作后生成如下目录,主题内容则需要开发者自行编写

    img

  • 添加主题的配置信息

    在 themes 文件夹中,我们需要对主题的信息进行配置,让项目在加载的时候能够进行准确的识别和加载

    img

// layout.json
{
  "contentWidgets": {
    "groups": []
  },
  "mapWidgets": {
    "widgets": []
  }
}



// manifest.json
{
  "name": "全空间一张图测试主题",
  "author": "MapGIS",
  "description": "",
  "component": "ClassicTheme1",
  "styles": [
    {
      "name": "dark",
      "description": "暗蓝",
      "color": "#1890ff",
      "theme": "night"
    },
    {
      "name": "dust-red",
      "description": "薄暮",
      "color": "#f5222d",
      "theme": "dark"
    },
    {
      "name": "volcano",
      "description": "火山",
      "color": "#fa541c",
      "theme": "dark"
    },
    {
      "name": "sunrise-yellow",
      "description": "日出",
      "color": "#fadb14",
      "theme": "dark"
    },
    {
      "name": "polar-green",
      "description": "极光绿",
      "color": "#3eaf7c",
      "theme": "dark"
    },
    {
      "name": "cyan",
      "description": "明青",
      "color": "#13c2c2",
      "theme": "dark"
    },
    {
      "name": "daybreak-blue",
      "description": "拂晓蓝",
      "color": "#1890ff",
      "theme": "dark"
    },
    {
      "name": "golden-purple",
      "description": "酱紫",
      "color": "#722ed1",
      "theme": "dark"
    },
    {
      "name": "magenta",
      "description": "法式洋红",
      "color": "#eb2f96",
      "theme": "dark"
    }
  ],
  "contents": [],
  "defaultAppConfig": {
    "title": "MapGIS全空间一张图",
    "subtitle": "",
    "logo": "data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="160px" height="160px" viewBox="0 0 160 160" enable-background="new 0 0 160 160" xml:space="preserve">  <image id="image0" width="160" height="160" x="0" y="0"
    href="data:image/png;base64,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" />
</svg>
",
    "copyright": "2022 武汉中地数码科技有限公司 Version 10.6.0.10",
    "links": [{ "url": "http://www.smaryun.com", "label": "MapGIS Cloud" }]
  },
  "icon": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAA2BAMAAACikgPZAAAAAXNSR0IB2cksfwAAAAlwSFlzAAALEwAACxMBAJqcGAAAABJQTFRF2NjYAAAAgICAAAAAj42Nx8TE0/zE5wAAAAZ0Uk5T////AP//ICV/3wAAAFxJREFUeJxjYCAWMAoSBQSGl0ImJSVlY8LAAKzQxcTZhUyFRkpowACH1UQrxGE1XiWhYDCqcFQhDoV4kzdZCqljNQSQqJCwOlJNpL7VVFeoGkoEGFU4qpAeCokFAI5fxNzdnOPYAAAAAElFTkSuQmCC",
  "version": "2.0.0",
  "properties": {
    "cssFile": "theme.css", // 主题css文件
    "jsFile": "theme.js" // 主题js文件
  }
}
  • 打包命令

    以上工作完成后执行打包命令将项目进行打包,为了满足调试需求,增加打包成可调式的源码脚本命令

yarn build // 正常打包

yarn build:debug // 调试打包
  • 项目打包

    执行打包脚本后,项目会增加打包后的 dist-libs 文件夹,我们只需要关注其中的文件夹即可,在正常情况下,主题打包后生成的 js 和 css 文件默认会放在第一个主题文件夹中,所以多个主题的情况下,其他主题的 manifest.json 文件中的 properties 属性需要指向第一个主题文件夹,如"themes/classic-theme/theme.js"。若只需要单独的某一个主题,可以按照第一个主题文件夹中的 properties 属性配置,然后将其中的 theme.js 和 theme.css 文件复制到该主题中,然后打包成 zip 即可。 img

  • 项目使用

    将按上述步骤打包好的 zip 包通过管理平台的功能菜单应用管理 -主题管理进行主题 zip 包的上传操作。上传成功后通过功能菜单应用管理-应用搭建对主题进行切换,保存后登录一张图即可看到主题效果。

若需要对以此种方式加载的主题进行调试,只需要执行调试打包脚本命令,将对应主题上传应用后进入一张图,打开控制台正常调试即可

  • link调试

    在开发过程中若需要实时查看效果,通常使用link的方式进行,使用基本的link操作外,开发者只需要配置好主题的layout.json和manifest.json文件即可,然后将对应的主题直接打包,将打包好的 zip 包通过管理平台的功能菜单应用管理 -主题管理进行主题 zip 包的上传操作。上传成功后通过功能菜单应用管理-应用搭建对主题进行切换,保存后登录一张图即可实时调试。

yarn link // 主题脚手架执行
yarn link '@mapgis/mapgis-pan-spatial-map-themes-frame' // 主应用中执行

// 主应用中添加
import themesFrame from '@mapgis/mapgis-pan-spatial-map-themes-frame'
Vue.use(themesFrame)

link调试情况下是不需要执行打包脚本的,只需要将themes目录下需要调试的主题定义好后通过管理平台上传即可

在执行打包脚本和link的情况下,项目优先使用link模式下的代码

Releases

No releases published

Packages

No packages published