123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 |
- // Copyright 2021 The Casdoor Authors. All Rights Reserved.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- import React from "react";
- import {Link} from "react-router-dom";
- import {Button, Col, List, Row, Table, Tooltip} from "antd";
- import {EditOutlined} from "@ant-design/icons";
- import moment from "moment";
- import * as Setting from "./Setting";
- import * as ApplicationBackend from "./backend/ApplicationBackend";
- import i18next from "i18next";
- import BaseListPage from "./BaseListPage";
- import PopconfirmModal from "./common/modal/PopconfirmModal";
- class ApplicationListPage extends BaseListPage {
- constructor(props) {
- super(props);
- }
- componentDidMount() {
- this.setState({
- organizationName: this.props.account.owner,
- });
- }
- newApplication() {
- const randomName = Setting.getRandomName();
- return {
- owner: "admin", // this.props.account.applicationName,
- name: `application_${randomName}`,
- organization: this.state.organizationName,
- createdTime: moment().format(),
- displayName: `New Application - ${randomName}`,
- logo: `${Setting.StaticBaseUrl}/img/casdoor-logo_1185x256.png`,
- enablePassword: true,
- enableSignUp: true,
- enableSigninSession: false,
- enableCodeSignin: false,
- enableSamlCompress: false,
- providers: [
- {name: "provider_captcha_default", canSignUp: false, canSignIn: false, canUnlink: false, prompted: false, alertType: "None"},
- ],
- signupItems: [
- {name: "ID", visible: false, required: true, rule: "Random"},
- {name: "Username", visible: true, required: true, rule: "None"},
- {name: "Display name", visible: true, required: true, rule: "None"},
- {name: "Password", visible: true, required: true, rule: "None"},
- {name: "Confirm password", visible: true, required: true, rule: "None"},
- {name: "Email", visible: true, required: true, rule: "Normal"},
- {name: "Phone", visible: true, required: true, rule: "None"},
- {name: "Agreement", visible: true, required: true, rule: "None"},
- ],
- cert: "cert-built-in",
- redirectUris: ["http://localhost:9000/callback"],
- tokenFormat: "JWT",
- expireInHours: 24 * 7,
- formOffset: 2,
- };
- }
- addApplication() {
- const newApplication = this.newApplication();
- ApplicationBackend.addApplication(newApplication)
- .then((res) => {
- if (res.status === "ok") {
- this.props.history.push({pathname: `/applications/${newApplication.organization}/${newApplication.name}`, mode: "add"});
- Setting.showMessage("success", i18next.t("general:Successfully added"));
- } else {
- Setting.showMessage("error", `${i18next.t("general:Failed to add")}: ${res.msg}`);
- }
- })
- .catch(error => {
- Setting.showMessage("error", `${i18next.t("general:Failed to connect to server")}: ${error}`);
- });
- }
- deleteApplication(i) {
- ApplicationBackend.deleteApplication(this.state.data[i])
- .then((res) => {
- if (res.status === "ok") {
- Setting.showMessage("success", i18next.t("general:Successfully deleted"));
- this.setState({
- data: Setting.deleteRow(this.state.data, i),
- pagination: {total: this.state.pagination.total - 1},
- });
- } else {
- Setting.showMessage("error", `${i18next.t("general:Failed to delete")}: ${res.msg}`);
- }
- })
- .catch(error => {
- Setting.showMessage("error", `${i18next.t("general:Failed to connect to server")}: ${error}`);
- });
- }
- renderTable(applications) {
- const columns = [
- {
- title: i18next.t("general:Name"),
- dataIndex: "name",
- key: "name",
- width: "150px",
- fixed: "left",
- sorter: true,
- ...this.getColumnSearchProps("name"),
- render: (text, record, index) => {
- return (
- <Link to={`/applications/${record.organization}/${text}`}>
- {text}
- </Link>
- );
- },
- },
- {
- title: i18next.t("general:Created time"),
- dataIndex: "createdTime",
- key: "createdTime",
- width: "160px",
- sorter: true,
- render: (text, record, index) => {
- return Setting.getFormattedDate(text);
- },
- },
- {
- title: i18next.t("general:Display name"),
- dataIndex: "displayName",
- key: "displayName",
- // width: '100px',
- sorter: true,
- ...this.getColumnSearchProps("displayName"),
- },
- {
- title: "Logo",
- dataIndex: "logo",
- key: "logo",
- width: "200px",
- render: (text, record, index) => {
- return (
- <a target="_blank" rel="noreferrer" href={text}>
- <img src={text} alt={text} width={150} />
- </a>
- );
- },
- },
- {
- title: i18next.t("general:Organization"),
- dataIndex: "organization",
- key: "organization",
- width: "150px",
- sorter: true,
- ...this.getColumnSearchProps("organization"),
- render: (text, record, index) => {
- return (
- <Link to={`/organizations/${text}`}>
- {text}
- </Link>
- );
- },
- },
- {
- title: i18next.t("general:Providers"),
- dataIndex: "providers",
- key: "providers",
- ...this.getColumnSearchProps("providers"),
- // width: '600px',
- render: (text, record, index) => {
- const providers = text;
- if (providers.length === 0) {
- return `(${i18next.t("general:empty")})`;
- }
- const half = Math.floor((providers.length + 1) / 2);
- const getList = (providers) => {
- return (
- <List
- size="small"
- locale={{emptyText: " "}}
- dataSource={providers}
- renderItem={(providerItem, i) => {
- return (
- <List.Item>
- <div style={{display: "inline"}}>
- <Tooltip placement="topLeft" title="Edit">
- <Button style={{marginRight: "5px"}} icon={<EditOutlined />} size="small" onClick={() => Setting.goToLinkSoft(this, `/providers/${record.organization}/${providerItem.name}`)} />
- </Tooltip>
- <Link to={`/providers/${record.organization}/${providerItem.name}`}>
- {providerItem.name}
- </Link>
- </div>
- </List.Item>
- );
- }}
- />
- );
- };
- return (
- <div>
- <Row>
- <Col span={12}>
- {
- getList(providers.slice(0, half))
- }
- </Col>
- <Col span={12}>
- {
- getList(providers.slice(half))
- }
- </Col>
- </Row>
- </div>
- );
- },
- },
- {
- title: i18next.t("general:Action"),
- dataIndex: "",
- key: "op",
- width: "170px",
- fixed: (Setting.isMobile()) ? "false" : "right",
- render: (text, record, index) => {
- return (
- <div>
- <Button style={{marginTop: "10px", marginBottom: "10px", marginRight: "10px"}} type="primary" onClick={() => this.props.history.push(`/applications/${record.organization}/${record.name}`)}>{i18next.t("general:Edit")}</Button>
- <PopconfirmModal
- title={i18next.t("general:Sure to delete") + `: ${record.name} ?`}
- onConfirm={() => this.deleteApplication(index)}
- disabled={record.name === "app-built-in"}
- >
- </PopconfirmModal>
- </div>
- );
- },
- },
- ];
- const paginationProps = {
- total: this.state.pagination.total,
- showQuickJumper: true,
- showSizeChanger: true,
- showTotal: () => i18next.t("general:{total} in total").replace("{total}", this.state.pagination.total),
- };
- return (
- <div>
- <Table scroll={{x: "max-content"}} columns={columns} dataSource={applications} rowKey={(record) => `${record.owner}/${record.name}`} size="middle" bordered pagination={paginationProps}
- title={() => (
- <div>
- {i18next.t("general:Applications")}
- <Button type="primary" size="small" onClick={this.addApplication.bind(this)}>{i18next.t("general:Add")}</Button>
- </div>
- )}
- loading={this.state.loading}
- onChange={this.handleTableChange}
- />
- </div>
- );
- }
- fetch = (params = {}) => {
- const field = params.searchedColumn, value = params.searchText;
- const sortField = params.sortField, sortOrder = params.sortOrder;
- this.setState({loading: true});
- (Setting.isAdminUser(this.props.account) ? ApplicationBackend.getApplications("admin", params.pagination.current, params.pagination.pageSize, field, value, sortField, sortOrder) :
- ApplicationBackend.getApplicationsByOrganization("admin", this.state.organizationName, params.pagination.current, params.pagination.pageSize, field, value, sortField, sortOrder))
- .then((res) => {
- if (res.status === "ok") {
- this.setState({
- loading: false,
- data: res.data,
- pagination: {
- ...params.pagination,
- total: res.data2,
- },
- searchText: params.searchText,
- searchedColumn: params.searchedColumn,
- });
- } else {
- if (Setting.isResponseDenied(res)) {
- this.setState({
- loading: false,
- isAuthorized: false,
- });
- }
- }
- });
- };
- }
- export default ApplicationListPage;
|