com.aimluck.eip.modules.screens.AddressBookWordXlsExportScreen.java Source code

Java tutorial

Introduction

Here is the source code for com.aimluck.eip.modules.screens.AddressBookWordXlsExportScreen.java

Source

/*
 * Aipo is a groupware program developed by TOWN, Inc.
 * Copyright (C) 2004-2015 TOWN, Inc.
 * http://www.aipo.com
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package com.aimluck.eip.modules.screens;

import org.apache.jetspeed.services.logging.JetspeedLogFactoryService;
import org.apache.jetspeed.services.logging.JetspeedLogger;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.turbine.util.RunData;
import org.apache.velocity.context.Context;

import com.aimluck.eip.addressbook.AddressBookFilterdSelectData;
import com.aimluck.eip.addressbook.AddressBookResultData;
import com.aimluck.eip.common.ALDBErrorException;
import com.aimluck.eip.common.ALPageNotFoundException;
import com.aimluck.eip.services.accessctl.ALAccessControlConstants;
import com.aimluck.eip.services.eventlog.ALEventlogFactoryService;
import com.aimluck.eip.util.ALEipUtils;

/**
 * ?????
 */
public class AddressBookWordXlsExportScreen extends ALXlsScreen {

    /** logger */
    private static final JetspeedLogger logger = JetspeedLogFactoryService
            .getLogger(AddressBookWordXlsExportScreen.class.getName());

    public static final String FILE_NAME = "addressbook.xls";

    /** ID */
    private String userid;

    /** ???? */
    private String aclPortletFeature = null;

    /**
     * ?????
     *
     * @param action
     * @param rundata
     * @param context
     */
    @Override
    public void init(RunData rundata, Context context) throws ALPageNotFoundException, ALDBErrorException {

        String target_user_id = rundata.getParameters().getString("target_user_id"/*
                                                                                   * AddressBookUtils.
                                                                                   * TARGET_USER_ID
                                                                                   */);
        userid = Integer.toString(ALEipUtils.getUserId(rundata));

        // 
        if (
        // target_user_id == null || "".equals(target_user_id)
        // ||
        userid.equals(target_user_id)) {
            aclPortletFeature = ALAccessControlConstants.POERTLET_FEATURE_ADDRESSBOOK_ADDRESS_OUTSIDE;
        }
        // else {
        // aclPortletFeature =
        // ALAccessControlConstants.POERTLET_FEATURE_TIMECARD_TIMECARD_OTHER;
        // }

        super.init(rundata, context);
    }

    @Override
    protected boolean createHSSFWorkbook(RunData rundata, Context context, HSSFWorkbook wb) {
        try {
            setupAddressBookSheet(rundata, context, wb);
        } catch (Exception e) {
            logger.error("AddressBookWordXlsExportScreen.createHSSFWorkbook", e);
            return false;
        }
        return true;
    }

    private void setupAddressBookSheet(RunData rundata, Context context, HSSFWorkbook wb) throws Exception {

        String sheet_name = "";
        // ?
        String[] headers = { "???", "???", "", "?",
                "??", "?", "??",
                "??", "??", "?", "?", "?", "FAX?",
                "URL", "???", "" };
        // 01
        short[] cell_enc_types = { HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16,
                HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16,
                HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16,
                HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16,
                HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16, HSSFCell.ENCODING_UTF_16,
                HSSFCell.ENCODING_UTF_16 };
        HSSFSheet sheet = createHSSFSheet(wb, sheet_name, headers, cell_enc_types);

        int rowcount = 0;

        // ?
        HSSFCellStyle style_col = wb.createCellStyle();
        style_col.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
        style_col.setAlignment(HSSFCellStyle.ALIGN_JUSTIFY);

        AddressBookFilterdSelectData listData;
        listData = new AddressBookFilterdSelectData();

        listData.initField();
        listData.setRowsNum(1000);
        listData.doSelectList(this, rundata, context);
        listData.loadGroups(rundata, context);
        int page_num = listData.getPagesNum();
        int current_page = 1;
        while (true) {
            int listsize = listData.getList().size();
            AddressBookResultData rd;
            for (int j = 0; j < listsize; j++) {
                rd = (AddressBookResultData) listData.getList().get(j);
                String[] rows = { rd.getName().getValue(), rd.getNameKana().getValue(), rd.getEmail().getValue(),
                        rd.getTelephone().getValue(), rd.getCellularPhone().getValue(),
                        rd.getCellularMail().getValue(), rd.getCompanyName().getValue(),
                        rd.getCompanyNameKana().getValue(), rd.getPostName().getValue(), rd.getZipcode().getValue(),
                        rd.getCompanyAddress().getValue(), rd.getCompanyTelephone().getValue(),
                        rd.getCompanyFaxNumber().getValue(), rd.getCompanyUrl().getValue(),
                        rd.getPositionName().getValue(), rd.getNoteRaw() };

                rowcount = rowcount + 1;
                addRow(sheet.createRow(rowcount), cell_enc_types, rows);
            }

            current_page++;
            if (current_page > page_num) {
                break;
            }
            listData.setCurrentPage(current_page);
            listData.doSelectList(this, rundata, context);
        }

        int uid = ALEipUtils.getUserId(rundata);
        ALEventlogFactoryService.getInstance().getEventlogHandler().logXlsScreen(uid, "",
                163/* ALEventlogConstants.PORTLET_TYPE_ADDRESSBOOK_XLS_SCREEN */);
    }

    @Override
    protected String getFileName() {
        return FILE_NAME;
    }

    /**
     * ?? ???????
     *
     * @return
     */
    @Override
    public String getAclPortletFeature() {
        return aclPortletFeature;
    }

}