Skip to content

arthurbernierjr/kofujs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

61 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Kofujs

kofulogo

KofuJS a slightly opinionated and elegant JS framework

Use Kofu in your app

  • If you want to use the official Kofu starter app
      npm i -g create-kofujs-app gulp-cli yarn
  • If you want to create your own app from scratch create an npm project and run
    yarn add kofujs

or

    npm i kofujs

Live demo

Starter Generator (a la create-react-app )

Frontend Framework using

  • Virtual Dom with Snabbdom
  • JSX
  • CSS-in-JS
  • Lodash ( map , filter and reduce)
  • RXJS ( The whole point is out of box Observables from the ground up)

Starter Kit Contains

- KofuJS
- Vanilla Router
- Webpack
- BrowserSync
- Babel
- Gulp
- Gulp-Nodemon

Usage information

The `ko` object contains rxjs and will be further filtered down used to use Observables for Application Stae Management
The `fu`  object contains map, filter and reduce from lodash as well as the jss library for css in jss but note: CSS In JS is built into the Komponent class with the setStyles method

What is in it Now

  /*Komponent*/

  import {
    Komponent,
    render
  } from "kofujs";

  export class HelloWorld extends Komponent {
    constructor(props) {
      super(props);
      this.handleClick = this.handleClick.bind(this)
    }

    komponentDidMount () {
      console.log('up')
    }
    handleClick() {
      console.log('hi')
    }

    render() {
      return <div className="container m-t"
      onClick={ this.handleClick }
      >
        <h1>Hello World</h1>
        </div>;
    }

  };

  render(<HelloWorld />, document.getElementById("app"));
import {
  Komponent,
  render
} from "kofujs";

export class HelloWorld extends Komponent {
  constructor(props) {
    super(props);
    const styles = {
      mainHeader : {
        backgroundImage: `url('/assets/img/bg3.jpg')`
      }
    }
    // Adds the created CSS Classes to this
    // JSS is installed by default and can be used with the this.setStyles function
    const { classes } = this.setStyles(styles)
    this.classes = classes
    // User this.state or this.data or both
    this.state = {
      reactive: " this data must be updated with SetState"
    }
    this.data = {
      unReactive: "this is available also and this will be just an object and previous data is unreachable after a key is overwritten"
    }
    // Bind Functions if necessary
    this.handleClick = this.handleClick.bind(this)
  }
  komponentGenesis(){
    console.log('genesis')
  }
  komponentDidMount () {
    console.log('mounted')
  }
  handleClick() {
    console.log('hi')
    alert('On Click Works')
  }
// This is where you put the jsx that you want to render or present it is called present so that it doesn't get confused by the render method outsided the class
  present() {
    console.log('rendering')
    return (
      <div>
        <nav className="navbar navbar-color-on-scroll navbar-transparent fixed-top navbar-expand-lg" color-on-scroll="100">
          <div className="container">
            <div className="navbar-translate">
              <a className="navbar-brand" href="#">
              KofuJS </a>
              <button className="navbar-toggler" type="button" data-toggle="collapse" aria-expanded="false" aria-label="Toggle navigation"
              onClick={this.handleClick}
              >
                <span className="sr-only">Toggle navigation</span>
                <span className="navbar-toggler-icon"></span>
                <span className="navbar-toggler-icon"></span>
                <span className="navbar-toggler-icon"></span>
              </button>
          </div>
          <div className="collapse navbar-collapse">
            <ul className="navbar-nav ml-auto">
              <li className="nav-item">
                <a href="#" className="nav-link">
                  <i className="material-icons">apps</i> Template
                </a>
              </li>
            </ul>
          </div>
        </div>
      </nav>
      <div
        className={`page-header header-filter ${this.classes.mainHeader}`}
        data-parallax="true"
        >
        <div className="container">
          <div className="row">
            <div className="col-md-8 ml-auto mr-auto">
              <div className="brand text-center">
                <h1>Hello World</h1>
                <h3 className="title text-center">It works</h3>
              </div>
            </div>
          </div>
        </div>
      </div>
      <div className="main main-raised">
        <div className="container">
          <div className="section text-center">
            <h2 className="title">KofuJS Concept Page</h2>
          </div>
        </div>
      </div>
      <footer className="footer footer-default">
        <div className="container">
          <nav className="float-left">
            <ul>
              <li>
                <a href="https://kofujs.io/">
                  Built with KofuJS
                </a>
              </li>
            </ul>
          </nav>
          <div className="copyright float-right">
            &copy;
              { new Date().getFullYear() }, made with <i className="material-icons">favorite</i> by{' '}
            <a href="https://arthurbernierjr.com/" target="blank">Arthur Bernier Jr.</a> for a better web.
          </div>
        </div>
        </footer>
      </div>
    )
  }

};

render(<HelloWorld />, document.getElementById("app"));
import { Komponent , render, fu} from '../../kofujs'

/*  Using fu.mapElements to display data from a list*/

const styles = {
  mainPageHeading: {
    backgroundColor: 'red'
  }
}

class Child extends Komponent {
  constructor (props)  {
    super (props)
  }
  present () {
    return( <h3>I am a child</h3>)
  }
}

class Example extends Komponent{
  constructor (props)  {
    super (props)
    this.classes = this.setStyles(styles).classes
  }

  komponentDidMount () {
    console.log('Hello world')
  }
    present () {
    const g = [1,2,3,4,5]

    return (
        <div>
        <h1 className={`${this.classes.mainPageHeading}`}> Hello World</h1>
          <div>{fu.mapElements( g, (item, i) => <li><Child /></li>)}</div>
        </div>
    )
  }
}

render(<Example />, document.getElementById('app'))
Not listed but included : import {ko} in your file and you can use all Rx.js methods ko contains all rx js methods, import {fu} and a simple utilities are included
export var fu = {
  map: map, // lodash map
  filter: filter, // lodash filter
  reduce: reduce, // lodash reduce
  css: jss, // jss is exported as fu.css
  preset: preset, // jss preset default
  color: color // color npm package
};

Coming Soon .kofu files with templates
Computed properties coming soon

Getting started developing

git clone git@github.com:arthurbernierjr/kofujs.git
cd kofujs
npm i -g gulp-cli
npm i
npm run compile
npm run watch

Credits

  • Demo uses Custom Bootstrap 4 theme created by Creative Tim

Goal is to be able to make it so it works like NUXT or NEXT out of the box with the Starter Kit but it could also be used as a mere SPA with using just Kofu.js and Vanilla Router todo : fork Vanilla Router and make Kofu Router

Project Reason

- Academic pursuit as a faculty member
- Main purpose is to show students inner workings of FrontEnd / Full Satck Frameworks
- Secondary Purpose is for usage with Freelance Projects
- Third purpose is that maybe someone will love the project and use it for their own projects and hopefully help make it better

Timeline to Beta

- Hopeful Beta is May 22 2020

Resources and Inspiration

  • Evan You and VueJS
  • Jose Santos Garcia Web Developer Starter kit
  • Marvin Frachet Create a FrontEnd Framework
  • Jafar Husain (ASYNC with RXJS)
  • Sean Larkin (Webpack)
  • Kyle Simpson (Getify)
  • Brad Traversy
  • Stephen Grider
  • Colt Steele

todo

- Create a build chain and dev server setup with Gulp, Webpack, Express, Nodemon and BrowserSync (Done)
- Integrate JSS (Done)
- Integrate Lodash Natively by exposing map, reduce and filter to every component (done)
- Set up RXJS

Why?

  • There are things I love about React and Things I love about Vue and things I love about Nuxt.js
  • I want this project to be a true framework that includes a Router, State Management, Isomorphic Behavior, and Component Library out of the box
  • It also needs to be easy to use only what you need
  • I want to make this the framework you might turn to if you really want to build an application with rxjs