This is a meteor and react project inspired by Telescopeapp.org and its underlying architecture.
The current theme relies on izzilab:material-ui and can be customized using objects. You will find the documentation here: React material-ui.
Here is a short example:
let BlueTheme =
{
spacing: Spacing,
fontFamily: 'Roboto, sans-serif',
palette: {
primary1Color: Colors.blue200,
primary2Color: Colors.blue400,
primary3Color: Colors.lightBlack,
accent1Color: Colors.pinkA200,
accent2Color: Colors.grey100,
accent3Color: Colors.grey500,
textColor: Colors.darkBlack,
alternateTextColor: Colors.white,
canvasColor: Colors.white,
borderColor: Colors.grey300,
disabledColor: ColorManipulator.fade(Colors.darkBlack, 0.3),
},
};
Check out the ThemeManager javascript file to understand the important fields.
This method is necessary to always return the correct render function.
/**
* Render helper. This makes sure it returns always the same render function
* @type {{render: (function(*=, *))}}
*/
Base2Ind.Helper = {
render(layout,view)
{
return ReactLayout.render( layout, {content(){ return (view) }} );
}
}
/**
* Example
*/
let notFound = "not Found";
Base2Ind.Helper.render(App,<div>{notFound}</div>);
You can make use of _AppDispatcher in case you need Stores and Observers in case something changes.
// use actions and dispatcher for a stateful experience
let {_AppDispatcher} = Base2Ind.Dispatcher;
// The store mixin
let {StoreMixin} = Base2Ind.Mixins;
// Handles stores
let {MessageStore} = Base2Ind.Store;
/**
* Router functions that can be used to check whether you are logged in and should proceed or
* if you are not logged in and should be redirected.
*
* @type {{checkLoggedIn: (function(*, *)), redirectIfLoggedIn: (function(*, *))}}
*/
Base2Ind.Router =
{
checkLoggedIn (ctx, redirect) {
if (!Meteor.userId()) {
redirect('/')
}
},
/**
* For public routes such as
* @param ctx
* @param redirect
*/
redirectIfLoggedIn (ctx, redirect) {
if (Meteor.userId()) {
redirect('/')
}
}
}
The following classes are available:
/**
* Base2Ind.Theme includes all custom styles for your theme based on Material UI ThemeManager.
*/
_.extend(Base2Ind.Theme,{CustomTheme}); // from core package
/**
* Base2Ind.Components includes all custom components that do not ship with Material UI
*/
_.extend(Base2Ind.Components,{NavComponent}); // From core package
/**
* Add global namespace for
* @type {{}}
*/
Base2Ind = {};
/**
* Add namespace for classes
* @type {{}}
*/
Base2Ind.Classes = {};
/**
* Build in components
* @type {{}}
*/
Base2Ind.Components = {};
/**
* Add all available mixins to project
* @type {{}}
*/
Base2Ind.Mixins = {};
/**
* Put all your Base2Ind.Dispatcher's in this object
* @type {{}}
*/
Base2Ind.Dispatcher = {};
/**
* Put all the stores in here.
* @type {{}}
*/
Base2Ind.Store = {};
I am aiming to build in these packages, such as:
- email integration
- upload
- layout
- search
- settings
- tags
- users
- api
- newsletter
- posts
- payment integration (e.g. Stripe)
Packages are further described here.
It should be possible to add a certain payment solution to this app. Strip is currently the prefered solution.
Will be used to create content and entries.
This app should maintain several layouts. These are the ones applicable at the moment.
Current default theme has:
- sidebar slide over main content
- sidebar on the left of the content
- sidebar shows automatically when there is enough screen width available and hides when there is not enough available (using media queries via window.matchMedia)
This package is supposed to integrate upload functionality, to other services but also to a local space. One of the must haves is to integrate an overview of what media has been uploaded to your server.
This is a simple server side email send on, e.g. user registers account.
A search customizable based on what ever collections are available.
render()
{
/**
* This is only an example of how search could be implemented.
*
* AutoComplete.Item will be turned into an array of results.
*/
return (
<div>
<AutoComplete
fullWidth = {true}
showAllItems = {true}
dataSource={{
a:(<AutoComplete.Item primaryText={'a'} secondaryText="☺" />),
divider:(<AutoComplete.Divider/>),
b:(<AutoComplete.Item primaryText={'b'} secondaryText="⚝" />),
}}
onUpdateInput={(t) => {console.log(t); this.setState({input1: [t, t+t, t+t+t]});}}
onNewRequest={(t, index) => {console.log('request:'+index);}} />
</div>
);
}
This package is solely for social sharing for 'this' particular content.
This package will only be usable to an admin of this site. It will help to maintain users, site content, themes, newsletter and email setup etc.
This package will come in handy when this projects has a content creation package such as posts.
This will largely be a permissions package for users.
A package to help with newsletters. It'll be possible to build your own newsletter campaign or use existing services such as mailchimp.com.
My name is Michel Herszak. I am a freelance web developer from Canada. I specialize in Meteor with React projects, and I like to build using Microservices. You can get in touch with me on Twitter: @MHerszak, online at Base2Industries or by email at michel.herszak@gmail.com.