Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

0.26 #589

Merged
merged 119 commits into from
Sep 3, 2018
Merged

0.26 #589

Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
119 commits
Select commit Hold shift + click to select a range
b3c9520
feat: remove direct dependency on date-fns
mattlewis92 Jun 10, 2018
ab764ec
feat: upgrade the drag and drop library
mattlewis92 Jun 10, 2018
9b071db
refactor: move shared logic into main adapter
mattlewis92 Jun 10, 2018
522e3c6
chore: merge with master
mattlewis92 Jun 13, 2018
e05a115
docs: fix stackblitz generation
mattlewis92 Jun 10, 2018
1c5d32f
feat: allow moment to be used as a replacement to date-fns
mattlewis92 Jun 10, 2018
a2fff58
fix(moment): change weekViewColumnSubHeader from `D MMM` to `MMM D`
mattlewis92 Jun 10, 2018
dcf1a8f
build: revert accidental tsconfig changes
mattlewis92 Jun 10, 2018
c788300
refactor: cleanup date adapter api
mattlewis92 Jun 13, 2018
7e35137
refactor: undo accidental breaking change
mattlewis92 Jun 13, 2018
8e1a982
docs(demos): fix the moment demo in aot
mattlewis92 Jun 13, 2018
36fb312
fix: prevent text getting selected in safari while dragging events
mattlewis92 Jun 16, 2018
24eb394
feat: remove deep module imports
mattlewis92 Jun 16, 2018
b2a3e05
test: fix tests
mattlewis92 Jun 16, 2018
c27b2d8
feat: allow meta to be passed to the event times changed interface
mattlewis92 Jun 16, 2018
797178f
chore: merge with master
mattlewis92 Jun 16, 2018
111234d
chore: merge with master
mattlewis92 Jun 17, 2018
427d5a2
build: upgrade drag and drop lib
mattlewis92 Jun 17, 2018
40b02cb
build: upgrade drag and drop lib
mattlewis92 Jun 17, 2018
44347e2
feat(day-view): expose events in beforeViewRender output
mattlewis92 Jun 17, 2018
df62e7a
feat(event-title-formatter): expose the pre-formatted title
mattlewis92 Jun 17, 2018
f634a86
feat: add a CalendarView enum to prevent typos in view names
mattlewis92 Jun 17, 2018
1fd9089
fix(day-view): prevent segment double hover when dragging
mattlewis92 Jun 17, 2018
19d4250
build: prevent local build from crashing
mattlewis92 Jun 17, 2018
ce8063d
fix: make sure events that are being resized are always on top
mattlewis92 Jun 17, 2018
1e414cf
refactor: make drag helper start position readonly
mattlewis92 Jun 18, 2018
6641319
feat(day-view): allow events to be dragged outside of the view
mattlewis92 Jun 18, 2018
d2223d5
fix(day-view): dont remove events that start and end at the same time
mattlewis92 Jun 18, 2018
50159cc
feat(day-view): make previous and next view helpers respect excludeDays
mattlewis92 Jun 18, 2018
be40f52
build: exclude all export not found warnings in tests
mattlewis92 Jun 18, 2018
97459d8
docs: clarify demo utils are only for the demo
mattlewis92 Jun 18, 2018
2454892
feat(month-view): allow events to be dropped on the open day events list
mattlewis92 Jun 18, 2018
c505d38
fix(month-view): prevent day clicked from firing when dragging events
mattlewis92 Jun 18, 2018
79dd846
fix(day-view): make sure segmentHeight is passed to a custom template
mattlewis92 Jun 18, 2018
8908759
fix(day-view): always default eventSnapSize to hour segment height
mattlewis92 Jun 18, 2018
885f349
docs(demos): dont preload all modules
mattlewis92 Jun 18, 2018
b0ebcd5
docs(demos): fix async demo in non GMT timezone
mattlewis92 Jun 18, 2018
4f9ee6c
build: upgrade calendar-utils
mattlewis92 Jun 18, 2018
bca145e
refactor: remove accidental console.log
mattlewis92 Jun 22, 2018
d9e76d4
feat: upgrade draggable library
mattlewis92 Jun 22, 2018
45444b8
refactor: dont expose duplicate events
mattlewis92 Jun 22, 2018
10ff7d5
fix(month-view): stop events overflowing on ie11
mattlewis92 Jun 22, 2018
a0d80ef
chore: merge with matser
mattlewis92 Jun 22, 2018
01b0c14
build: use star imports for date-fns
mattlewis92 Jun 22, 2018
9a4c14c
docs(demos): add calendar-utils to stackblitz
mattlewis92 Jun 22, 2018
013c98b
test: fix day view tests
mattlewis92 Jun 23, 2018
2aaaeb8
test: fix tests for real
mattlewis92 Jun 23, 2018
e2538a1
feat(week-view): allow events to be dragged outside of the view
mattlewis92 Jun 23, 2018
bb08ec1
fix(week-view): make sure currently resized events are always on top
mattlewis92 Jun 23, 2018
56dc132
fix(day-view): disable pointer events whilst resizing
mattlewis92 Jun 23, 2018
ccffe05
fix(week-view): allow resizing events with no end date
mattlewis92 Jun 23, 2018
94a8e79
refactor(day-view): make intention more explicit
mattlewis92 Jun 23, 2018
b00d57c
fix(day-view): allow events with no end date to be resized
mattlewis92 Jun 23, 2018
3dcc029
test: remove it.only from tests
mattlewis92 Jun 23, 2018
51f3f2b
build: transpile date-adapters to commonjs for better interop
mattlewis92 Jun 23, 2018
ab3aa6e
refactor(click): make click event handler stop propagation automatic
mattlewis92 Jun 24, 2018
403e127
fix(event-clicked): clicking actual events now triggers eventClicked
dwknippers May 30, 2018
ba1dd15
refactor(tests): use more explicit chai helpers
mattlewis92 Jun 24, 2018
9a56f4e
build: upgrade tslint rules
mattlewis92 Jun 24, 2018
c4e3c26
build(demos): fix tslint warnings
mattlewis92 Jun 24, 2018
743e216
build: upgrade dependencies
mattlewis92 Jun 24, 2018
0d7d184
test: fix week view tests
mattlewis92 Jun 24, 2018
3b2482a
build: fix aot with missing date adapter
mattlewis92 Jun 25, 2018
2dddd25
build: npm update
mattlewis92 Jun 25, 2018
3fb7bb7
build: swap out bootstrap dependency
mattlewis92 Jun 25, 2018
af8149c
docs(demos): fix stackblitz demo
mattlewis92 Jun 25, 2018
6ada99e
build: reinstall all deps
mattlewis92 Jun 25, 2018
d6d61c4
feat(tooltip): allow tooltip to be auto positioned
mattlewis92 Jun 25, 2018
479c75a
feat(event-times-changed): expose type of event (resize, drag or drop)
mattlewis92 Jun 28, 2018
5353b15
build: upgrade dependencies
mattlewis92 Jun 28, 2018
249f5e9
refactor: use proper drag end event
mattlewis92 Jun 28, 2018
7cab7b6
Merge branch 'master' into 0.26
mattlewis92 Jun 29, 2018
9fe2a0f
fix: handle scrolling the page while dragging evwnts
mattlewis92 Jun 29, 2018
8ae3ced
Merge branch '0.26' of github.com:mattlewis92/angular-calendar into 0.26
mattlewis92 Jun 29, 2018
db0c880
feat(month-view): allow the open day events animation to be overridden
mattlewis92 Jul 2, 2018
6e170bc
build: npm update
mattlewis92 Jul 2, 2018
61f4b62
chore: merge with master
mattlewis92 Jul 5, 2018
13a688e
feat(month-view): add class to day that's being highlighted
mattlewis92 Jul 8, 2018
571c36b
build: upgrade calendar-utils
mattlewis92 Jul 11, 2018
ca2705d
build: upgrade dependencies
mattlewis92 Jul 17, 2018
e5d8630
Merge branch 'master' into 0.26
mattlewis92 Jul 20, 2018
e3b402c
build: pin calendar-utils
mattlewis92 Jul 20, 2018
f2e26a2
build: upgrade dependencies
mattlewis92 Jul 24, 2018
bcd6a59
chore: merge with master
mattlewis92 Jul 26, 2018
7ce5967
Merge branch 'master' into 0.26
mattlewis92 Jul 30, 2018
1cc282c
chore: merge with master
mattlewis92 Jul 30, 2018
e54c140
chore: merge with master
mattlewis92 Jul 30, 2018
cab760d
refactor: use a Set instead of a WeakSet to fix ie11 compat
mattlewis92 Jul 31, 2018
b06e470
test: run tests in UTC
mattlewis92 Jul 31, 2018
7e7c374
test: fix tests
mattlewis92 Jul 31, 2018
5cfbfc7
feat: add time grid to the week view
mattlewis92 Jul 31, 2018
0b4fcd5
feat(week-view): allow total days in the week to be customised
mattlewis92 Jul 31, 2018
2d22869
build: upgrade dependencies
mattlewis92 Aug 3, 2018
b11260a
build: upgrade dependencies
mattlewis92 Aug 3, 2018
3147854
style: reformat with prettier
mattlewis92 Aug 3, 2018
df339b9
fix: allow events that end on different days to be dragged
mattlewis92 Aug 3, 2018
1185d27
feat: expose the full week view on the beforeViewRender output
mattlewis92 Aug 5, 2018
aa82729
build: npm update
mattlewis92 Aug 5, 2018
e3d6652
Merge branch 'master' into 0.26
mattlewis92 Aug 5, 2018
62c41b9
feat(day-view): allow dragging and dropping all day events
mattlewis92 Aug 5, 2018
fb4bbb7
fix(week-view): use correct event left positioning
mattlewis92 Aug 6, 2018
2c8a6db
feat: allow event actions template to be customised
mattlewis92 Aug 6, 2018
6a7e956
test: fix all failing tests
mattlewis92 Aug 6, 2018
66e9223
fix(week-view): fix cursor on draggable events
mattlewis92 Aug 6, 2018
c6b095a
feat(day-view): remove the mwl-calendar-all-day-event component
mattlewis92 Aug 6, 2018
4bfac45
fix(resizable): prevent resizing of elements when not on top stack
mattlewis92 Aug 6, 2018
aa7edd9
feat(week-view): make the week view title work with no config with i18n
mattlewis92 Aug 6, 2018
46a650a
fix: more robust way of telling if an event is dropped within a calendar
mattlewis92 Aug 8, 2018
710431c
build: upgrade dependencies
mattlewis92 Aug 8, 2018
25f8db5
build: upgrade dependencies
mattlewis92 Aug 11, 2018
08661c4
fix: allow the mouse to be moved slightly when clicking events
mattlewis92 Aug 11, 2018
1706b32
build: upgrade dependencies
mattlewis92 Aug 13, 2018
b682fa7
build: upgrade dependencies to final versions
mattlewis92 Aug 29, 2018
6bb89fe
build: upgrade dependencies
mattlewis92 Aug 29, 2018
a894502
build: remove unused dep
mattlewis92 Aug 29, 2018
f13e03d
build: upgrade dependencies
mattlewis92 Sep 1, 2018
40a82a2
build: remove yarn.lock from example
mattlewis92 Sep 1, 2018
21fa48f
build: switch to the angular cli
mattlewis92 Sep 2, 2018
f2bb934
build: upgrade dependencies
mattlewis92 Sep 3, 2018
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion demos/demo-modules/draggable-external-events/component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,9 +55,13 @@ export class DemoComponent {
eventDropped({
event,
newStart,
newEnd
newEnd,
allDay
}: CalendarEventTimesChangedEvent): void {
const externalIndex = this.externalEvents.indexOf(event);
if (typeof allDay !== 'undefined') {
event.allDay = allDay;
}
if (externalIndex > -1) {
this.externalEvents.splice(externalIndex, 1);
this.events.push(event);
Expand Down
11 changes: 9 additions & 2 deletions demos/demo-modules/kitchen-sink/component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,13 @@ export class DemoComponent {
end: addDays(new Date(), 1),
title: 'A 3 day event',
color: colors.red,
actions: this.actions
actions: this.actions,
allDay: true,
resizable: {
beforeStart: true,
afterEnd: true
},
draggable: true
},
{
start: startOfDay(new Date()),
Expand All @@ -94,7 +100,8 @@ export class DemoComponent {
start: subDays(endOfMonth(new Date()), 3),
end: addDays(endOfMonth(new Date()), 3),
title: 'A long event that spans 2 months',
color: colors.blue
color: colors.blue,
allDay: true
},
{
start: addHours(startOfDay(new Date()), 2),
Expand Down
12 changes: 6 additions & 6 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -164,9 +164,9 @@
"@angular/core": ">=6.0.0 <8.0.0"
},
"dependencies": {
"angular-draggable-droppable": "4.0.0-beta.13",
"angular-draggable-droppable": "^4.0.0-beta.16",
"angular-resizable-element": "^3.2.0",
"calendar-utils": "0.2.0-alpha.13",
"calendar-utils": "0.2.0-alpha.15",
"positioning": "^1.4.0"
},
"sideEffects": [
Expand Down
4 changes: 4 additions & 0 deletions src/date-adapters/date-adapter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -90,4 +90,8 @@ export abstract class DateAdapter implements BaseDateAdapter {
date: Date | string | number,
options?: { weekStartsOn?: number }
): Date;

abstract getHours(date: Date | string | number): number;

abstract getMinutes(date: Date | string | number): number;
}
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,13 @@ export class CalendarAngularDateFormatter
return `Week ${weekNumber} of ${year}`;
}

/**
* The time formatting down the left hand side of the week view
*/
public weekViewHour({ date, locale }: DateFormatterParams): string {
return new DatePipe(locale).transform(date, 'h a', null, locale);
}

/**
* The time formatting down the left hand side of the day view
*/
Expand Down
5 changes: 5 additions & 0 deletions src/modules/common/calendar-date-formatter.interface.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,11 @@ export interface CalendarDateFormatterInterface {
*/
weekViewTitle({ date: Date }: DateFormatterParams): string;

/**
* The time formatting down the left hand side of the day view
*/
weekViewHour({ date: Date }: DateFormatterParams): string;

/**
* The time formatting down the left hand side of the day view
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,5 @@ export interface CalendarEventTimesChangedEvent<MetaType = any> {
event: CalendarEvent<MetaType>;
newStart: Date;
newEnd?: Date;
allDay?: boolean;
}
9 changes: 9 additions & 0 deletions src/modules/common/calendar-moment-date-formatter.provider.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,15 @@ export class CalendarMomentDateFormatter
.format('[Week] W [of] YYYY');
}

/**
* The time formatting down the left hand side of the week view
*/
public weekViewHour({ date, locale }: DateFormatterParams): string {
return this.moment(date)
.locale(locale)
.format('ha');
}

/**
* The time formatting down the left hand side of the day view
*/
Expand Down
7 changes: 7 additions & 0 deletions src/modules/common/calendar-native-date-formatter.provider.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,13 @@ export class CalendarNativeDateFormatter
return `Week ${weekNumber} of ${year}`;
}

/**
* The time formatting down the left hand side of the week view
*/
public weekViewHour({ date, locale }: DateFormatterParams): string {
return new Intl.DateTimeFormat(locale, { hour: 'numeric' }).format(date);
}

/**
* The time formatting down the left hand side of the day view
*/
Expand Down
5 changes: 4 additions & 1 deletion src/modules/common/calendar-resize-helper.provider.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,10 @@ export class CalendarResizeHelper {
) {}

validateResize({ rectangle }: { rectangle: ClientRect }): boolean {
if (this.minWidth && rectangle.width < this.minWidth) {
if (
this.minWidth &&
Math.ceil(rectangle.width) < Math.ceil(this.minWidth)
) {
return false;
}

Expand Down
72 changes: 63 additions & 9 deletions src/modules/common/util.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,13 @@
import {
CalendarEvent,
DayViewEvent,
DayViewHour,
DayViewHourSegment,
validateEvents as validateEventsWithoutLog,
WeekDay
WeekDay,
WeekViewAllDayEvent
} from 'calendar-utils';
import { DateAdapter } from '../../date-adapters/date-adapter';

export const validateEvents = (events: CalendarEvent[]) => {
const warn = (...args) => console.warn('angular-calendar', ...args);
Expand All @@ -11,14 +16,14 @@ export const validateEvents = (events: CalendarEvent[]) => {

export function isInside(outer: ClientRect, inner: ClientRect): boolean {
return (
outer.left <= inner.left &&
inner.left <= outer.right &&
outer.left <= inner.right &&
inner.right <= outer.right &&
outer.top <= inner.top &&
inner.top <= outer.bottom &&
outer.top <= inner.bottom &&
inner.bottom <= outer.bottom
Math.ceil(outer.left) <= Math.ceil(inner.left) &&
Math.ceil(inner.left) <= Math.ceil(outer.right) &&
Math.ceil(outer.left) <= Math.ceil(inner.right) &&
Math.ceil(inner.right) <= Math.ceil(outer.right) &&
Math.ceil(outer.top) <= Math.ceil(inner.top) &&
Math.ceil(inner.top) <= Math.ceil(outer.bottom) &&
Math.ceil(outer.top) <= Math.ceil(inner.bottom) &&
Math.ceil(inner.bottom) <= Math.ceil(outer.bottom)
);
}

Expand All @@ -33,3 +38,52 @@ export const trackByWeekDayHeaderDate = (index: number, day: WeekDay) =>
day.date.toISOString();

export const trackByIndex = (index: number) => index;

export const trackByHourSegment = (
index: number,
segment: DayViewHourSegment
) => segment.date.toISOString();

export const trackByHour = (index: number, hour: DayViewHour) =>
hour.segments[0].date.toISOString();

export const trackByDayOrWeekEvent = (
index: number,
weekEvent: WeekViewAllDayEvent | DayViewEvent
) => (weekEvent.event.id ? weekEvent.event.id : weekEvent.event);

const MINUTES_IN_HOUR = 60;

export function getMinutesMoved(
movedY: number,
hourSegments: number,
hourSegmentHeight: number,
eventSnapSize: number
): number {
const draggedInPixelsSnapSize = roundToNearest(
movedY,
eventSnapSize || hourSegmentHeight
);
const pixelAmountInMinutes =
MINUTES_IN_HOUR / (hourSegments * hourSegmentHeight);
return draggedInPixelsSnapSize * pixelAmountInMinutes;
}

export function getMinimumEventHeightInMinutes(
hourSegments: number,
hourSegmentHeight: number
) {
return (MINUTES_IN_HOUR / (hourSegments * hourSegmentHeight)) * 30;
}

export function getDefaultEventEnd(
dateAdapter: DateAdapter,
event: CalendarEvent,
minimumMinutes: number
): Date {
if (event.end) {
return event.end;
} else {
return dateAdapter.addMinutes(event.start, minimumMinutes);
}
}
Loading