[%# This Source Code Form is subject to the terms of the Mozilla Public # License, v. 2.0. If a copy of the MPL was not distributed with this # file, You can obtain one at http://mozilla.org/MPL/2.0/. # # This Source Code Form is "Incompatible With Secondary Licenses", as # defined by the Mozilla Public License, v. 2.0. #%] [% PROCESS global/variables.none.tmpl %] [% items = [ { id => '', name => 'Splendidest Gear' }, { id => '#185687', name => 'Moleskine Notebook (Firefox)' }, { id => '#155749', name => 'Rickshaw Messenger Bag ' }, { id => '#155415S', name => 'Champion Hooded Sweatshirt S' }, { id => '#155415M', name => 'Champion Hooded Sweatshirt M' }, { id => '#155415L', name => 'Champion Hooded Sweatshirt L' }, { id => '#155415X', name => 'Champion Hooded Sweatshirt XL' }, { id => '#1554152', name => 'Champion Hooded Sweatshirt 2XL' }, { id => '#157452S', name => 'Very Splendid Package Ladies S' }, { id => '#157452M', name => 'Very Splendid Package Ladies M' }, { id => '#157452L', name => 'Very Splendid Package Ladies L' }, { id => '#157452X', name => 'Very Splendid Package Ladies XL' }, { id => '#1574522', name => 'Very Splendid Package Ladies 2XL' }, { id => '#157454S', name => 'Very Splendid Package Men\'s S' }, { id => '#157454M', name => 'Very Splendid Package Men\'s M' }, { id => '#157454L', name => 'Very Splendid Package Men\'s L' }, { id => '#157454X', name => 'Very Splendid Package Men\'s XL' }, { id => '#1574542', name => 'Very Splendid Package Men\'s 2XL' }, { id => '#1574543', name => 'Very Splendid Package Men\'s 3XL' }, { id => '#157451S', name => 'Most Splendid Package, S' }, { id => '#157451M', name => 'Most Splendid Package, M' }, { id => '#157451L', name => 'Most Splendid Package, L' }, { id => '#157451X', name => 'Most Splendid Package, XL' }, { id => '', name => 'Splendider Gear' }, { id => '#155751', name => 'Drawstring Tote ' }, { id => '#155340', name => 'Beanie' }, { id => '#155339', name => 'Black Cap with Tote ' }, { id => '#212669', name => 'Stoneware Ceramic Mug' }, { id => '#190928S', name => 'Firefox Tee w/Woven Tag Navy S' }, { id => '#190928M', name => 'Firefox Tee w/Woven Tag Navy M' }, { id => '#190928L', name => 'Firefox Tee w/Woven Tag Navy L' }, { id => '#190928X', name => 'Firefox Tee w/Woven Tag Navy XL' }, { id => '#1909282', name => 'Firefox Tee w/Woven Tag Navy 2XL' }, { id => '#1909283', name => 'Firefox Tee w/Woven Tag Navy 3XL' }, { id => '#190929S', name => 'Firefox SS Lapis Tee Lapis S' }, { id => '#190929M', name => 'Firefox SS Lapis Tee Lapis M' }, { id => '#190929L', name => 'Firefox SS Lapis Tee Lapis L' }, { id => '#190929X', name => 'Firefox SS Lapis Tee Lapis XL' }, { id => '#155413S', name => 'Ladies\' T-shirt Navy S' }, { id => '#155413M', name => 'Ladies\' T-shirt Navy M' }, { id => '#155413L', name => 'Ladies\' T-shirt Navy L' }, { id => '#155413X', name => 'Ladies\' T-shirt Navy XL' }, { id => '#1554132', name => 'Ladies\' T-shirt Navy 2XL' }, { id => '', name => 'Splendid Gear' }, { id => '#192150', name => '1.25" Firefox Button-PKG25 ' }, { id => '#197156', name => 'Firefox Tattoos- Pkg50' }, { id => '#197158', name => 'Firefox Sticker' }, { id => '#197159', name => 'Firefox Laminated Badge' }, { id => '#155754', name => 'Lanyard with Bulldog Clip (Mozilla)' }, { id => '#155756', name => 'Silicone Wristband ' }, { id => '', name => 'Limited Availability Gear' }, { id => '#265073', name => 'Mozilla Cap' }, { id => '#265080', name => 'Fox Plush' }, { id => '#265072S', name => 'Mozilla Custom Hoodie' }, { id => '#265072M', name => 'Mozilla Custom Hoodie' }, { id => '#265072L', name => 'Mozilla Custom Hoodie' }, { id => '#265072X', name => 'Mozilla Custom Hoodie' }, { id => '#2650722', name => 'Mozilla Custom Hoodie' }, { id => '#265074S', name => 'Ladies\' Firefox Logo T-Shirt' }, { id => '#265074M', name => 'Ladies\' Firefox Logo T-Shirt' }, { id => '#265074L', name => 'Ladies\' Firefox Logo T-Shirt' }, { id => '#265074X', name => 'Ladies\' Firefox Logo T-Shirt' }, { id => '#2650742', name => 'Ladies\' Firefox Logo T-Shirt' }, { id => '#265075S', name => 'Women\'s Vertical T-Shirt' }, { id => '#265075M', name => 'Women\'s Vertical T-Shirt' }, { id => '#265075L', name => 'Women\'s Vertical T-Shirt' }, { id => '#265075X', name => 'Women\'s Vertical T-Shirt' }, { id => '#2650752', name => 'Women\'s Vertical T-Shirt' }, { id => '#265078S', name => 'Mozilla Horizontal T-Shirt' }, { id => '#265078M', name => 'Mozilla Horizontal T-Shirt' }, { id => '#265078L', name => 'Mozilla Horizontal T-Shirt' }, { id => '#265078X', name => 'Mozilla Horizontal T-Shirt' }, { id => '#2650782', name => 'Mozilla Horizontal T-Shirt' }, ]; mozspaces = [ { name => 'Beijing', address1 => 'Mozilla Online Ltd, International Club Office Tower 800A', address2 => '21 Jian Guo Men Wai Avenue', city => 'Beijing', state => 'Chaoyang District', country => 'China', postcode => '100020', }, { name => 'Berlin', address1 => 'MZ Denmark ApS - Germany', address2 => 'Voltastrasse 5 / Building (Haus) 10 / Stair (Treppe) 6 / 2nd floor.', city => 'Berlin', state => 'Germany', country => 'Germany', postcode => '13355', }, { name => 'London', address1 => 'Mozilla London', address2 => '101 St. Martin\'s Lane, 3rd Floor', city => 'London', state => 'Greater London', country => 'UK', postcode => 'WC2N 4AZ', }, { name => 'Mountain View', address1 => 'Mozilla', address2 => '331 E. Evelyn Ave.', city => 'Mountain View', state => 'CA', country => 'USA', postcode => '94041', }, { name => 'Paris', address1 => 'Mozilla', address2 => '16 bis Boulevard Montmartre', city => 'Paris', state => 'Paris', country => 'France', postcode => '75009', }, { name => 'Portland', address1 => 'Mozilla Portland', address2 => 'Brewery Block 2, 1120 NW Couch St. Suite 320', city => 'Portland', state => 'OR', country => 'USA', postcode => '97209', }, { name => 'San Francisco', address1 => 'Mozilla', address2 => '2 Harrison Street, Suite 175', city => 'San Francisco', state => 'CA', country => 'USA', postcode => '94105', }, { name => 'Taipei', address1 => '4F-A1, No. 106, Sec.5, Xinyi Rd', address2 => '', city => 'Taipei City', state => 'Xinyi District', country => 'Taiwan', postcode => '11047', }, { name => 'Tokyo', address1 => '7-5-6 Roppongi', address2 => '', city => 'Minato-ku', state => 'Tokyo', country => 'Japan', postcode => '106-0032', }, { name => 'Toronto', address1 => 'Mozilla Canada', address2 => '366 Adelaide Street W, Suite 500', city => 'Toronto', state => 'Ontario', country => 'Canada', postcode => 'M5V 1R9', }, { name => 'Vancouver', address1 => 'Mozilla Canada', address2 => '163 West Hastings Street, Suite 209', city => 'Vancouver', state => 'BC', country => 'Canada', postcode => 'V6B 1H5', }, ]; PROCESS "bug/create/cost-centers.none.tmpl"; %] [% inline_style = BLOCK %] #gear_form th { text-align: right; font-weight: normal; } #gear_form .heading { text-align: left; font-weight: bold; border-top: 2px dotted #969696; } .mandatory { color: red; } [% END %] [% inline_javascript = BLOCK %] var Dom = YAHOO.util.Dom; var needed = { [% FOREACH item = items %] [% NEXT UNLESS item.id %] '[% item.id FILTER js %]': 0[% ',' UNLESS loop.last %] [% END %] }; var needed_freeform = []; var gear = [ [% FOREACH item = items %] { id: '[% item.id FILTER js %]', name: '[% item.name FILTER js %]' } [% ',' UNLESS loop.last %] [% END %] ]; var mozspaces = { [% FOREACH space = mozspaces %] '[% space.name FILTER js %]': { [% FOREACH key = space.keys.sort %] '[% key FILTER js %]': '[% space.$key FILTER js %]'[% ',' UNLESS loop.last %] [% END %] }[% ',' UNLESS loop.last %] [% END %] }; [%# implemented this way to allow for dynamic updating of mandatory fields #%] var fields = [ { id: 'firstname', mandatory: true }, { id: 'lastname', mandatory: true }, { id: 'email', mandatory: true }, { id: 'mozspace', mandatory: false }, { id: 'teamcode', mandatory: true }, { id: 'purpose', mandatory: true }, { id: 'purpose_other', mandatory: false }, { id: 'date_required', mandatory: false }, { id: 'items', mandatory: true }, { id: 'shiptofirstname', mandatory: true }, { id: 'shiptolastname', mandatory: true }, { id: 'shiptoemail', mandatory: true }, { id: 'shiptoaddress1', mandatory: true }, { id: 'shiptoaddress2', mandatory: false }, { id: 'shiptocity', mandatory: true }, { id: 'shiptostate', mandatory: true }, { id: 'shiptocountry', mandatory: true }, { id: 'shiptopostcode', mandatory: true }, { id: 'shiptophone', mandatory: true }, { id: 'shiptoidrut', mandatory: false }, { id: 'comment', mandatory: false } ]; function initFields() { [%# find fields in the form, and update the fields array #%] var rows = Dom.get('gear_form').getElementsByTagName('TR'); for (var i = 0, l = rows.length; i < l; i++) { var row = rows[i]; var field = firstChild(row, 'INPUT') || firstChild(row, 'SELECT') || firstChild(row, 'TEXTAREA'); if (!field || field.type == 'submit') continue; var id = field.id; var label = firstChild(row, 'TH'); for (var j = 0, m = fields.length; j < m; j++) { if (fields[j].id == id) { fields[j].field = field; fields[j].label = label; fields[j].caption = label.textContent; break; } } } createCalendar('date_required'); } function tagMandatoryFields() { [%# add or remove the "* mandatory" marker from fields #%] for (var i = 0, l = fields.length; i < l; i++) { var f = fields[i]; if (!f.label) continue; var caption = f.caption; if (f.mandatory) caption = caption + ' *'; f.label.innerHTML = caption; } } function validateAndSubmit() { var alert_text = ''; for(var i = 0, l = fields.length; i < l; i++) { var f = fields[i]; if (f.mandatory && !isFilledOut(f.id)) if (f.field.nodeName == 'SELECT') { alert_text += 'Please select the ' + f.caption + ".\n"; } else { alert_text += 'Please enter the ' + f.caption + ".\n"; } } if (isFilledOut('email') && !isValidEmail(Dom.get('email').value)) alert_text += "Please enter a valid Email Address.\n"; if (isFilledOut('shiptoemail') && !isValidEmail(Dom.get('shiptoemail').value)) alert_text += "Please enter a valid Shipping Email Address.\n"; if (alert_text != '') { alert(alert_text); return false; } Dom.get('short_desc').value = 'Mozilla Gear - ' + Dom.get('firstname').value + ' ' + Dom.get('lastname').value; return true; } function onPurposeChange() { var value = Dom.get('purpose').value; var other = Dom.get('purpose_other'); if (value == 'Event') { getField('purpose_other').mandatory = true; other.placeholder = 'link to wiki' Dom.removeClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } else if (value == 'Gear Space Stock') { getField('purpose_other').mandatory = true; other.placeholder = 'indicate space' Dom.removeClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } else if (value == 'Other') { getField('purpose_other').mandatory = true; other.placeholder = 'more information'; Dom.removeClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } else if (value == 'Mozillian Recognition') { getField('purpose_other').mandatory = false; Dom.addClass('purpose_other_row', 'bz_default_hidden'); Dom.removeClass('recognition_row', 'bz_default_hidden'); onRecognitionChange(); } else { getField('purpose_other').mandatory = false; Dom.addClass('purpose_other_row', 'bz_default_hidden'); Dom.addClass('recognition_row', 'bz_default_hidden'); } onRecognitionChange(); } function onRecognitionChange() { var mandatory = Dom.get('purpose').value != 'Mozillian Recognition' || !Dom.get('recognition_shipping').checked; getField('shiptoaddress1').mandatory = mandatory; getField('shiptocity').mandatory = mandatory; getField('shiptostate').mandatory = mandatory; getField('shiptocountry').mandatory = mandatory; getField('shiptopostcode').mandatory = mandatory; getField('shiptophone').mandatory = mandatory; tagMandatoryFields(); } function onMozSpaceChange() { if (Dom.get('mozspace').value) { Dom.removeClass('shipto_mozspace_container', 'bz_default_hidden'); } else { Dom.addClass('shipto_mozspace_container', 'bz_default_hidden'); } onShipToMozSpaceClick(); } function onShipToMozSpaceClick() { var address1 = address2 = city = state = country = postcode = ''; if (Dom.get('shipto_mozspace').checked) { var space = Dom.get('mozspace').value; address1 = mozspaces[space].address1; address2 = mozspaces[space].address2; city = mozspaces[space].city; state = mozspaces[space].state; country = mozspaces[space].country; postcode = mozspaces[space].postcode; } Dom.get('shiptoaddress1').value = address1; Dom.get('shiptoaddress2').value = address2; Dom.get('shiptocity').value = city; Dom.get('shiptostate').value = state; Dom.get('shiptocountry').value = country; Dom.get('shiptopostcode').value = postcode; Dom.get('shiptophone').value = ''; Dom.get('shiptoidrut').value = ''; onRecognitionChange(); } function onAddGearChange(focusInput) { var add_gear = Dom.get('add_gear').value; var isFreeform = add_gear == 'custom' || add_gear == 'other'; if (isFreeform) { Dom.addClass('quantity', 'bz_default_hidden'); resetFreeform(); Dom.get('freeform_quantity').value = Dom.get('quantity').value; Dom.removeClass('freeform_quantity', 'bz_default_hidden'); Dom.removeClass('add_freeform', 'bz_default_hidden'); if (focusInput) Dom.get('freeform_add').focus(); } else { Dom.get('quantity').value = Dom.get('freeform_quantity').value; Dom.removeClass('quantity', 'bz_default_hidden'); Dom.addClass('freeform_quantity', 'bz_default_hidden'); Dom.addClass('add_freeform', 'bz_default_hidden'); } } function firstChild(parent, name) { var a = parent.getElementsByTagName(name); return a.length == 0 ? false : a[0]; } function getField(id) { for(var i = 0, l = fields.length; i < l; i++) { if (fields[i].id == id) return fields[i]; } return false; } function addGear() { var id = Dom.get('add_gear').value; if (id == 'custom' || id == 'other') { var quantity = parseInt(Dom.get('freeform_quantity').value, 10); var name = Dom.get('freeform_add').value; if (!quantity || !name) return; needed_freeform.push({ 'type': id, 'quantity': quantity, 'name': name }); Dom.get('add_gear').value = ''; resetFreeform(); onAddGearChange(); } else { var quantity = parseInt(Dom.get('quantity').value, 10); if (!quantity || !id) return; needed[id] += quantity; } showGear(); } function resetFreeform() { Dom.get('freeform_quantity').value = '1'; Dom.get('freeform_add').value = ''; } function removeGear(id) { if (!id) return; needed[id] = 0; showGear(); } function removeFreeform(index) { needed_freeform.splice(index, 1); showGear(); } function showGear() { var html = '
' + needed[id] + ' x | ' + '' + YAHOO.lang.escapeHTML(item.name) + ' | ' + '' + ' |
' + item.quantity + ' x | ' + '(' + item.type + ') ' + YAHOO.lang.escapeHTML(item.name) + ' | ' + '' + ' |
No gear selected. |
Want gear? Follow the steps below and click Submit Request.
Requests are reviewed and processed on Monday morning (US/Pacific). Any requests received after 9am Monday will be processed the following week.
Check the gear wiki for more information about gear, including approved uses and the list of available gear.
Gear requests for Rep-driven events and campaigns should continue to be submitted through their existing process.
* Required Field
Requests will only be visible to the person who submitted it, authorized members of the Mozilla Engagement team, and our Staples Customer Service rep. We do this to help protect the personal identifying information in this [% terms.bugs %].
[% PROCESS global/footer.html.tmpl %]