index.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. import DateTimePicker from '../dateTimePicker/index.vue';
  2. import DateUtil from '../dateTimePicker/dateUtil';
  3. import { DATE_TYPES } from '../dateTimePicker/constant';
  4. export default {
  5. components: {
  6. DateTimePicker
  7. },
  8. data() {
  9. return {
  10. showStartDatePicker: false,
  11. showEndDatePicker: false,
  12. startDate: '',
  13. endDate: '',
  14. activeDate: 'startDate' // 正在处理哪一个日期值,startDate/endDate
  15. };
  16. },
  17. props: {
  18. // 日期筛选模式,1:年月日(默认),2:年月,3:年,4:年月日时分秒,5:时分秒,6:时分
  19. mode: {
  20. type: Number,
  21. default: DATE_TYPES.YMD
  22. },
  23. // 默认开始日期
  24. defaultStartDate: {
  25. type: String,
  26. default: ''
  27. },
  28. // 默认结束日期
  29. defaultEndDate: {
  30. type: String,
  31. default: ''
  32. },
  33. // 可选的最小日期
  34. minDate: {
  35. type: String,
  36. default: ''
  37. },
  38. // 可选的最大日期
  39. maxDate: {
  40. type: String,
  41. default: ''
  42. }
  43. },
  44. watch: {
  45. mode() {
  46. // 筛选模式更换时清空一下数据
  47. this.resetData();
  48. },
  49. startDate() {
  50. this.$emit('onChange', {
  51. startDate: this.startDate,
  52. endDate: this.endDate
  53. });
  54. },
  55. endDate() {
  56. this.$emit('onChange', {
  57. startDate: this.startDate,
  58. endDate: this.endDate
  59. });
  60. },
  61. defaultStartDate: {
  62. handler(defaultStartDate) {
  63. if (!defaultStartDate) {
  64. return;
  65. }
  66. if (this.mode == DATE_TYPES.HMS || this.mode == DATE_TYPES.HM) {
  67. console.error('时分秒/时分模式不支持设置默认开始时间');
  68. return;
  69. }
  70. if (DateUtil.isBefore(defaultStartDate, this.minDate)) {
  71. console.warn(
  72. `默认开始日期不可小于最小可选日期,已把默认开始日期设为最小可选日期。默认开始日期:${defaultStartDate},最小可选日期:${this.minDate}`
  73. );
  74. this.startDate = this.getModeFormatDateString(this.minDate);
  75. } else {
  76. this.startDate = this.getModeFormatDateString(defaultStartDate);
  77. }
  78. },
  79. immediate: true
  80. },
  81. defaultEndDate: {
  82. handler(defaultEndDate) {
  83. if (!defaultEndDate) {
  84. return;
  85. }
  86. if (this.mode == DATE_TYPES.HMS || this.mode == DATE_TYPES.HM) {
  87. console.error('时分秒/时分模式不支持设置默认结束时间');
  88. return;
  89. }
  90. if (DateUtil.isAfter(defaultEndDate, this.maxDate)) {
  91. console.warn(
  92. `默认结束日期不可大于最大可选日期,已把默认结束日期设为最大可选日期。默认结束日期:${defaultEndDate},最大可选日期:${this.maxDate}`
  93. );
  94. this.endDate = this.getModeFormatDateString(this.maxDate);
  95. } else {
  96. this.endDate = this.getModeFormatDateString(defaultEndDate);
  97. }
  98. },
  99. immediate: true
  100. },
  101. minDate(val) {
  102. if ((val && this.mode == DATE_TYPES.HMS) || this.mode == DATE_TYPES.HM) {
  103. console.error('时分秒/时分模式不支持设置最小可选时间');
  104. return;
  105. }
  106. },
  107. maxDate(val) {
  108. if ((val && this.mode == DATE_TYPES.HMS) || this.mode == DATE_TYPES.HM) {
  109. console.error('时分秒/时分模式不支持设置最大可选时间');
  110. return;
  111. }
  112. }
  113. },
  114. methods: {
  115. onTapStartDate() {
  116. this.showEndDatePicker = false;
  117. if (!this.startDate) {
  118. this.startDate = this.getModeFormatDateString(new Date());
  119. }
  120. this.activeDate = 'startDate';
  121. this.showStartDatePicker = true;
  122. },
  123. onTapEndDate() {
  124. this.showStartDatePicker = false;
  125. if (!this.endDate) {
  126. this.endDate = this.startDate;
  127. }
  128. this.activeDate = 'endDate';
  129. this.showEndDatePicker = true;
  130. },
  131. onChangeStartDate(date) {
  132. this.startDate = date;
  133. },
  134. onChangeEndDate(date) {
  135. this.endDate = date;
  136. },
  137. validateInput() {
  138. if (!this.startDate) {
  139. uni.showToast({
  140. title: '请选择开始时间',
  141. icon: 'none'
  142. });
  143. return false;
  144. } else if (!this.endDate) {
  145. uni.showToast({
  146. title: '请选择结束时间',
  147. icon: 'none'
  148. });
  149. return false;
  150. } else if (DateUtil.isAfter(this.startDate, this.endDate)) {
  151. uni.showToast({
  152. title: '结束时间不能小于开始时间',
  153. icon: 'none'
  154. });
  155. return false;
  156. }
  157. return true;
  158. },
  159. onCancel() {
  160. this.resetData();
  161. },
  162. onConfirm() {
  163. if (this.validateInput()) {
  164. this.$emit('onSubmit', {
  165. startDate: this.startDate,
  166. endDate: this.endDate
  167. });
  168. this.showStartDatePicker = false;
  169. this.showEndDatePicker = false;
  170. }
  171. },
  172. resetData() {
  173. this.startDate = '';
  174. this.endDate = '';
  175. this.activeDate = 'startDate';
  176. this.showStartDatePicker = false;
  177. this.showEndDatePicker = false;
  178. },
  179. // 返回对应日期模式的时间字符串
  180. getModeFormatDateString(date) {
  181. let fmt = 'YYYY-MM-DD';
  182. switch (this.mode) {
  183. case DATE_TYPES.YM:
  184. fmt = 'YYYY-MM';
  185. break;
  186. case DATE_TYPES.Y:
  187. fmt = 'YYYY';
  188. break;
  189. case DATE_TYPES['YMD-HMS']:
  190. fmt = 'YYYY-MM-DD HH:mm:ss';
  191. break;
  192. case DATE_TYPES.HMS:
  193. fmt = 'HH:mm:ss';
  194. break;
  195. case DATE_TYPES.HM:
  196. fmt = 'HH:mm';
  197. break;
  198. default:
  199. break;
  200. }
  201. return DateUtil.formatDate(date, fmt);
  202. }
  203. }
  204. };