setting.vue 6.1 KB

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