'use strict'; define type: 'Base' version: '0.1.2' options: autoload: true initialize: (options) -> @sandbox.logger.log "initialized!" @sandbox.on "content.#{@identifier}.load", @load, @ # TODO convert options to respective types and remove != 'false' comparison if options.autoload and options.autoload != 'false' delete options.autoload @sandbox.emit "content.#{@identifier}.load" @$el.addClass "content idle" @$el.attr 'id', @identifier unless @$el.attr 'id' request_options: (extra) -> options = @sandbox.util._.omit @options, 'el', 'ref', '_ref', 'name', 'require', 'baseUrl' normalized_options = @sandbox.util.extend context: @, options, extra throw new TypeError "content.initialize: No uri provided to load content" unless normalized_options.uri? # In the case of instantiating the widget without uri # # TODO create a event listener that executes only one time and # store the uri on first load @options.uri ||= normalized_options.uri normalized_options.url = normalized_options.uri delete normalized_options.uri normalized_options.headers = @sandbox.util.extend 'X-XHR-Referer': document.location.href, normalized_options.headers normalized_options # Total number of completed loads (loaded or failed) loads: 0 # TODO move to handlers load: (options) -> # TODO move to anoter method if @loads > 0 _.invoke @sandbox._children, 'stop' if @sandbox._children?.length @$el.html '' @loading?.abort() @spinner?.stop() # Give user some feedback # TODO move spinner outside this component? And use only css # classes instead @spinner = @sandbox.ui.loader @$el @$el.addClass "loading" @$el.removeClass "idle" # TODO remove jQuery dependency @loading = $.ajax(@request_options options).done(@loaded).fail(@failed).always(@ended) @sandbox.emit "content.#{@identifier}.loading", @loading # Executed upon successfully loaded loaded: (response) -> # Will also initialize sandbox in this element, also firing any # other widget in the responded html @html response # Executed upon failure loaded failed: (xhr) -> switch xhr.status # abort when 0 # TODO default abort message @sandbox.emit "content.#{@identifier}.loading_aborted" # forbidden when 401 # TODO default forbidden message @sandbox.emit "content.#{@identifier}.loading_unauthorized" else @sandbox.emit "content.#{@identifier}.loading_failed" # TODO better debugging code location if @sandbox.debug.enabled html = "

Content Widget: Failed to load Content. Click to retry.

" html += xhr.responseText html = html.replace /\n/g, '
' else # TODO prettier default user message message html = "Failed to load content. Click to retry." # TODO change method name to retry # TODO treat complex settings cases, and better store the settings @$el.one('click', => @load()) @html html # Always executed after the load temptative ended: -> @$el.removeClass "loading" @$el.addClass "idle" @loads++ # TODO move to anoter method @spinner?.stop() @spinner = null @loading = null