setting.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  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. <el-form-item label="是否显示标题">
  21. <el-switch
  22. v-model="config.customize.showTitle"
  23. class="bs-el-switch"
  24. active-color="#007aff"
  25. />
  26. </el-form-item>
  27. <el-form-item
  28. v-if="config.customize.showTitle"
  29. label="标题"
  30. >
  31. <el-input
  32. v-model="config.customize.title"
  33. class="bs-el-input"
  34. clearable
  35. />
  36. </el-form-item>
  37. <el-form-item
  38. v-if="config.customize.showTitle"
  39. label="标题大小"
  40. >
  41. <el-input-number
  42. v-model="config.customize.titleStyle.fontSize"
  43. class="bs-el-input-number"
  44. controls-position="right"
  45. :min="12"
  46. :max="100"
  47. />
  48. </el-form-item>
  49. <el-form-item
  50. v-if="config.customize.showTitle"
  51. label="标题颜色"
  52. >
  53. <ColorPicker
  54. v-model="config.customize.titleStyle.color"
  55. :predefine="predefineThemeColors"
  56. />
  57. </el-form-item>
  58. <el-form-item
  59. v-if="config.customize.showTitle"
  60. label="标题右间距"
  61. >
  62. <el-input-number
  63. v-model="config.customize.titleStyle.marginRight"
  64. class="bs-el-input-number"
  65. controls-position="right"
  66. :min="0"
  67. :max="100"
  68. />
  69. </el-form-item>
  70. </div>
  71. <SettingTitle>位置</SettingTitle>
  72. <div class="lc-field-body">
  73. <PosWhSetting :config="config" />
  74. </div>
  75. <SettingTitle v-if="config.border">边框</SettingTitle>
  76. <div class="lc-field-body">
  77. <BorderSetting
  78. v-if="config.border"
  79. label-width="100px"
  80. :config="config.border"
  81. :bigTitle='config.title'
  82. />
  83. </div>
  84. <SettingTitle>基础</SettingTitle>
  85. <div class="lc-field-body">
  86. <el-form-item label="输入值字体大小">
  87. <el-input-number
  88. v-model="config.customize.inputStyle.fontSize"
  89. class="bs-el-input-number"
  90. controls-position="right"
  91. :min="12"
  92. :max="100"
  93. />
  94. </el-form-item>
  95. <el-form-item label="输入值字体颜色">
  96. <ColorPicker
  97. v-model="config.customize.inputStyle.color"
  98. :predefine="predefineThemeColors"
  99. />
  100. </el-form-item>
  101. <!-- <el-form-item label="输入值左间距">
  102. <el-input-number
  103. v-model="config.customize.inputStyle.paddingLeft"
  104. class="bs-el-input-number"
  105. controls-position="right"
  106. :min="0"
  107. :max="100"
  108. />
  109. </el-form-item> -->
  110. <el-form-item label="背景颜色">
  111. <ColorPicker
  112. v-model="config.customize.backgroundStyle.backgroundColor"
  113. :predefine="predefineThemeColors"
  114. />
  115. </el-form-item>
  116. <el-form-item label="占位符">
  117. <el-input
  118. v-model="config.customize.placeholderStyle.placeholder"
  119. class="bs-el-input"
  120. clearable
  121. />
  122. </el-form-item>
  123. <el-form-item label="图标选择">
  124. <IconPicker v-model="config.customize.icon.name" />
  125. </el-form-item>
  126. <el-form-item label="图标位置">
  127. <el-select
  128. v-model="config.customize.icon.position"
  129. popper-class="bs-el-select"
  130. class="bs-el-select"
  131. >
  132. <el-option
  133. v-for="iconPosition in iconPositionOptions"
  134. :key="iconPosition.value"
  135. :label="iconPosition.label"
  136. :value="iconPosition.value"
  137. />
  138. </el-select>
  139. </el-form-item>
  140. <!-- <el-form-item label="占位符字体颜色">
  141. <ColorPicker
  142. v-model="config.customize.placeholderStyle.placeholderColor"
  143. :predefine="predefineThemeColors"
  144. />
  145. </el-form-item> -->
  146. <el-form-item label="边框颜色">
  147. <ColorPicker
  148. v-model="config.customize.borderStyle.borderColor"
  149. :predefine="predefineThemeColors"
  150. />
  151. </el-form-item>
  152. <el-form-item label="边框宽度">
  153. <el-input-number
  154. v-model="config.customize.borderStyle.borderWidth"
  155. class="bs-el-input-number"
  156. controls-position="right"
  157. :min="0"
  158. :max="10"
  159. />
  160. </el-form-item>
  161. <el-form-item label="边框样式">
  162. <el-select
  163. v-model="config.customize.borderStyle.borderStyle"
  164. popper-class="bs-el-select"
  165. class="bs-el-select"
  166. clearable
  167. >
  168. <el-option
  169. v-for="borderStyle in borderStyleOptions"
  170. :key="borderStyle.value"
  171. :label="borderStyle.label"
  172. :value="borderStyle.value"
  173. />
  174. </el-select>
  175. </el-form-item>
  176. <el-form-item label="边框圆角">
  177. <el-input-number
  178. v-model="config.customize.borderStyle.borderRadius"
  179. class="bs-el-input-number"
  180. controls-position="right"
  181. :min="0"
  182. :max="100"
  183. />
  184. </el-form-item>
  185. </div>
  186. </el-form>
  187. </div>
  188. </el-form>
  189. </div>
  190. </template>
  191. <script>
  192. import SettingTitle from 'data-room-ui/SettingTitle/index.vue'
  193. import IconPicker from 'data-room-ui/IconPicker/index.vue'
  194. import ColorPicker from 'data-room-ui/ColorPicker/index.vue'
  195. import BorderSetting from 'data-room-ui/BigScreenDesign/RightSetting/BorderSetting.vue'
  196. import PosWhSetting from 'data-room-ui/BigScreenDesign/RightSetting/PosWhSetting.vue'
  197. export default {
  198. name: 'InputSetting',
  199. components: {
  200. ColorPicker,
  201. IconPicker,
  202. PosWhSetting,
  203. SettingTitle,
  204. BorderSetting
  205. },
  206. props: {
  207. config: {
  208. type: Object,
  209. required: true
  210. },
  211. predefineThemeColors: {
  212. type: Array,
  213. default: () => {
  214. return [
  215. '#007aff',
  216. '#1aa97b',
  217. '#ff4d53',
  218. '#1890FF',
  219. '#DF0E1B',
  220. '#0086CC',
  221. '#2B74CF',
  222. '#00BC9D',
  223. '#ED7D32'
  224. ]
  225. }
  226. }
  227. },
  228. data () {
  229. return {
  230. // 输入框类型
  231. // typeOptions: [
  232. // {
  233. // label: '单行文本',
  234. // value: 'text'
  235. // },
  236. // {
  237. // label: '多行文本',
  238. // value: 'textarea'
  239. // }
  240. // ],
  241. // 标题位置
  242. titlePositionOptions: [
  243. {
  244. label: '左',
  245. value: 'left'
  246. },
  247. {
  248. label: '右',
  249. value: 'right'
  250. },
  251. {
  252. label: '上',
  253. value: 'top'
  254. },
  255. {
  256. label: '下',
  257. value: 'bottom'
  258. }
  259. ],
  260. // 边框样式
  261. borderStyleOptions: [
  262. {
  263. label: '实线',
  264. value: 'solid'
  265. },
  266. {
  267. label: '虚线',
  268. value: 'dashed'
  269. },
  270. {
  271. label: '点线',
  272. value: 'dotted'
  273. }
  274. ],
  275. iconPositionOptions: [
  276. {
  277. label: '左',
  278. value: 'left'
  279. },
  280. {
  281. label: '右',
  282. value: 'right'
  283. }
  284. ]
  285. }
  286. },
  287. watch: {},
  288. mounted () {},
  289. methods: {}
  290. }
  291. </script>
  292. <style lang="scss" scoped>
  293. .lc-field-body {
  294. width: 97%;
  295. padding: 12px 16px;
  296. //padding-bottom: 65px;
  297. }
  298. </style>