Vuetify Week Scheduler



A simple component to manage weekly events
Inspired by jquery-schedule.
For Vue 3
See Vuetify Week Scheduler V3.
Installation
NPM
npm install @innovation-system/vuetify-week-scheduler --save
Yarn
yarn add @innovation-system/vuetify-week-scheduler
Demo
Checkout a demo here.
Demo source code is here
Usage
Import component
import VueWeekScheduler from "@innovation-system/vuetify-week-scheduler";
And add to parent component
export default {
components: {
VueWeekScheduler,
},
};
Props
config
{
hour: 24,
days: 7,
periodDuration: 15,
periodTitle: "",
periodBackgroundColor: "#F44336FF",
periodBorderColor: "transparent",
periodTextColor: "#000",
periodRemoveButton: "Remove",
periodDuplicateButton: "Duplicate",
daysList: [
"Monday",
"Tuesday",
"Wednesday",
"Thursday",
"Friday",
"Saturday",
"Sunday",
],
colors: [
"#F44336",
"#FF9800",
"#FFEB3B",
"#8BC34A",
"#4CAF50",
"#00BCD4",
"#2196F3",
],
inputType: "text"
}
value
- Type:
array
- Required:
true
Array of events, two-way binding with (v-model
). The format of events is:
[
{
"day": 0,
"periods": [
{
"start": "00:00",
"end": "09:00",
"title": 15,
"backgroundColor": "#FF0000FF"
},
{
"start": "09:00",
"end": "20:00",
"title": 22,
"backgroundColor": "#008000FF"
}
]
},
{
"day": 1,
"periods": []
}
...
editable
- Type:
boolean
- Default:
false
Whether or not the component permits to add/edit events
Events
edit(obj)
In desktop devices this event is emitted when user right clicks on double clicks on an event, in touch devices this is emitted when user long press on an event.
obj: {
day: number,
index: number
}
error(err)
err
error throwed during initialization