G2CustomSetting.vue 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. <template>
  2. <div class="bs-setting-wrap">
  3. <el-form
  4. ref="form"
  5. :model="config"
  6. :rules="customRules"
  7. label-width="120px"
  8. label-position="left"
  9. class="setting-body bs-el-form"
  10. >
  11. <SettingTitle>基础</SettingTitle>
  12. <div class="lc-field-body">
  13. <el-form-item
  14. label="标题"
  15. label-width="120px"
  16. >
  17. <el-input
  18. v-model="config.title"
  19. placeholder="请输入标题"
  20. clearable
  21. />
  22. </el-form-item>
  23. </div>
  24. <SettingTitle>位置</SettingTitle>
  25. <div class="lc-field-body">
  26. <PosWhSetting
  27. label-width="120px"
  28. :config="config"
  29. />
  30. </div>
  31. <template v-for="group in groupList">
  32. <div :key="group.groupName">
  33. <SettingTitle> {{ group.groupName | filterGroupName }}</SettingTitle>
  34. <div class="lc-field-body">
  35. <div
  36. v-for="(setting, settingIndex) in group.list"
  37. :key="settingIndex+1"
  38. >
  39. <el-form-item
  40. :label="setting.type=== 'padding' ? '' : setting.label"
  41. :label-width="setting.type=== 'padding' ? '0px' :'120px'"
  42. >
  43. <el-input
  44. v-if="setting.type === 'input'"
  45. v-model="setting.value"
  46. :placeholder="`请输入${setting.label}`"
  47. clearable
  48. />
  49. <el-select
  50. v-else-if="setting.type === 'select'"
  51. v-model="setting.value"
  52. popper-class="bs-el-select"
  53. class="bs-el-select"
  54. :placeholder="`请选择${setting.label}`"
  55. :multiple="setting.multiple"
  56. clearable
  57. >
  58. <el-option
  59. v-for="(opt, optIndex) in setting.options"
  60. :key="optIndex"
  61. :label="opt.label"
  62. :value="opt.value"
  63. />
  64. </el-select>
  65. <template v-else-if="setting.type === 'colorSelect'">
  66. <color-select
  67. v-model="colorScheme"
  68. @update="updateColorScheme"
  69. />
  70. <div
  71. style="
  72. display: flex;
  73. align-items: center;
  74. flex-wrap: wrap;
  75. "
  76. class="color-picker-box"
  77. >
  78. <el-color-picker
  79. v-for="(colorItem, colorItemIndex) in colors"
  80. :key="colorItemIndex"
  81. v-model="setting.value[colorItemIndex]"
  82. popper-class="bs-el-color-picker"
  83. show-alpha
  84. class="start-color"
  85. />
  86. <span
  87. class="el-icon-circle-plus-outline"
  88. style="color: #007aff; font-size: 20px"
  89. @click="addColor"
  90. />
  91. <span
  92. v-if="colors.length"
  93. class="el-icon-remove-outline"
  94. style="color: #ea0b30; font-size: 20px"
  95. @click="delColor()"
  96. />
  97. </div>
  98. </template>
  99. <el-color-picker
  100. v-else-if="setting.type === 'colorPicker'"
  101. v-model="setting.value"
  102. popper-class="bs-el-color-picker"
  103. class="bs-el-color-picker"
  104. show-alpha
  105. />
  106. <!-- 渐变色设置 -->
  107. <GradualSetting
  108. v-else-if="setting.type === 'gradual'"
  109. v-model="setting.value"
  110. />
  111. <el-input-number
  112. v-else-if="setting.type === 'inputNumber'"
  113. v-model="setting.value"
  114. class="bs-el-input-number"
  115. :step="setting.step || 1"
  116. :min="setting.min || 0"
  117. :max="setting.max || 100000"
  118. />
  119. <el-radio-group
  120. v-else-if="setting.type === 'radio'"
  121. v-model="setting.value"
  122. class="bs-el-radio-group"
  123. >
  124. <template v-for="(opt, optIndex) in setting.options">
  125. <el-radio-button
  126. :key="optIndex"
  127. :label="opt.value"
  128. >
  129. {{ opt.label }}
  130. </el-radio-button>
  131. </template>
  132. </el-radio-group>
  133. <el-switch
  134. v-else-if="setting.type === 'switch'"
  135. v-model="setting.value"
  136. class="bs-el-switch"
  137. :active-value="setting.active"
  138. :inactive-value="setting.inactive"
  139. />
  140. <el-slider
  141. v-else-if="setting.type === 'slider'"
  142. v-model="setting.value"
  143. :min="0"
  144. :max="1"
  145. :step="0.01"
  146. />
  147. <PaddingSetting
  148. v-else-if="setting.type === 'padding'"
  149. v-model="setting.value"
  150. />
  151. </el-form-item>
  152. </div>
  153. </div>
  154. </div>
  155. </template>
  156. <!-- </div> -->
  157. </el-form>
  158. </div>
  159. </template>
  160. <script>
  161. import SettingTitle from 'data-room-ui/SettingTitle/index.vue'
  162. import { chartSettingMixins } from 'data-room-ui/js/mixins/chartSettingMixins'
  163. import ColorSelect from 'data-room-ui/ColorMultipleSelect/index.vue'
  164. // import ColorPicker from 'data-room-ui/ColorPicker/index.vue'
  165. import PaddingSetting from 'data-room-ui/BigScreenDesign/RightSetting/PaddingSetting/index.vue'
  166. import GradualSetting from 'data-room-ui/BigScreenDesign/RightSetting/GradualSetting/index.vue'
  167. import PosWhSetting from 'data-room-ui/BigScreenDesign/RightSetting/PosWhSetting.vue'
  168. export default {
  169. name: 'CustomComponentSetting',
  170. components: {
  171. ColorSelect,
  172. // ColorPicker,
  173. PaddingSetting,
  174. GradualSetting,
  175. PosWhSetting,
  176. SettingTitle
  177. },
  178. mixins: [chartSettingMixins],
  179. data () {
  180. return {
  181. groupList: []
  182. }
  183. },
  184. filters: {
  185. filterGroupName (val) {
  186. const settingGroup = {
  187. basic: '基础',
  188. position: '位置',
  189. graph: '图表',
  190. grid: '网格线',
  191. legend: '图例',
  192. xAxis: 'X轴',
  193. yAxis: 'Y轴',
  194. padding: '边距',
  195. other: '其他'
  196. }
  197. return settingGroup[val]
  198. }
  199. },
  200. computed: {
  201. config: {
  202. get () {
  203. return this.$store.state.bigScreen.activeItemConfig
  204. },
  205. set (val) {
  206. this.$store.commit('bigScreen/changeActiveItemConfig', val)
  207. }
  208. },
  209. appCode: {
  210. get () {
  211. return this.$store.state.bigScreen.pageInfo.appCode
  212. }
  213. },
  214. pageCode () {
  215. return this.$route.query.code
  216. }
  217. },
  218. watch: {
  219. groupList: {
  220. // 1、原数组,2、修改后的数组只包含custom,3、合并的时候xy的配置必须放在最前面
  221. handler (val) {
  222. const setList = [].concat(...val.map(item => item.list))
  223. const newSetList = [...this.config.setting, ...setList]
  224. let newArr = [] // 存新数组
  225. const hash = {}
  226. newArr = newSetList.reduce(function (acc, cru, index) {
  227. if (!hash[cru.field]) {
  228. hash[cru.field] = { index: index }
  229. acc.push(cru)
  230. } else {
  231. acc.splice(hash[cru.field].index, 1, cru)
  232. }
  233. return acc
  234. }, [])
  235. this.$store.commit('bigScreen/changeActiveItemConfig', { ...this.config, setting: newArr })
  236. },
  237. deep: true
  238. }
  239. },
  240. mounted () {
  241. this.init()
  242. const groupNameList = []
  243. this.config.setting.filter(
  244. (item) => item.tabName === 'custom'
  245. ).forEach(item => {
  246. if (item.tabName === 'custom' && item.groupName) {
  247. if (!groupNameList.includes(item.groupName)) {
  248. groupNameList.push(item.groupName)
  249. this.groupList.push({
  250. groupName: item.groupName,
  251. list: [item]
  252. })
  253. } else {
  254. this.groupList.find(group => group.groupName === item.groupName).list.push(item)
  255. }
  256. } else {
  257. if (this.groupList.find(group => group.groupName === 'other')) {
  258. this.groupList.find(group => group.groupName === 'other').list.push(item)
  259. } else {
  260. this.groupList.push({
  261. groupName: 'other',
  262. list: [item]
  263. })
  264. }
  265. }
  266. })
  267. for (let i = 0; i < this.groupList.length; i++) {
  268. if (this.groupList[i].groupName === 'other') {
  269. const otherObject = this.groupList.splice(i, 1)[0]
  270. this.groupList.push(otherObject)
  271. break
  272. }
  273. }
  274. },
  275. methods: {
  276. init () {
  277. this.config = this.$store.state.bigScreen.activeItemConfig
  278. }
  279. }
  280. }
  281. </script>
  282. <style lang="scss" scoped>
  283. @import '../../assets/style/settingWrap.scss';
  284. @import '../../assets/style/bsTheme.scss';
  285. // 筛选条件的按钮样式
  286. .add-filter-box {
  287. position: relative;
  288. .add-filter {
  289. margin-left: 90px;
  290. margin-bottom: 10px;
  291. }
  292. .add-filter-btn {
  293. position: absolute;
  294. top: 0;
  295. }
  296. }
  297. .lc-field-body {
  298. padding:12px 16px;
  299. }
  300. .el-form-item{
  301. margin-bottom: 6px !important;
  302. }
  303. .lc-field-title {
  304. position: relative;
  305. padding-left: 12px;
  306. line-height: 30px;
  307. height: 30px;
  308. margin-bottom: 12px;
  309. &:after {
  310. position: absolute;
  311. left: 0;
  312. top: 50%;
  313. transform: translateY(-50%);
  314. content: '';
  315. width: 4px;
  316. height: 14px;
  317. background-color: var(--bs-el-color-primary);
  318. }
  319. }
  320. ::v-deep .el-color-picker__trigger {
  321. border-color: var(--bs-el-border);
  322. }
  323. .color-picker-box{
  324. ::v-deep .el-color-picker__trigger {
  325. width: 27px!important;
  326. }
  327. }
  328. </style>