da_html

da_html.cr

My personal Crystal shard to create sanitized HTML.

Currently, Crustal 0.26.1, you have to include the setup a special def initialize on the module to do the final rendering if you use an intermediary module instead of including DA_HTML::Base directly:

   module Something
     include DA_HTML::Base
     def my_tag
       tag(:my_tag) { }
     end
   end

   module B
     include Something
   end

   struct C
     include B

     # Not necessary if you include DA_HTML::Base directly
     # or use an include DA_HTML::Base via included macro:
     def initialize
       super
     end
   end

Different designs were designed and implemented before settling on server-side rendering for all HTML. (No client-side rendering, such as in React/JSX) The reason is to decrease typos and other errors via the Crystal compiler. Using Crystal to render both on the server-side and client-side was also dismissed because the complexity in combining Crystal and Javascript contexts.

The easiest way (i.e. less code, fewest bugs, cognitive load of the developer) is thus:

  • Render all HTML templates and output on the server.
  • Send content via AJAX calls (and if possible HTTP compression) to browser (i.e. client).
  • Browser adds Javascript events, actions, etc.
  • HTML is added to DOM.

Quick Intro:

  require "da_html"
  DA_HTML.to_html {
    p {
      strong { "hello" }
    }
  }

Custom Tags:

  struct My_Page

    include DA_HTML::Base

    def my_tag(*args)
      args.each { |x|
        # sanitize args
      }

      tag :my_tag, args do
        result = yield
        text(result) if result.is_a?(String)
      end

    end # def

    def self.to_html
      page = new
      with page yield
      page.io.to_s
    end # def

  end # === class My_Page

  My_Page.to_html {
    my_tag { "some text" }
  }

Partials:

  module My_Partial
    def my_tag
      tag(:my_tag) { }
    end
  end

  struct My_Page
    include DA_HTML::Base
    include My_Partial

    def self.to_html
      page = new
      with page yield
      page.io.to_s
    end # def
  end

  My_Page.to_html { |page|
    div { }
    my_tag
  }

Security:

Handle this "window.opener API." security vulnerability:

Repository

da_html

Owner
Statistic
  • 0
  • 0
  • 0
  • 0
  • 5
  • almost 4 years ago
  • September 16, 2017
License

MIT License

Links
Synced at

Sat, 21 Dec 2024 06:07:29 GMT

Languages