UNPKG

element-plus

Version:

A Component Library for Vue 3

1 lines 5.38 kB
{"version":3,"file":"basic-year-table.mjs","sources":["../../../../../../../packages/components/date-picker/src/date-picker-com/basic-year-table.vue"],"sourcesContent":["<template>\n <table class=\"el-year-table\" @click=\"handleYearTableClick\">\n <tbody>\n <tr>\n <td class=\"available\" :class=\"getCellStyle(startYear + 0)\">\n <a class=\"cell\">{{ startYear }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 1)\">\n <a class=\"cell\">{{ startYear + 1 }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 2)\">\n <a class=\"cell\">{{ startYear + 2 }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 3)\">\n <a class=\"cell\">{{ startYear + 3 }}</a>\n </td>\n </tr>\n <tr>\n <td class=\"available\" :class=\"getCellStyle(startYear + 4)\">\n <a class=\"cell\">{{ startYear + 4 }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 5)\">\n <a class=\"cell\">{{ startYear + 5 }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 6)\">\n <a class=\"cell\">{{ startYear + 6 }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 7)\">\n <a class=\"cell\">{{ startYear + 7 }}</a>\n </td>\n </tr>\n <tr>\n <td class=\"available\" :class=\"getCellStyle(startYear + 8)\">\n <a class=\"cell\">{{ startYear + 8 }}</a>\n </td>\n <td class=\"available\" :class=\"getCellStyle(startYear + 9)\">\n <a class=\"cell\">{{ startYear + 9 }}</a>\n </td>\n <td></td>\n <td></td>\n </tr>\n </tbody>\n </table>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed } from 'vue'\nimport dayjs from 'dayjs'\nimport { useLocale } from '@element-plus/hooks'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport { hasClass, castArray } from '@element-plus/utils'\n\nimport type { PropType } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nconst datesInYear = (year: Dayjs, lang: string) => {\n const firstDay = dayjs(String(year)).locale(lang).startOf('year')\n const lastDay = firstDay.endOf('year')\n const numOfDays = lastDay.dayOfYear()\n return rangeArr(numOfDays).map((n) => firstDay.add(n, 'day').toDate())\n}\n\nexport default defineComponent({\n props: {\n disabledDate: {\n type: Function as PropType<(_: Date) => void>,\n },\n parsedValue: {\n type: Object as PropType<Dayjs>,\n },\n date: {\n type: Object as PropType<Dayjs>,\n },\n },\n\n emits: ['pick'],\n\n setup(props, ctx) {\n const { lang } = useLocale()\n const startYear = computed(() => {\n return Math.floor(props.date.year() / 10) * 10\n })\n const getCellStyle = (year) => {\n const style = {} as any\n const today = dayjs().locale(lang.value)\n\n style.disabled = props.disabledDate\n ? datesInYear(year, lang.value).every(props.disabledDate)\n : false\n\n style.current =\n castArray(props.parsedValue).findIndex((_) => _.year() === year) >= 0\n\n style.today = today.year() === year\n\n return style\n }\n\n const handleYearTableClick = (event: MouseEvent) => {\n const target = event.target as HTMLDivElement\n if (target.tagName === 'A') {\n if (hasClass((target as any).parentNode, 'disabled')) return\n const year = target.textContent || target.innerText\n ctx.emit('pick', Number(year))\n }\n }\n return {\n startYear,\n getCellStyle,\n handleYearTableClick,\n }\n },\n})\n</script>\n"],"names":["_openBlock","_createElementBlock"],"mappings":";;;;;;;;;;;AAuDA,MAAM,cAAc,CAAC,MAAa,SAAiB;AACjD,QAAM,WAAW,MAAM,OAAO,OAAO,OAAO,MAAM,QAAQ;AAC1D,QAAM,UAAU,SAAS,MAAM;AAC/B,QAAM,YAAY,QAAQ;AAC1B,SAAO,SAAS,WAAW,IAAI,CAAC,MAAM,SAAS,IAAI,GAAG,OAAO;AAAA;AAG/D,MAAK,YAAa,gBAAa;AAAA,EAC7B,OAAO;AAAA,IACL,cAAc;AAAA,MACZ,MAAM;AAAA;AAAA,IAER,aAAa;AAAA,MACX,MAAM;AAAA;AAAA,IAER,MAAM;AAAA,MACJ,MAAM;AAAA;AAAA;AAAA,EAIV,OAAO,CAAC;AAAA,EAER,MAAM,OAAO,KAAK;AAChB,UAAM,EAAE,SAAS;AACjB,UAAM,YAAY,SAAS,MAAM;AAC/B,aAAO,KAAK,MAAM,MAAM,KAAK,SAAS,MAAM;AAAA;AAE9C,UAAM,eAAe,CAAC,SAAS;AAC7B,YAAM,QAAQ;AACd,YAAM,QAAQ,QAAQ,OAAO,KAAK;AAElC,YAAM,WAAW,MAAM,eACnB,YAAY,MAAM,KAAK,OAAO,MAAM,MAAM,gBAC1C;AAEJ,YAAM,UACJ,UAAU,MAAM,aAAa,UAAU,CAAC,MAAM,EAAE,WAAW,SAAS;AAEtE,YAAM,QAAQ,MAAM,WAAW;AAE/B,aAAO;AAAA;AAGT,UAAM,uBAAuB,CAAC,UAAsB;AAClD,YAAM,SAAS,MAAM;AACrB,UAAI,OAAO,YAAY,KAAK;AAC1B,YAAI,SAAU,OAAe,YAAY;AAAa;AACtD,cAAM,OAAO,OAAO,eAAe,OAAO;AAC1C,YAAI,KAAK,QAAQ,OAAO;AAAA;AAAA;AAG5B,WAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA;AAAA;AAAA;qBArGO,OAAM;qBAGN,OAAM;qBAGN,OAAM;qBAKN,OAAM;qBAGN,OAAM;qBAGN,OAAM;qBAGN,OAAM;qBAKN,OAAM;4BAGD;;uDAGD;;2BAtCf,wBAyCQ;SAzCIA,aAACC,mBAAe;AAAA,IAAE,OAAK;AAAA;KACjC;AAAA,uBACE,SAaK;AAAA,yBAZH,MAEK;AAAA,2BAFI,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;;;yBAIF,MAEK;AAAA,2BAFI,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;;;yBAIF,MAEK;AAAA,2BAFI,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,2BAAS,MAAC;AAAA;WACR;AAAA;WAEF;AAAA,QACA;AAAA;;;;;;;;;"}