setting.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. <template>
  2. <div class="bs-setting-wrap">
  3. <el-form
  4. ref="form"
  5. :model="config"
  6. label-width="100px"
  7. label-position="left"
  8. class="setting-body bs-el-form"
  9. >
  10. <div>
  11. <slot name="top" />
  12. <el-form
  13. :model="config.customize"
  14. label-position="left"
  15. class="setting-body bs-el-form"
  16. label-width="100px"
  17. >
  18. <SettingTitle>位置</SettingTitle>
  19. <div class="lc-field-body">
  20. <PosWhSetting :config="config" />
  21. </div>
  22. <SettingTitle v-if="config.border">边框</SettingTitle>
  23. <div class="lc-field-body">
  24. <BorderSetting
  25. v-if="config.border"
  26. label-width="100px"
  27. :config="config.border"
  28. :bigTitle='config.title'
  29. />
  30. </div>
  31. <SettingTitle>旋转</SettingTitle>
  32. <div class="lc-field-body">
  33. <RotateSetting
  34. :config="config"
  35. />
  36. </div>
  37. <SettingTitle>基础</SettingTitle>
  38. <div class="lc-field-body">
  39. <el-form-item label="按钮名称">
  40. <el-input
  41. v-model="config.title"
  42. class="bs-el-input"
  43. clearable
  44. />
  45. </el-form-item>
  46. <el-form-item label="字体颜色">
  47. <ColorPicker
  48. v-model="config.customize.fontColor"
  49. :predefine="predefineThemeColors"
  50. />
  51. </el-form-item>
  52. <el-form-item label="字体大小">
  53. <el-input-number
  54. v-model="config.customize.fontSize"
  55. class="bs-el-input-number"
  56. controls-position="right"
  57. :min="12"
  58. :max="100"
  59. />
  60. </el-form-item>
  61. <el-form-item label="背景颜色">
  62. <div>
  63. <ColorPicker
  64. v-model="config.customize.backgroundColor"
  65. :predefine="predefineThemeColors"
  66. />
  67. </div>
  68. </el-form-item>
  69. <el-form-item label="图标选择">
  70. <IconPicker v-model="config.customize.icon.name" />
  71. </el-form-item>
  72. <el-form-item label="图标位置">
  73. <el-select
  74. v-model="config.customize.icon.position"
  75. popper-class="bs-el-select"
  76. class="bs-el-select"
  77. >
  78. <el-option
  79. v-for="iconPosition in iconPositionOptions"
  80. :key="iconPosition.value"
  81. :label="iconPosition.label"
  82. :value="iconPosition.value"
  83. />
  84. </el-select>
  85. </el-form-item>
  86. <el-form-item label="边框颜色">
  87. <ColorPicker
  88. v-model="config.customize.borderStyle.borderColor"
  89. :predefine="predefineThemeColors"
  90. />
  91. </el-form-item>
  92. <el-form-item label="边框宽度">
  93. <el-input-number
  94. v-model="config.customize.borderStyle.borderWidth"
  95. class="bs-el-input-number"
  96. controls-position="right"
  97. :min="0"
  98. :max="10"
  99. />
  100. </el-form-item>
  101. <el-form-item label="边框样式">
  102. <el-select
  103. v-model="config.customize.borderStyle.borderStyle"
  104. popper-class="bs-el-select"
  105. class="bs-el-select"
  106. clearable
  107. >
  108. <el-option
  109. v-for="borderStyleItem in borderStyleOptions"
  110. :key="borderStyleItem.value"
  111. :label="borderStyleItem.label"
  112. :value="borderStyleItem.value"
  113. />
  114. </el-select>
  115. </el-form-item>
  116. <el-form-item label="边框圆角">
  117. <el-input-number
  118. v-model="config.customize.borderStyle.borderRadius"
  119. class="bs-el-input-number"
  120. controls-position="right"
  121. :min="0"
  122. :max="100"
  123. />
  124. </el-form-item>
  125. </div>
  126. </el-form>
  127. </div>
  128. </el-form>
  129. </div>
  130. </template>
  131. <script>
  132. import SettingTitle from 'data-room-ui/SettingTitle/index.vue'
  133. import BorderSetting from 'data-room-ui/BigScreenDesign/RightSetting/BorderSetting.vue'
  134. import IconPicker from 'data-room-ui/IconPicker/index.vue'
  135. import ColorPicker from 'data-room-ui/ColorPicker/index.vue'
  136. import PosWhSetting from 'data-room-ui/BigScreenDesign/RightSetting/PosWhSetting.vue'
  137. import RotateSetting from 'data-room-ui/BigScreenDesign/RightSetting/RotateSetting.vue'
  138. import {predefineColors} from "data-room-ui/js/utils/colorList";
  139. export default {
  140. name: 'Border14Setting',
  141. components: {
  142. IconPicker,
  143. ColorPicker,
  144. PosWhSetting,
  145. SettingTitle,
  146. BorderSetting,
  147. RotateSetting
  148. },
  149. props: {
  150. config: {
  151. type: Object,
  152. required: true
  153. },
  154. predefineThemeColors: {
  155. type: Array,
  156. default: () => predefineColors
  157. }
  158. },
  159. data () {
  160. return {
  161. typeOptions: [
  162. {
  163. label: '默认按钮',
  164. value: 'default'
  165. },
  166. {
  167. label: '主要按钮',
  168. value: 'primary'
  169. },
  170. {
  171. label: '文字按钮',
  172. value: 'text'
  173. },
  174. {
  175. label: '成功按钮',
  176. value: 'success'
  177. },
  178. {
  179. label: '信息按钮',
  180. value: 'info'
  181. },
  182. {
  183. label: '警告按钮',
  184. value: 'warning'
  185. },
  186. {
  187. label: '危险按钮',
  188. value: 'danger'
  189. }
  190. ],
  191. borderStyleOptions: [
  192. {
  193. label: '实线',
  194. value: 'solid'
  195. },
  196. {
  197. label: '虚线',
  198. value: 'dashed'
  199. },
  200. {
  201. label: '点线',
  202. value: 'dotted'
  203. }
  204. ],
  205. iconPositionOptions: [
  206. {
  207. label: '左',
  208. value: 'left'
  209. },
  210. {
  211. label: '右',
  212. value: 'right'
  213. }
  214. ]
  215. }
  216. },
  217. watch: {},
  218. mounted () {},
  219. methods: {}
  220. }
  221. </script>
  222. <style lang="scss" scoped>
  223. .lc-field-body {
  224. width: 97%;
  225. padding: 16px;
  226. }
  227. </style>