Skip to content

Commit

Permalink
Add calendar block v1
Browse files Browse the repository at this point in the history
  • Loading branch information
jorgefilipecosta committed Feb 8, 2019
1 parent a1d79a9 commit e25812d
Show file tree
Hide file tree
Showing 11 changed files with 257 additions and 0 deletions.
3 changes: 3 additions & 0 deletions lib/load.php
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,9 @@
}
// Currently merged in core as `gutenberg_render_block_core_latest_comments`,
// expected to change soon.
if ( ! function_exists( 'render_block_core_calendar' ) ) {
require dirname( __FILE__ ) . '/../packages/block-library/src/calendar/index.php';
}
if ( ! function_exists( 'render_block_core_latest_comments' )
&& ! function_exists( 'gutenberg_render_block_core_latest_comments' ) ) {
require dirname( __FILE__ ) . '/../packages/block-library/src/latest-comments/index.php';
Expand Down
67 changes: 67 additions & 0 deletions packages/block-library/src/calendar/edit.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
/**
* External dependencies
*/
import moment from 'moment';
import memoize from 'memize';

/**
* WordPress dependencies
*/
import {
Disabled,
ServerSideRender,
} from '@wordpress/components';
import { Component } from '@wordpress/element';
import { withSelect } from '@wordpress/data';

class CalendarEdit extends Component {
constructor() {
super( ...arguments );
this.getYearMonth = memoize(
this.getYearMonth.bind( this ),
{ maxSize: 1 }
);
this.getServerSideAttributes = memoize(
this.getServerSideAttributes.bind( this ),
{ maxSize: 1 }
);
}

getYearMonth( date ) {
if ( ! date ) {
return {};
}
const momentDate = moment( date );
return {
year: momentDate.year(),
monthNum: momentDate.month() + 1,
};
}

getServerSideAttributes( attributes, date ) {
return {
...attributes,
...this.getYearMonth( date ),
};
}

render() {
return (
<Disabled>
<ServerSideRender
block="core/calendar"
attributes={ this.getServerSideAttributes(
this.props.attributes,
this.props.date
) }
/>
</Disabled>
);
}
}

export default withSelect( ( select ) => {
return {
date: select( 'core/editor' ).getEditedPostAttribute( 'date' ),
};
} )( CalendarEdit );
33 changes: 33 additions & 0 deletions packages/block-library/src/calendar/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
/**
* WordPress dependencies
*/
import { __ } from '@wordpress/i18n';

/**
* Internal dependencies
*/
import edit from './edit';

export const name = 'core/calendar';

export const settings = {
title: __( 'Calendar' ),

description: __( 'A calendar of your site’s Posts.' ),

icon: 'calendar',

category: 'widgets',

keywords: [ __( 'posts' ), __( 'archive' ) ],

supports: {
align: true,
},

edit,

save() {
return null;
},
};
60 changes: 60 additions & 0 deletions packages/block-library/src/calendar/index.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
<?php
/**
* Server-side rendering of the `core/calendar` block.
*
* @package WordPress
*/

/**
* Renders the `core/calendar` block on server.
*
* @param array $attributes The block attributes.
*
* @return string Returns the block content.
*/
function render_block_core_calendar( $attributes ) {
global $monthnum, $year;
if ( isset( $attributes['monthNum'] ) ) {
$monthnum = $attributes['monthNum'];
}

if ( isset( $attributes['year'] ) ) {
$year = $attributes['year'];
}
$custom_class_name = empty( $attributes['className'] ) ? '' : ' ' . $attributes['className'];
$align_class_name = empty( $attributes['align'] ) ? '' : " align{$attributes['align']}";

return sprintf(
'<div class="%1$s">%2$s</div>',
esc_attr( 'wp-block-calendar' . $custom_class_name . $align_class_name ),
get_calendar( true, false )
);
}

/**
* Registers the `core/calendar` block on server.
*/
function register_block_core_calendar() {
register_block_type(
'core/calendar',
array(
'attributes' => array(
'align' => array(
'type' => 'string',
),
'className' => array(
'type' => 'string',
),
'monthNum' => array(
'type' => 'integer',
),
'year' => array(
'type' => 'integer',
),
),
'render_callback' => 'render_block_core_calendar',
)
);
}

add_action( 'init', 'register_block_core_calendar' );
61 changes: 61 additions & 0 deletions packages/block-library/src/calendar/style.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
.wp-block-calendar {
text-align: center;
border: 2px solid #ebecee;

table {
width: 100%;
border-collapse: collapse;
font-family: $default-font;
}
table thead {
display: table-row-group;
}

table tfoot {
display: table-header-group;
border-bottom: 2px solid #ebecee;
}

table tfoot,
caption {
font-weight: 600;
background: #edeff0;
}

table tfoot tr td#prev a,
table tfoot tr td#next a {
color: transparent;
overflow: hidden;
max-height: 40px;
width: 16px;

}

table tfoot tr td#prev a::before,
table tfoot tr td#next a::after {
// Disabling lint because in this case we need dashicons and not
// a generic font.
/* stylelint-disable */
font-family: dashicons;
/* stylelint-enable */
display: inline-block;
color: $black;
}

table tfoot tr td#prev a::before {
content: "\f141";
}

table tfoot tr td#next a::after {
content: "\f139";
}

table td,
table th {
border: none;
}

a {
text-decoration: underline;
}
}
2 changes: 2 additions & 0 deletions packages/block-library/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import * as gallery from './gallery';
import * as archives from './archives';
import * as audio from './audio';
import * as button from './button';
import * as calendar from './calendar';
import * as categories from './categories';
import * as code from './code';
import * as columns from './columns';
Expand Down Expand Up @@ -67,6 +68,7 @@ export const registerCoreBlocks = () => {
archives,
audio,
button,
calendar,
categories,
code,
columns,
Expand Down
1 change: 1 addition & 0 deletions packages/block-library/src/style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
@import "./block/edit-panel/style.scss";
@import "./block/indicator/style.scss";
@import "./button/style.scss";
@import "./calendar/style.scss";
@import "./categories/style.scss";
@import "./columns/style.scss";
@import "./cover/style.scss";
Expand Down
1 change: 1 addition & 0 deletions test/integration/full-content/fixtures/core__calendar.html
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
<!-- wp:calendar /-->
10 changes: 10 additions & 0 deletions test/integration/full-content/fixtures/core__calendar.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
[
{
"clientId": "_clientId_0",
"name": "core/calendar",
"isValid": true,
"attributes": {},
"innerBlocks": [],
"originalContent": ""
}
]
18 changes: 18 additions & 0 deletions test/integration/full-content/fixtures/core__calendar.parsed.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
[
{
"blockName": "core/calendar",
"attrs": {},
"innerBlocks": [],
"innerHTML": "",
"innerContent": []
},
{
"blockName": null,
"attrs": {},
"innerBlocks": [],
"innerHTML": "\n",
"innerContent": [
"\n"
]
}
]
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
<!-- wp:calendar /-->

0 comments on commit e25812d

Please sign in to comment.