BorderSetting.vue 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  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. <el-form
  11. :model="config.customize"
  12. label-position="left"
  13. class="setting-body bs-el-form"
  14. label-width="100px"
  15. >
  16. <SettingTitle>标题</SettingTitle>
  17. <el-form-item
  18. label="边框名称"
  19. class="lc-field-body"
  20. >
  21. <el-input
  22. v-model="config.title"
  23. clearable
  24. />
  25. </el-form-item>
  26. <SettingTitle>位置</SettingTitle>
  27. <div class="lc-field-body">
  28. <PosWhSetting :config="config" />
  29. </div>
  30. <SettingTitle>旋转</SettingTitle>
  31. <div class="lc-field-body">
  32. <RotateSetting
  33. :config="config"
  34. />
  35. </div>
  36. <SettingTitle>基础</SettingTitle>
  37. <div class="lc-field-body">
  38. <slot name="top" />
  39. <el-form-item label="边框主颜色">
  40. <ColorPicker
  41. v-model="config.customize.borderMainColor"
  42. placeholder="请选择边框主颜色"
  43. :predefine-colors="predefineThemeColors"
  44. />
  45. </el-form-item>
  46. <el-form-item label="边框副颜色">
  47. <ColorPicker
  48. v-model="config.customize.borderSecondaryColor"
  49. placeholder="请选择边框副颜色"
  50. :predefine-colors="predefineThemeColors"
  51. />
  52. </el-form-item>
  53. <el-form-item label="背景色类型">
  54. <el-radio-group
  55. v-model="config.customize.colorType"
  56. class="bs-el-radio-group"
  57. >
  58. <el-radio label="single">
  59. 纯色
  60. </el-radio>
  61. <el-radio label="gradient">
  62. 渐变色
  63. </el-radio>
  64. </el-radio-group>
  65. </el-form-item>
  66. <el-form-item
  67. v-if="config.customize.colorType === 'single'"
  68. label="背景色"
  69. >
  70. <ColorPicker
  71. v-model="config.customize.backgroundColor"
  72. placeholder="请选择背景色"
  73. :predefine-colors="predefineThemeColors"
  74. />
  75. </el-form-item>
  76. <el-form-item
  77. v-if="config.customize.colorType === 'gradient'"
  78. label="开始色值"
  79. >
  80. <ColorPicker
  81. v-model="config.customize.gradientColor0"
  82. placeholder="请选择渐变色开始色值"
  83. :predefine-colors="predefineThemeColors"
  84. />
  85. </el-form-item>
  86. <el-form-item
  87. v-if="config.customize.colorType === 'gradient'"
  88. label="结束色值"
  89. >
  90. <ColorPicker
  91. v-model="config.customize.gradientColor1"
  92. placeholder="请选择渐变色结束色值"
  93. :predefine-colors="predefineThemeColors"
  94. />
  95. </el-form-item>
  96. <el-form-item
  97. v-if="config.customize.colorType === 'gradient'"
  98. label="渐变色方向"
  99. >
  100. <el-select
  101. v-model="config.customize.gradientDirection"
  102. popper-class="bs-el-select"
  103. class="bs-el-select"
  104. >
  105. <el-option
  106. v-for="item in gradientDirection"
  107. :key="item.value"
  108. :label="item.label"
  109. :value="item.value"
  110. />
  111. </el-select>
  112. </el-form-item>
  113. <el-form-item
  114. v-if="config.customize.colorType === 'gradient'"
  115. label="不透明度"
  116. >
  117. <el-input-number
  118. v-model="config.customize.opacity"
  119. class="bs-el-input-number"
  120. :min="0"
  121. :max="100"
  122. :step="10"
  123. />
  124. </el-form-item>
  125. <slot name="bottom" />
  126. </div>
  127. </el-form>
  128. </el-form>
  129. </div>
  130. </template>
  131. <script>
  132. import SettingTitle from 'data-room-ui/SettingTitle/index.vue'
  133. import ColorPicker from 'data-room-ui/ColorPicker/index.vue'
  134. import PosWhSetting from 'data-room-ui/BigScreenDesign/RightSetting/PosWhSetting.vue'
  135. import RotateSetting from 'data-room-ui/BigScreenDesign/RightSetting/RotateSetting.vue'
  136. export default {
  137. name: 'BorderSetting',
  138. components: {
  139. ColorPicker,
  140. PosWhSetting,
  141. SettingTitle,
  142. RotateSetting
  143. },
  144. props: {
  145. config: {
  146. type: Object,
  147. required: true
  148. },
  149. predefineThemeColors: {
  150. type: Array,
  151. default: () => {
  152. return [
  153. '#007aff',
  154. '#1aa97b',
  155. '#ff4d53',
  156. '#1890FF',
  157. '#DF0E1B',
  158. '#0086CC',
  159. '#2B74CF',
  160. '#00BC9D',
  161. '#ED7D32'
  162. ]
  163. }
  164. }
  165. },
  166. data () {
  167. return {
  168. gradientDirection: [
  169. {
  170. label: '从左到右',
  171. value: 'to right'
  172. },
  173. {
  174. label: '从右到左',
  175. value: 'to left'
  176. },
  177. {
  178. label: '从上到下',
  179. value: 'to bottom'
  180. },
  181. {
  182. label: '从下到上',
  183. value: 'to top'
  184. },
  185. {
  186. label: '从左上到右下',
  187. value: 'to bottom right'
  188. },
  189. {
  190. label: '从右上到左下',
  191. value: 'to bottom left'
  192. },
  193. {
  194. label: '从左下到右上',
  195. value: 'to top right'
  196. },
  197. {
  198. label: '从右下到左上',
  199. value: 'to top left'
  200. }
  201. ]
  202. }
  203. },
  204. watch: {},
  205. mounted () {},
  206. methods: {}
  207. }
  208. </script>
  209. <style lang="scss" scoped>
  210. @import '../assets/style/bsTheme.scss';
  211. .lc-field-body {
  212. padding: 12px 16px;
  213. }
  214. .padding {
  215. padding: 10px 0;
  216. }
  217. </style>