$ -> # An editor for CMS linklist attributes. # Creates the DOM for one link element of the linklist and substitutes the # title and url attribute. template = (attributes) -> attributes ||= {} description = attributes['description'] || '' title = attributes['title'] || '' url = attributes['url'] || '' $("
") contentBrowserButtonTemplate = -> icon = $('') .addClass('editing-icon') .addClass('editing-icon-plus') button = $('') .addClass('editing-button') .addClass('editing-green') .addClass('add-link') .html(icon) button # Returns the closest linklist DOM element. getCmsField = (element) -> element.closest('[data-scrivito-field-type=linklist]') # Saves the entire linklist to the CMS and stores the last successfully saved value. save = (cmsField) -> value = getAttributes(cmsField) lastSaved = getLastSaved(cmsField) unless JSON.stringify(value) == JSON.stringify(lastSaved) cmsField.scrivito('save', value).done -> cmsField.trigger('save.scrivito_editors') storeLastSaved(cmsField, value) # Run when clicking the '...' button inside a li. onOpenContentBrowser = (event) -> event.preventDefault() linkItem = $(event.currentTarget).closest('li') cmsField = getCmsField(linkItem) filters = cmsField.data('filters') filterContext = cmsField.data('filterContext') id = linkItem.data('id') selection = if id then [id] else [] scrivito.content_browser.open selection: selection filters: filters filter_context: filterContext selection_mode: 'single' .done (selection) => onContentBrowserSaveLinkItem(selection, linkItem) # Resource browser callback for saving a single link. onContentBrowserSaveLinkItem = (selection, linkItem) -> id = selection[0] return unless id url = buildUrl(id) val = "Content browser selection (#{url})" linkItem .data "id", id .find('[name=url]') .data "value", url .val val # trigger save after inserting the value cmsField = getCmsField(linkItem) save(cmsField) true # Transforms an obj id into an url that can be parsed by Scrivito # to establish an internal link. buildUrl = (id) -> "/#{id}" # Collects all link attributes for a given linklist. getAttributes = (cmsField) -> items = $(cmsField).find('li') attributes = for item in items item = $(item) title = item.find('[name=title]').val() input = item.find('[name=url]') url = input.data('value') || input.val() # Make sure the url is not empty. if !isEmpty(url) 'title': title 'url': url # Remove empty array elements. removeEmptyElements(attributes) isEmpty = (value) -> !value removeEmptyElements = (array) -> $.grep(array, (n) -> n) # Adds a new link to the linklist. addLink = (event) -> event.preventDefault() cmsField = getCmsField($(event.currentTarget)) content = $('
  • ').html(template()) cmsField.find('ul').append(content) # Removes a link from the linklist. removeLink = (event) -> event.preventDefault() target = $(event.currentTarget) cmsField = getCmsField(target) target.closest('li').remove() save(cmsField) # Turns the server side generated linklist data into the linklist editor using a template. transformLinks = (cmsFields) -> cmsFields.append(contentBrowserButtonTemplate) items = cmsFields.find('li') for item in items item = $(item) content = template description: item.data('description') title: item.data('title') url: item.data('url') item.html(content) .find('[name=url]') .on 'focus', -> input = $(this) raw = input.data 'value' input.val raw if raw input.data 'value', null # Returns the last saved value. getLastSaved = (cmsField) -> cmsField.data('last-saved') # Stores a given value as last saved. storeLastSaved = (cmsField, value) -> $(cmsField).data('last-saved', value) # Automatically save when focus is lost. onBlur = (event) -> cmsField = getCmsField($(event.currentTarget)) save(cmsField) initialize = (root) -> linklistElements = $(root).find('[data-scrivito-field-type="linklist"]:not([data-editor]), [data-editor~="linklist"]') if linklistElements.length transformLinks(linklistElements) for linklistElement in linklistElements storeLastSaved(linklistElement, getAttributes(linklistElement)) linklistElements.on 'blur', 'li input', onBlur linklistElements.on 'click', 'li a.delete', removeLink linklistElements.on 'click', 'button.add-link', addLink linklistElements.on 'click', 'a.content-browser-open', onOpenContentBrowser linklistElements.find('ul').sortable update: (event) -> cmsField = getCmsField($(event.target)) save(cmsField) # Initialize linklist editor and setup event callbacks. scrivito.on 'content', (root) -> if scrivito.in_editable_view() initialize(root)